mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
* #2082 Support custom date time format * Clang-format
This commit is contained in:
@@ -926,7 +926,10 @@ void RimSummaryPlot::updateTimeAxis()
|
||||
|
||||
if (m_timeAxisProperties->timeMode() == RimSummaryTimeAxisProperties::DATE)
|
||||
{
|
||||
m_qwtPlot->useDateBasedTimeAxis();
|
||||
QString dateFormat = m_timeAxisProperties->dateFormat();
|
||||
QString timeFormat = m_timeAxisProperties->timeFormat();
|
||||
|
||||
m_qwtPlot->useDateBasedTimeAxis(dateFormat, timeFormat);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
@@ -1,17 +1,17 @@
|
||||
/////////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Copyright (C) 2016 Statoil ASA
|
||||
//
|
||||
//
|
||||
// ResInsight 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.
|
||||
//
|
||||
//
|
||||
// ResInsight 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 at <http://www.gnu.org/licenses/gpl.html>
|
||||
//
|
||||
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
||||
// for more details.
|
||||
//
|
||||
/////////////////////////////////////////////////////////////////////////////////
|
||||
@@ -24,16 +24,17 @@
|
||||
|
||||
#include "RimSummaryPlot.h"
|
||||
|
||||
#include "cafPdmUiComboBoxEditor.h"
|
||||
#include "cafPdmUiDateEditor.h"
|
||||
#include "cafPdmUiLineEditor.h"
|
||||
|
||||
#include "qwt_date.h"
|
||||
#include "cafPdmUiTimeEditor.h"
|
||||
#include "cvfAssert.h"
|
||||
|
||||
#include "qwt_date.h"
|
||||
|
||||
namespace caf
|
||||
{
|
||||
template<>
|
||||
void caf::AppEnum< RimSummaryTimeAxisProperties::TimeModeType >::setUp()
|
||||
void caf::AppEnum<RimSummaryTimeAxisProperties::TimeModeType>::setUp()
|
||||
{
|
||||
addItem(RimSummaryTimeAxisProperties::DATE, "DATE", "Date");
|
||||
addItem(RimSummaryTimeAxisProperties::TIME_FROM_SIMULATION_START, "TIME_FROM_SIMULATION_START", "Time From Simulation Start");
|
||||
@@ -42,26 +43,23 @@ void caf::AppEnum< RimSummaryTimeAxisProperties::TimeModeType >::setUp()
|
||||
}
|
||||
|
||||
template<>
|
||||
void caf::AppEnum< RimSummaryTimeAxisProperties::TimeUnitType >::setUp()
|
||||
void caf::AppEnum<RimSummaryTimeAxisProperties::TimeUnitType>::setUp()
|
||||
{
|
||||
addItem(RimSummaryTimeAxisProperties::SECONDS, "SECONDS", "Seconds");
|
||||
addItem(RimSummaryTimeAxisProperties::MINUTES, "MINUTES", "Minutes");
|
||||
addItem(RimSummaryTimeAxisProperties::HOURS, "HOURS", "Hours");
|
||||
addItem(RimSummaryTimeAxisProperties::DAYS, "DAYS ", "Days");
|
||||
addItem(RimSummaryTimeAxisProperties::DAYS, "DAYS ", "Days");
|
||||
addItem(RimSummaryTimeAxisProperties::YEARS, "YEARS", "Years");
|
||||
|
||||
setDefault(RimSummaryTimeAxisProperties::YEARS);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
} // namespace caf
|
||||
|
||||
CAF_PDM_SOURCE_INIT(RimSummaryTimeAxisProperties, "SummaryTimeAxisProperties");
|
||||
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
RimSummaryTimeAxisProperties::RimSummaryTimeAxisProperties()
|
||||
{
|
||||
@@ -77,17 +75,24 @@ RimSummaryTimeAxisProperties::RimSummaryTimeAxisProperties()
|
||||
CAF_PDM_InitFieldNoDefault(&m_timeMode, "TimeMode", "Time Mode", "", "", "");
|
||||
CAF_PDM_InitFieldNoDefault(&m_timeUnit, "TimeUnit", "Time Unit", "", "", "");
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateRangeMax, "VisibleRangeMax", "Max", "", "", "");
|
||||
m_visibleDateRangeMax.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateRangeMax, "VisibleDateRangeMax", "Max Date", "", "", "");
|
||||
m_visibleDateRangeMax.uiCapability()->setUiEditorTypeName(caf::PdmUiDateEditor::uiEditorTypeName());
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateRangeMin, "VisibleDateRangeMin", "Min Date", "", "", "");
|
||||
m_visibleDateRangeMin.uiCapability()->setUiEditorTypeName(caf::PdmUiDateEditor::uiEditorTypeName());
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateRangeMin, "VisibleRangeMin", "Min", "", "", "");
|
||||
m_visibleDateRangeMin.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeRangeMax, "VisibleTimeRangeMax", "MaxTime", "", "", "");
|
||||
m_visibleTimeRangeMax.uiCapability()->setUiEditorTypeName(caf::PdmUiTimeEditor::uiEditorTypeName());
|
||||
m_visibleTimeRangeMax.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::HIDDEN);
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeRangeMax, "VisibleTimeModeRangeMax", "Max", "", "", "");
|
||||
m_visibleDateRangeMax.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeRangeMin, "VisibleTimeRangeMin", "Min Time", "", "", "");
|
||||
m_visibleTimeRangeMin.uiCapability()->setUiEditorTypeName(caf::PdmUiTimeEditor::uiEditorTypeName());
|
||||
m_visibleTimeRangeMin.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::HIDDEN);
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeRangeMin, "VisibleTimeModeRangeMin", "Min", "", "", "");
|
||||
m_visibleDateRangeMin.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeSinceStartRangeMax, "VisibleTimeModeRangeMax", "Max", "", "", "");
|
||||
m_visibleTimeSinceStartRangeMax.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleTimeSinceStartRangeMin, "VisibleTimeModeRangeMin", "Min", "", "", "");
|
||||
m_visibleTimeSinceStartRangeMin.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_titlePositionEnum, "TitlePosition", "Title Position", "", "", "");
|
||||
CAF_PDM_InitField(&m_titleFontSize, "FontSize", 10, "Font Size", "", "", "");
|
||||
@@ -95,6 +100,19 @@ RimSummaryTimeAxisProperties::RimSummaryTimeAxisProperties()
|
||||
CAF_PDM_InitField(&m_valuesFontSize, "ValuesFontSize", 10, "Font Size", "", "", "");
|
||||
m_valuesFontSize = RiaFontCache::pointSizeFromFontSizeEnum(RiaApplication::instance()->preferences()->defaultPlotFontSize());
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_dateFormat, "DateFormat", "Date Format", "", "", "");
|
||||
m_dateFormat.uiCapability()->setUiEditorTypeName(caf::PdmUiComboBoxEditor::uiEditorTypeName());
|
||||
m_dateFormat = RiaApplication::instance()->preferences()->dateFormat();
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_timeFormat, "TimeFormat", "Time Format", "", "", "");
|
||||
m_timeFormat.uiCapability()->setUiEditorTypeName(caf::PdmUiComboBoxEditor::uiEditorTypeName());
|
||||
m_timeFormat = RiaApplication::instance()->preferences()->timeFormat();
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateTimeRangeMax_OBSOLETE, "VisibleRangeMax", "Max", "", "", "");
|
||||
m_visibleDateTimeRangeMax_OBSOLETE.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
|
||||
CAF_PDM_InitFieldNoDefault(&m_visibleDateTimeRangeMin_OBSOLETE, "VisibleRangeMin", "Min", "", "", "");
|
||||
m_visibleDateTimeRangeMin_OBSOLETE.uiCapability()->setUiEditorTypeName(caf::PdmUiLineEditor::uiEditorTypeName());
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@@ -138,66 +156,71 @@ void RimSummaryTimeAxisProperties::setValuesFontSize(int fontSize)
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
double RimSummaryTimeAxisProperties::visibleRangeMin() const
|
||||
{
|
||||
if ( m_timeMode() == DATE )
|
||||
return QwtDate::toDouble(m_visibleDateRangeMin());
|
||||
if (m_timeMode() == DATE)
|
||||
{
|
||||
return QwtDate::toDouble(visibleDateTimeMin());
|
||||
}
|
||||
else
|
||||
return m_visibleTimeRangeMin();
|
||||
return m_visibleTimeSinceStartRangeMin();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
double RimSummaryTimeAxisProperties::visibleRangeMax() const
|
||||
{
|
||||
if ( m_timeMode() == DATE )
|
||||
return QwtDate::toDouble(m_visibleDateRangeMax());
|
||||
if (m_timeMode() == DATE)
|
||||
{
|
||||
return QwtDate::toDouble(visibleDateTimeMax());
|
||||
}
|
||||
else
|
||||
return m_visibleTimeRangeMax();
|
||||
return m_visibleTimeSinceStartRangeMax();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::setVisibleRangeMin(double value)
|
||||
{
|
||||
if ( m_timeMode() == DATE )
|
||||
if (m_timeMode() == DATE)
|
||||
{
|
||||
m_visibleDateRangeMin = QwtDate::toDateTime(value);
|
||||
m_visibleTimeRangeMin = fromDateToDisplayTime(m_visibleDateRangeMin());
|
||||
QDateTime dateTime = QwtDate::toDateTime(value);
|
||||
m_visibleTimeSinceStartRangeMin = fromDateToDisplayTime(dateTime);
|
||||
setVisibleDateTimeMin(dateTime);
|
||||
}
|
||||
else
|
||||
{
|
||||
m_visibleTimeRangeMin = value;
|
||||
m_visibleDateRangeMin = fromDisplayTimeToDate(value);
|
||||
m_visibleTimeSinceStartRangeMin = value;
|
||||
QDateTime dateTime = fromDisplayTimeToDate(value);
|
||||
setVisibleDateTimeMin(dateTime);
|
||||
}
|
||||
auto s = m_visibleDateRangeMin().toString();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::setVisibleRangeMax(double value)
|
||||
{
|
||||
if ( m_timeMode() == DATE )
|
||||
if (m_timeMode() == DATE)
|
||||
{
|
||||
m_visibleDateRangeMax = QwtDate::toDateTime(value);
|
||||
m_visibleTimeRangeMax = fromDateToDisplayTime(m_visibleDateRangeMax());
|
||||
|
||||
QDateTime dateTime = QwtDate::toDateTime(value);
|
||||
m_visibleTimeSinceStartRangeMax = fromDateToDisplayTime(dateTime);
|
||||
setVisibleDateTimeMax(dateTime);
|
||||
}
|
||||
else
|
||||
{
|
||||
m_visibleTimeRangeMax = value;
|
||||
m_visibleDateRangeMax = fromDisplayTimeToDate(value);
|
||||
m_visibleTimeSinceStartRangeMax = value;
|
||||
QDateTime dateTime = fromDisplayTimeToDate(value);
|
||||
setVisibleDateTimeMax(dateTime);
|
||||
}
|
||||
auto s = m_visibleDateRangeMax().toString();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
bool RimSummaryTimeAxisProperties::isAutoZoom() const
|
||||
{
|
||||
@@ -205,7 +228,7 @@ bool RimSummaryTimeAxisProperties::isAutoZoom() const
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::setAutoZoom(bool enableAutoZoom)
|
||||
{
|
||||
@@ -213,25 +236,25 @@ void RimSummaryTimeAxisProperties::setAutoZoom(bool enableAutoZoom)
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::updateTimeVisibleRange()
|
||||
{
|
||||
m_visibleTimeRangeMax = fromDateToDisplayTime(m_visibleDateRangeMax());
|
||||
m_visibleTimeRangeMin = fromDateToDisplayTime(m_visibleDateRangeMin());
|
||||
m_visibleTimeSinceStartRangeMax = fromDateToDisplayTime(visibleDateTimeMax());
|
||||
m_visibleTimeSinceStartRangeMin = fromDateToDisplayTime(visibleDateTimeMin());
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::updateDateVisibleRange()
|
||||
{
|
||||
m_visibleDateRangeMin = fromDisplayTimeToDate(m_visibleTimeRangeMin());
|
||||
m_visibleDateRangeMax = fromDisplayTimeToDate(m_visibleTimeRangeMax());
|
||||
setVisibleDateTimeMin(fromDisplayTimeToDate(m_visibleTimeSinceStartRangeMin()));
|
||||
setVisibleDateTimeMax(fromDisplayTimeToDate(m_visibleTimeSinceStartRangeMax()));
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
QDateTime RimSummaryTimeAxisProperties::fromDisplayTimeToDate(double displayTime)
|
||||
{
|
||||
@@ -239,7 +262,7 @@ QDateTime RimSummaryTimeAxisProperties::fromDisplayTimeToDate(double displayTime
|
||||
this->firstAncestorOrThisOfType(rimSummaryPlot);
|
||||
time_t startOfSimulation = rimSummaryPlot->firstTimeStepOfFirstCurve();
|
||||
|
||||
time_t secsSinceSimulationStart = displayTime/fromTimeTToDisplayUnitScale();
|
||||
time_t secsSinceSimulationStart = displayTime / fromTimeTToDisplayUnitScale();
|
||||
QDateTime date;
|
||||
date.setTime_t(startOfSimulation + secsSinceSimulationStart);
|
||||
|
||||
@@ -247,7 +270,7 @@ QDateTime RimSummaryTimeAxisProperties::fromDisplayTimeToDate(double displayTime
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
double RimSummaryTimeAxisProperties::fromDateToDisplayTime(const QDateTime& displayTime)
|
||||
{
|
||||
@@ -257,12 +280,11 @@ double RimSummaryTimeAxisProperties::fromDateToDisplayTime(const QDateTime& disp
|
||||
this->firstAncestorOrThisOfType(rimSummaryPlot);
|
||||
time_t startOfSimulation = rimSummaryPlot->firstTimeStepOfFirstCurve();
|
||||
|
||||
return fromTimeTToDisplayUnitScale()*(secsSinceEpoc - startOfSimulation);
|
||||
return fromTimeTToDisplayUnitScale() * (secsSinceEpoc - startOfSimulation);
|
||||
}
|
||||
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
bool RimSummaryTimeAxisProperties::isActive() const
|
||||
{
|
||||
@@ -270,15 +292,51 @@ bool RimSummaryTimeAxisProperties::isActive() const
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
QList<caf::PdmOptionItemInfo> RimSummaryTimeAxisProperties::calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool * useOptionsOnly)
|
||||
QDateTime RimSummaryTimeAxisProperties::visibleDateTimeMin() const
|
||||
{
|
||||
QDateTime fullMin(m_visibleDateRangeMin(), m_visibleTimeRangeMin());
|
||||
return fullMin;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
QDateTime RimSummaryTimeAxisProperties::visibleDateTimeMax() const
|
||||
{
|
||||
QDateTime fullMax(m_visibleDateRangeMax(), m_visibleTimeRangeMax());
|
||||
return fullMax;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::setVisibleDateTimeMin(const QDateTime& dateTime)
|
||||
{
|
||||
m_visibleDateRangeMin = dateTime.date();
|
||||
m_visibleTimeRangeMin = dateTime.time();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::setVisibleDateTimeMax(const QDateTime& dateTime)
|
||||
{
|
||||
m_visibleDateRangeMax = dateTime.date();
|
||||
m_visibleTimeRangeMax = dateTime.time();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
QList<caf::PdmOptionItemInfo> RimSummaryTimeAxisProperties::calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions,
|
||||
bool* useOptionsOnly)
|
||||
{
|
||||
QList<caf::PdmOptionItemInfo> options;
|
||||
*useOptionsOnly = true;
|
||||
|
||||
if (&m_titleFontSize == fieldNeedingOptions ||
|
||||
&m_valuesFontSize == fieldNeedingOptions)
|
||||
if (&m_titleFontSize == fieldNeedingOptions || &m_valuesFontSize == fieldNeedingOptions)
|
||||
{
|
||||
std::vector<int> fontSizes;
|
||||
fontSizes.push_back(8);
|
||||
@@ -297,12 +355,35 @@ QList<caf::PdmOptionItemInfo> RimSummaryTimeAxisProperties::calculateValueOption
|
||||
options.push_back(caf::PdmOptionItemInfo(text, value));
|
||||
}
|
||||
}
|
||||
|
||||
else if (fieldNeedingOptions == &m_dateFormat)
|
||||
{
|
||||
for (auto dateFormat : RiaQDateTimeTools::supportedDateFormats())
|
||||
{
|
||||
QDate exampleDate = QDate(2019, 8, 16);
|
||||
QString fullDateFormat =
|
||||
RiaQDateTimeTools::dateFormatString(dateFormat, RiaQDateTimeTools::DATE_FORMAT_YEAR_MONTH_DAY);
|
||||
QString uiText = QString("%1 (%2)").arg(fullDateFormat).arg(exampleDate.toString(fullDateFormat));
|
||||
uiText.replace("AP", "AM/PM");
|
||||
options.push_back(caf::PdmOptionItemInfo(uiText, QVariant::fromValue(dateFormat)));
|
||||
}
|
||||
}
|
||||
else if (fieldNeedingOptions == &m_timeFormat)
|
||||
{
|
||||
for (auto timeFormat : RiaQDateTimeTools::supportedTimeFormats())
|
||||
{
|
||||
QTime exampleTime = QTime(15, 48, 22);
|
||||
QString timeFormatString =
|
||||
RiaQDateTimeTools::timeFormatString(timeFormat, RiaQDateTimeTools::TIME_FORMAT_HOUR_MINUTE_SECOND);
|
||||
QString uiText = QString("%1 (%2)").arg(timeFormatString).arg(exampleTime.toString(timeFormatString));
|
||||
uiText.replace("AP", "AM/PM");
|
||||
options.push_back(caf::PdmOptionItemInfo(uiText, QVariant::fromValue(timeFormat)));
|
||||
}
|
||||
}
|
||||
return options;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
caf::PdmFieldHandle* RimSummaryTimeAxisProperties::objectToggleField()
|
||||
{
|
||||
@@ -326,7 +407,7 @@ void RimSummaryTimeAxisProperties::setTimeMode(TimeModeType val)
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
double RimSummaryTimeAxisProperties::fromTimeTToDisplayUnitScale()
|
||||
{
|
||||
@@ -334,59 +415,75 @@ double RimSummaryTimeAxisProperties::fromTimeTToDisplayUnitScale()
|
||||
switch (m_timeUnit())
|
||||
{
|
||||
case SECONDS:
|
||||
break;
|
||||
break;
|
||||
case MINUTES:
|
||||
scale = 1.0/60.0;
|
||||
break;
|
||||
scale = 1.0 / 60.0;
|
||||
break;
|
||||
case HOURS:
|
||||
scale = 1.0/(60.0*60.0);
|
||||
break;
|
||||
scale = 1.0 / (60.0 * 60.0);
|
||||
break;
|
||||
case DAYS:
|
||||
scale = 1.0/(60.0*60.0*24.0);
|
||||
break;
|
||||
scale = 1.0 / (60.0 * 60.0 * 24.0);
|
||||
break;
|
||||
case YEARS:
|
||||
scale = 1.0/31556952.0;
|
||||
break;
|
||||
scale = 1.0 / 31556952.0;
|
||||
break;
|
||||
default:
|
||||
CVF_ASSERT(false);
|
||||
break;
|
||||
CVF_ASSERT(false);
|
||||
break;
|
||||
}
|
||||
|
||||
return scale;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
double RimSummaryTimeAxisProperties::fromDaysToDisplayUnitScale()
|
||||
{
|
||||
double scale = 1.0;
|
||||
switch (m_timeUnit())
|
||||
{
|
||||
case SECONDS:
|
||||
scale = 60.0 * 60.0 * 24.0;
|
||||
break;
|
||||
case MINUTES:
|
||||
scale = 60.0 * 24.0;
|
||||
break;
|
||||
case HOURS:
|
||||
scale = 24.0;
|
||||
break;
|
||||
case DAYS:
|
||||
break;
|
||||
case YEARS:
|
||||
scale = 1.0/365.2425;
|
||||
break;
|
||||
default:
|
||||
CVF_ASSERT(false);
|
||||
break;
|
||||
case SECONDS:
|
||||
scale = 60.0 * 60.0 * 24.0;
|
||||
break;
|
||||
case MINUTES:
|
||||
scale = 60.0 * 24.0;
|
||||
break;
|
||||
case HOURS:
|
||||
scale = 24.0;
|
||||
break;
|
||||
case DAYS:
|
||||
break;
|
||||
case YEARS:
|
||||
scale = 1.0 / 365.2425;
|
||||
break;
|
||||
default:
|
||||
CVF_ASSERT(false);
|
||||
break;
|
||||
}
|
||||
|
||||
return scale;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
const QString& RimSummaryTimeAxisProperties::dateFormat() const
|
||||
{
|
||||
return m_dateFormat();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
const QString& RimSummaryTimeAxisProperties::timeFormat() const
|
||||
{
|
||||
return m_timeFormat();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
||||
{
|
||||
@@ -396,18 +493,22 @@ void RimSummaryTimeAxisProperties::defineUiOrdering(QString uiConfigName, caf::P
|
||||
titleGroup.add(&m_titlePositionEnum);
|
||||
titleGroup.add(&m_titleFontSize);
|
||||
|
||||
caf::PdmUiGroup* timeGroup = uiOrdering.addNewGroup("Time Values");
|
||||
caf::PdmUiGroup* timeGroup = uiOrdering.addNewGroup("Time Values");
|
||||
timeGroup->add(&m_timeMode);
|
||||
if (m_timeMode() == DATE)
|
||||
{
|
||||
timeGroup->add( &m_visibleDateRangeMax);
|
||||
timeGroup->add(&m_visibleDateRangeMin);
|
||||
timeGroup->add(&m_visibleDateRangeMax, true);
|
||||
timeGroup->add(&m_visibleTimeRangeMax, false);
|
||||
timeGroup->add(&m_visibleDateRangeMin, true);
|
||||
timeGroup->add(&m_visibleTimeRangeMin, false);
|
||||
timeGroup->add(&m_dateFormat);
|
||||
timeGroup->add(&m_timeFormat);
|
||||
}
|
||||
else
|
||||
{
|
||||
timeGroup->add(&m_timeUnit);
|
||||
timeGroup->add(&m_visibleTimeRangeMax);
|
||||
timeGroup->add(&m_visibleTimeRangeMin);
|
||||
timeGroup->add(&m_timeUnit);
|
||||
timeGroup->add(&m_visibleTimeSinceStartRangeMax);
|
||||
timeGroup->add(&m_visibleTimeSinceStartRangeMin);
|
||||
}
|
||||
timeGroup->add(&m_valuesFontSize);
|
||||
|
||||
@@ -415,9 +516,11 @@ void RimSummaryTimeAxisProperties::defineUiOrdering(QString uiConfigName, caf::P
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue)
|
||||
void RimSummaryTimeAxisProperties::fieldChangedByUi(const caf::PdmFieldHandle* changedField,
|
||||
const QVariant& oldValue,
|
||||
const QVariant& newValue)
|
||||
{
|
||||
RimSummaryPlot* rimSummaryPlot = nullptr;
|
||||
this->firstAncestorOrThisOfType(rimSummaryPlot);
|
||||
@@ -425,10 +528,21 @@ void RimSummaryTimeAxisProperties::fieldChangedByUi(const caf::PdmFieldHandle* c
|
||||
|
||||
if (changedField == &m_visibleDateRangeMax)
|
||||
{
|
||||
QDateTime test = newValue.toDateTime();
|
||||
QDate test = newValue.toDate();
|
||||
if (!test.isValid())
|
||||
{
|
||||
m_visibleDateRangeMax = oldValue.toDateTime();
|
||||
m_visibleDateRangeMax = oldValue.toDate();
|
||||
}
|
||||
|
||||
updateTimeVisibleRange();
|
||||
m_isAutoZoom = false;
|
||||
}
|
||||
else if (changedField == &m_visibleTimeRangeMax)
|
||||
{
|
||||
QTime test = newValue.toTime();
|
||||
if (!test.isValid())
|
||||
{
|
||||
m_visibleTimeRangeMax = oldValue.toTime();
|
||||
}
|
||||
|
||||
updateTimeVisibleRange();
|
||||
@@ -436,16 +550,27 @@ void RimSummaryTimeAxisProperties::fieldChangedByUi(const caf::PdmFieldHandle* c
|
||||
}
|
||||
else if (changedField == &m_visibleDateRangeMin)
|
||||
{
|
||||
QDateTime test = newValue.toDateTime();
|
||||
QDate test = newValue.toDate();
|
||||
if (!test.isValid())
|
||||
{
|
||||
m_visibleDateRangeMin = oldValue.toDateTime();
|
||||
m_visibleDateRangeMin = oldValue.toDate();
|
||||
}
|
||||
|
||||
updateTimeVisibleRange();
|
||||
m_isAutoZoom = false;
|
||||
}
|
||||
else if (changedField == &m_visibleTimeRangeMin || changedField == &m_visibleTimeRangeMax)
|
||||
else if (changedField == &m_visibleTimeRangeMin)
|
||||
{
|
||||
QTime test = newValue.toTime();
|
||||
if (!test.isValid())
|
||||
{
|
||||
m_visibleTimeRangeMin = oldValue.toTime();
|
||||
}
|
||||
|
||||
updateTimeVisibleRange();
|
||||
m_isAutoZoom = false;
|
||||
}
|
||||
else if (changedField == &m_visibleTimeSinceStartRangeMin || changedField == &m_visibleTimeSinceStartRangeMax)
|
||||
{
|
||||
updateDateVisibleRange();
|
||||
m_isAutoZoom = false;
|
||||
@@ -460,7 +585,58 @@ void RimSummaryTimeAxisProperties::fieldChangedByUi(const caf::PdmFieldHandle* c
|
||||
rimSummaryPlot->loadDataAndUpdate();
|
||||
updateDateVisibleRange();
|
||||
}
|
||||
else if (changedField == &m_dateFormat || changedField == &m_timeFormat)
|
||||
{
|
||||
updateTimeVisibleRange(); // Use the stored max min dates to update the visible time range to new unit
|
||||
rimSummaryPlot->loadDataAndUpdate();
|
||||
updateDateVisibleRange();
|
||||
}
|
||||
|
||||
rimSummaryPlot->updateAxes();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::initAfterRead()
|
||||
{
|
||||
QDateTime maxDateTime = m_visibleDateTimeRangeMax_OBSOLETE();
|
||||
QDateTime minDateTime = m_visibleDateTimeRangeMin_OBSOLETE();
|
||||
if (maxDateTime.isValid())
|
||||
{
|
||||
m_visibleDateRangeMax = maxDateTime.date();
|
||||
m_visibleTimeRangeMax = maxDateTime.time();
|
||||
}
|
||||
if (minDateTime.isValid())
|
||||
{
|
||||
m_visibleDateRangeMin = minDateTime.date();
|
||||
m_visibleTimeRangeMin = minDateTime.time();
|
||||
}
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RimSummaryTimeAxisProperties::defineEditorAttribute(const caf::PdmFieldHandle* field,
|
||||
QString uiConfigName,
|
||||
caf::PdmUiEditorAttribute* attribute)
|
||||
{
|
||||
if (field == &m_visibleDateRangeMin || field == &m_visibleDateRangeMax)
|
||||
{
|
||||
auto dateAttrib = dynamic_cast<caf::PdmUiDateEditorAttribute*>(attribute);
|
||||
if (dateAttrib)
|
||||
{
|
||||
dateAttrib->dateFormat =
|
||||
RiaQDateTimeTools::dateFormatString(m_dateFormat(), RiaQDateTimeTools::DATE_FORMAT_YEAR_MONTH_DAY);
|
||||
}
|
||||
}
|
||||
else if (field == &m_visibleTimeRangeMin || field == &m_visibleTimeRangeMax)
|
||||
{
|
||||
auto timeAttrib = dynamic_cast<caf::PdmUiTimeEditorAttribute*>(attribute);
|
||||
if (timeAttrib)
|
||||
{
|
||||
timeAttrib->timeFormat =
|
||||
RiaQDateTimeTools::timeFormatString(m_timeFormat(), RiaQDateTimeTools::TIME_FORMAT_HOUR_MINUTE_SECOND);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -19,6 +19,7 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "RiaQDateTimeTools.h"
|
||||
#include "RimPlotAxisPropertiesInterface.h"
|
||||
|
||||
#include "cafPdmObject.h"
|
||||
@@ -70,6 +71,9 @@ public:
|
||||
double fromTimeTToDisplayUnitScale();
|
||||
double fromDaysToDisplayUnitScale();
|
||||
|
||||
const QString& dateFormat() const;
|
||||
const QString& timeFormat() const;
|
||||
|
||||
double visibleRangeMin() const;
|
||||
double visibleRangeMax() const;
|
||||
|
||||
@@ -81,30 +85,49 @@ public:
|
||||
|
||||
bool isActive() const;
|
||||
|
||||
QDateTime visibleDateTimeMin() const;
|
||||
QDateTime visibleDateTimeMax() const;
|
||||
|
||||
void setVisibleDateTimeMin(const QDateTime& dateTime);
|
||||
void setVisibleDateTimeMax(const QDateTime& dateTime);
|
||||
|
||||
protected:
|
||||
void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue) override;
|
||||
QList<caf::PdmOptionItemInfo> calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool * useOptionsOnly) override;
|
||||
caf::PdmFieldHandle* objectToggleField() override;
|
||||
void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override;
|
||||
void initAfterRead() override;
|
||||
void defineEditorAttribute(const caf::PdmFieldHandle* field,
|
||||
QString uiConfigName,
|
||||
caf::PdmUiEditorAttribute* attribute) override;
|
||||
|
||||
double fromDateToDisplayTime(const QDateTime& displayTime);
|
||||
QDateTime fromDisplayTimeToDate(double displayTime);
|
||||
void updateTimeVisibleRange();
|
||||
void updateDateVisibleRange();
|
||||
|
||||
|
||||
|
||||
private:
|
||||
caf::PdmField< caf::AppEnum< TimeModeType > > m_timeMode;
|
||||
caf::PdmField< caf::AppEnum< TimeUnitType > > m_timeUnit;
|
||||
|
||||
caf::PdmField<bool> m_isActive;
|
||||
caf::PdmField<QDateTime> m_visibleDateRangeMin;
|
||||
caf::PdmField<QDateTime> m_visibleDateRangeMax;
|
||||
caf::PdmField<double> m_visibleTimeRangeMin;
|
||||
caf::PdmField<double> m_visibleTimeRangeMax;
|
||||
caf::PdmField<QDate> m_visibleDateRangeMin;
|
||||
caf::PdmField<QDate> m_visibleDateRangeMax;
|
||||
caf::PdmField<QTime> m_visibleTimeRangeMin;
|
||||
caf::PdmField<QTime> m_visibleTimeRangeMax;
|
||||
|
||||
caf::PdmField<double> m_visibleTimeSinceStartRangeMin;
|
||||
caf::PdmField<double> m_visibleTimeSinceStartRangeMax;
|
||||
caf::PdmField<bool> m_isAutoZoom;
|
||||
|
||||
caf::PdmField<int> m_titleFontSize;
|
||||
caf::PdmField<caf::AppEnum<AxisTitlePositionType>> m_titlePositionEnum;
|
||||
caf::PdmField<int> m_valuesFontSize;
|
||||
caf::PdmField<QString> m_dateFormat;
|
||||
caf::PdmField<QString> m_timeFormat;
|
||||
|
||||
caf::PdmField<QDateTime> m_visibleDateTimeRangeMin_OBSOLETE;
|
||||
caf::PdmField<QDateTime> m_visibleDateTimeRangeMax_OBSOLETE;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user