Rev 780 |
Rev 877 |
Go to most recent revision |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
/********************************************************************************************
** iLand - an individual based forest landscape and disturbance model
** http://iland.boku.ac.at
** Copyright (C) 2009- Werner Rammer, Rupert Seidl
**
** This program is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation, either version 3 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program. If not, see <http://www.gnu.org/licenses/>.
********************************************************************************************/
#include "helper.h"
#include <QtCore>
#ifdef ILAND_GUI
#if QT_VERSION < 0x050000
#include <QtGui>
#else
#include <QtWidgets>
#endif
#endif
#include <QColor>
//#include "cycle.h"
#include <limits>
#include "version.h"
Helper::Helper()
{
}
QString Helper::currentRevision()
{
//QString cur_revision="$Revision: 202 $";
QString cur_revision = QString(svnRevision());
return cur_revision; //.section(" ",1,1);
}
QString Helper::loadTextFile(const QString& fileName)
{
QFile file(fileName);
if (!file.open(QIODevice::ReadOnly)) {
return "";
}
QTextStream s(&file);
//s.setCodec("UTF-8");
QString result=s.readAll();
return result;
}
void Helper::saveToTextFile(const QString& fileName, const QString& text)
{
QFile file(fileName);
if (!file.open(QIODevice::WriteOnly)) {
return;
}
QTextStream s(&file);
s << text;
}
QByteArray Helper::loadFile(const QString& fileName)
{
QFile file(fileName);
if (!file.open(QIODevice::ReadOnly)) {
return QByteArray();
}
QTextStream s(&file);
QByteArray result;
s >> result;
return result;
}
void Helper::saveToFile(const QString &fileName, const QByteArray &data)
{
QFile file(fileName);
if (!file.open(QIODevice::WriteOnly)) {
return;
}
QTextStream s(&file);
s << data;
}
/// ask the user for a input value
QString Helper::userValue(const QString &message, const QString defaultValue, QWidget *parent)
{
#ifdef ILAND_GUI
bool ok;
QString result = QInputDialog::getText(parent, "input data", message, QLineEdit::Normal, defaultValue, &ok);
if (ok)
return result;
else
return defaultValue;
#else
Q_UNUSED(defaultValue); Q_UNUSED(message); Q_UNUSED(parent);
return QString("not availabile in non-gui-mode");
#endif
}
void Helper::msg(const QString &message, QWidget *parent)
{
#ifdef ILAND_GUI
QMessageBox::information(parent, "iLand", message);
#else
Q_UNUSED(message); Q_UNUSED(parent);
#endif
}
bool Helper::question(const QString &message, QWidget *parent)
{
#ifdef ILAND_GUI
return QMessageBox::question(parent, "iLand", message, QMessageBox::Yes | QMessageBox::No) == QMessageBox::Yes;
#else
Q_UNUSED(message); Q_UNUSED(parent);
return false;
#endif
}
QString Helper::fileDialog(const QString &title, const QString &start_directory, const QString &filter)
{
#ifdef ILAND_GUI
QString the_filter = filter;
if (the_filter.isEmpty())
the_filter = "All files (*.*)";
else
the_filter += ";;All files (*.*)"; // as 2nd filter
QString fileName = QFileDialog::getOpenFileName(0,
title, start_directory, the_filter);
#else
Q_UNUSED(title); Q_UNUSED(start_directory); Q_UNUSED(filter);
QString fileName="undefined";
#endif
return fileName;
}
void Helper::openHelp(const QString& topic)
{
#ifdef ILAND_GUI
QUrl url;
qDebug() << "current path" << QDir::currentPath();
url.setUrl(QString("file:///%1/help/%2.html").arg(QDir::currentPath(),topic) , QUrl::TolerantMode);
qDebug() << url;
if (url.isValid())
qDebug() << "url is valid";
QDesktopServices::openUrl(url);
#else
Q_UNUSED(topic);
#endif
}
QString Helper::stripHtml(const QString &source)
{
QString str = source.simplified();
return str.replace(QRegExp("<[^>]+>"),"");
}
// debugging
bool Helper::m_quiet = true;
bool Helper::m_NoDebug = false;
// colors
QColor Helper::colorFromValue(const float value,
const float min_value, const float max_value,
const bool reverse, const bool black_white)
{
float rval = value;
rval = std::max(min_value, rval);
rval = std::min(max_value, rval);
if (reverse)
rval = max_value - rval;
float rel_value;
QColor col;
if (min_value < max_value) {
// default: high values -> red (h=0), low values to blue (h=high)
rel_value = 1 - (rval - min_value) / (max_value - min_value);
if (black_white) {
int c = (1.-rel_value)*255;
col = QColor(c,c,c);
} else
col= QColor::fromHsvF(0.66666666666*rel_value, 0.95, 0.95).rgb();
} else {
col = Qt::white;
}
return col;
}
/** UpdateState.
*/
void UpdateState::invalidate(bool self)
{
if (self)
mVal++;
foreach (UpdateState *s, mChilds)
s->invalidate(true);
}
void UpdateState::saveState(UpdateState *state)
{
mSavedStates[state]=state->mVal;
}
bool UpdateState::hasChanged(UpdateState *state)
{
if (!mSavedStates.contains(state))
return true;
qDebug() << "UpdateState::hasChanged: saved: " << mSavedStates[state] << "current: " << state->mVal;
return mSavedStates[state] != state->mVal;
}
// set internal state to the current state
void UpdateState::update()
{
mCurrentVal = mVal;
}
// check if state needs update
bool UpdateState::needsUpdate()
{
return mVal > mCurrentVal;
}