diff --git a/gui/include/gui/widgets/incrementstrategy.h b/gui/include/gui/widgets/incrementstrategy.h new file mode 100644 index 0000000000..e96c8c4fe2 --- /dev/null +++ b/gui/include/gui/widgets/incrementstrategy.h @@ -0,0 +1,144 @@ +/* + * Copyright (c) 2024 Analog Devices Inc. + * + * This file is part of Scopy + * (see https://www.github.com/analogdevicesinc/scopy). + * + * 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 . + * + */ + +#ifndef INCREMENTSTRATEGY_H +#define INCREMENTSTRATEGY_H + +#include +#include + +namespace scopy { +namespace gui { + +class SCOPY_GUI_EXPORT IncrementStrategy +{ +public: + virtual ~IncrementStrategy() {} + virtual double increment(double val) = 0; + virtual double decrement(double val) = 0; + virtual void setScale(double scale) = 0; +}; + +class SCOPY_GUI_EXPORT IncrementStrategy125 : public IncrementStrategy +{ +public: + NumberSeries m_steps; + + IncrementStrategy125() + : m_steps(1e-9, 1e9, 10) + {} + ~IncrementStrategy125() {} + virtual double increment(double val) override { return m_steps.getNumberAfter(val); } + virtual double decrement(double val) override { return m_steps.getNumberBefore(val); } + + double m_scale; + void setScale(double scale) override { m_scale = scale; } +}; + +class SCOPY_GUI_EXPORT IncrementStrategyPower2 : public IncrementStrategy +{ +public: + QList m_steps; + IncrementStrategyPower2() + { + for(int i = 30; i >= 0; i--) { + m_steps.append(-(1 << i)); + } + for(int i = 0; i < 31; i++) { + m_steps.append(1 << i); + } + } + ~IncrementStrategyPower2() {} + virtual double increment(double val) override + { + int i = 0; + val = val + 1; + while(val > m_steps[i]) { + i++; + } + return m_steps[i]; + } + virtual double decrement(double val) override + { + int i = m_steps.count() - 1; + val = val - 1; + while(val < m_steps[i]) { + i--; + } + return m_steps[i]; + } + double m_scale; + + void setScale(double scale) override { m_scale = scale; } +}; +class SCOPY_GUI_EXPORT IncrementStrategyFixed : public IncrementStrategy +{ +public: + IncrementStrategyFixed(double k = 1) + { + m_k = k; + m_scale = 1; + } + ~IncrementStrategyFixed() {} + virtual double increment(double val) override + { + val = val + m_k * m_scale; + return val; + } + virtual double decrement(double val) override + { + val = val - m_k * m_scale; + return val; + } + void setK(double val) { m_k = val; } + double k() { return m_k; } + +private: + double m_k; + double m_scale; + + void setScale(double scale) override { m_scale = scale; } +}; + +class SCOPY_GUI_EXPORT IncrementStrategyTest : public IncrementStrategy +{ +public: + IncrementStrategyTest() { m_scale = 1; } + ~IncrementStrategyTest() {} + virtual double increment(double val) override + { + val = val + m_scale; + return val; + } + virtual double decrement(double val) override + { + val = val - m_scale; + return val; + } + +private: + double m_scale; + + void setScale(double scale) override { m_scale = scale; } +}; +} // namespace gui +} // namespace scopy +#endif // INCREMENTSTRATEGY_H diff --git a/gui/include/gui/widgets/menuspinbox.h b/gui/include/gui/widgets/menuspinbox.h index 77f3930c41..6b329e6b92 100644 --- a/gui/include/gui/widgets/menuspinbox.h +++ b/gui/include/gui/widgets/menuspinbox.h @@ -28,112 +28,16 @@ #include #include #include -#include #include #include #include #include +#include +#include namespace scopy { namespace gui { -class SCOPY_GUI_EXPORT IncrementStrategy -{ -public: - virtual ~IncrementStrategy(){}; - virtual double increment(double val) = 0; - virtual double decrement(double val) = 0; - virtual void setScale(double scale) = 0; -}; - -class SCOPY_GUI_EXPORT IncrementStrategy125 : public IncrementStrategy -{ -public: - NumberSeries m_steps; - - IncrementStrategy125() - : m_steps(1e-9, 1e9, 10){}; - ~IncrementStrategy125(){}; - virtual double increment(double val) override { return m_steps.getNumberAfter(val); } - virtual double decrement(double val) override { return m_steps.getNumberBefore(val); } - - double m_scale; - void setScale(double scale) override { m_scale = scale; } -}; - -class SCOPY_GUI_EXPORT IncrementStrategyPower2 : public IncrementStrategy -{ -public: - QList m_steps; - IncrementStrategyPower2() - { - for(int i = 30; i >= 0; i--) { - m_steps.append(-(1 << i)); - } - for(int i = 0; i < 31; i++) { - m_steps.append(1 << i); - } - }; - ~IncrementStrategyPower2(){}; - virtual double increment(double val) override - { - int i = 0; - val = val + 1; - while(val > m_steps[i]) { - i++; - } - return m_steps[i]; - } - virtual double decrement(double val) override - { - int i = m_steps.count() - 1; - val = val - 1; - while(val < m_steps[i]) { - i--; - } - return m_steps[i]; - } - double m_scale; - - void setScale(double scale) override { m_scale = scale; } -}; -class SCOPY_GUI_EXPORT IncrementStrategyFixed : public IncrementStrategy -{ -public: - IncrementStrategyFixed(double k = 1) - { - m_k = k; - m_scale = 1; - }; - ~IncrementStrategyFixed(){}; - virtual double increment(double val) override - { - val = val + m_k * m_scale; - return val; - } - virtual double decrement(double val) override - { - val = val - m_k * m_scale; - return val; - } - void setK(double val) { m_k = val; } - double k() { return m_k; } - -private: - double m_k; - double m_scale; - - void setScale(double scale) override { m_scale = scale; } -}; - -class SCOPY_GUI_EXPORT UnitPrefix -{ -public: - QString prefix; - double scale; - // enum type - metric, hour, logarithmic, etc -}; - class SCOPY_GUI_EXPORT MenuSpinbox : public QWidget { Q_OBJECT @@ -157,7 +61,11 @@ class SCOPY_GUI_EXPORT MenuSpinbox : public QWidget IncrementStrategy *incrementStrategy() const; QString name() const; - void setScaleRange(double min, double max); + Scale *scale() const; + void setScale(Scale *newScale); + + int precision() const; + void setPrecision(int newPrecision); public Q_SLOTS: void setName(const QString &newName); @@ -169,6 +77,7 @@ public Q_SLOTS: void setValue(double newValue); void setIncrementMode(IncrementMode is); void setScalingEnabled(bool en); + bool scallingEnabled(); Q_SIGNALS: void nameChanged(QString); @@ -184,10 +93,10 @@ private Q_SLOTS: void layoutVertically(bool left); void layoutHorizontally(bool left); double clamp(double val, double min, double max); + void minMaxReached(double val); QLabel *m_label; QLineEdit *m_edit; - QComboBox *m_scaleCb; QPushButton *m_plus; QPushButton *m_minus; MouseWheelWidgetGuard *m_mouseWheelGuard; @@ -195,19 +104,14 @@ private Q_SLOTS: IncrementStrategy *m_incrementStrategy; IncrementMode m_im; + Scale *m_scale; + Q_PROPERTY(QString name READ name WRITE setName NOTIFY nameChanged) Q_PROPERTY(double value READ value WRITE setValue NOTIFY valueChanged) - Q_PROPERTY(QString unit READ unit WRITE setUnit NOTIFY unitChanged) QString m_name; double m_value, m_min, m_max; - double m_scaleMin, m_scaleMax; - QString m_unit; - - QList m_scales; - // QMap m_scaleMap; - double getScaleForPrefix(QString prefix, Qt::CaseSensitivity s = Qt::CaseSensitive); - bool m_scalingEnabled; + int m_precision = 3; }; } // namespace gui } // namespace scopy diff --git a/gui/include/gui/widgets/scale.h b/gui/include/gui/widgets/scale.h new file mode 100644 index 0000000000..ab814a3802 --- /dev/null +++ b/gui/include/gui/widgets/scale.h @@ -0,0 +1,100 @@ +/* + * Copyright (c) 2024 Analog Devices Inc. + * + * This file is part of Scopy + * (see https://www.github.com/analogdevicesinc/scopy). + * + * 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 . + * + */ + +#ifndef SCALE_H +#define SCALE_H + +#include +#include +#include +#include +#include + +namespace scopy { +namespace gui { + +class SCOPY_GUI_EXPORT UnitPrefix +{ +public: + QString prefix; + double scale; + // enum type - metric, hour, logarithmic, etc +}; + +class SCOPY_GUI_EXPORT ScaleOption +{ +public: + QString option; + double scale; + // enum type - metric, hour, logarithmic, etc +}; + +class SCOPY_GUI_EXPORT Scale : public QObject +{ + Q_OBJECT +public: + Scale(QString unit, double min, double max, bool hasPrefix = true); + ~Scale(); + + double getScaleForPrefix(QString prefix, Qt::CaseSensitivity s); + double getScaleForUnit(QString unit, Qt::CaseSensitivity s); + double getScaleForSymbol(QString symbol); + + QList scalePrefixes() const; + void setScalePrefixes(const QList &newScalePrefixes); + + QList scaleOptions() const; + void setScaleOptions(const QList &newScaleOptions); + + bool scalingEnabled() const; + void setScalingEnabled(bool newScalingEnabled); + + QComboBox *scaleCb() const; + + QString unit() const; + void setUnit(const QString &newUnit); + + void computeScale(double val); + + bool hasPrefix() const; + void setHasPrefix(bool newHasPrefix); + +Q_SIGNALS: + void scaleUpdated(); + void unitChanged(QString unit); + void scaleDown(int newScaleIndex); + +private: + bool m_hasPrefix; + bool m_scalingEnabled = true; + double m_min, m_max; + QString m_unit; + QList m_scaleOptions; + QList m_scalePrefixes; + QComboBox *m_scaleCb; + void populateScaleCb(); + + Q_PROPERTY(QString unit READ unit WRITE setUnit NOTIFY unitChanged) +}; + +} // namespace gui +} // namespace scopy +#endif // SCALE_H diff --git a/gui/src/style.cpp b/gui/src/style.cpp index 40e23cc7e4..b6c711cee8 100644 --- a/gui/src/style.cpp +++ b/gui/src/style.cpp @@ -359,3 +359,5 @@ QString Style::adjustForScaling(QString key, QString value) return value; } + +#include "moc_style.cpp" diff --git a/gui/src/widgets/menuplotaxisrangecontrol.cpp b/gui/src/widgets/menuplotaxisrangecontrol.cpp index 3fc59f435c..40599e3d72 100644 --- a/gui/src/widgets/menuplotaxisrangecontrol.cpp +++ b/gui/src/widgets/menuplotaxisrangecontrol.cpp @@ -32,13 +32,17 @@ MenuPlotAxisRangeControl::MenuPlotAxisRangeControl(PlotAxis *m_plotAxis, QWidget setLayout(minMaxLayout); minMaxLayout->setMargin(0); minMaxLayout->setSpacing(10); - QString unit = m_plotAxis->getUnits(); m_min = new MenuSpinbox("Min", 0, "counts", -1e9, 1e9, true, false, this); m_max = new MenuSpinbox("Max", 0, "counts", -1e9, 1e9, true, false, this); - m_min->setScaleRange(1, 1e9); - m_max->setScaleRange(1, 1e9); + m_min->setIncrementMode(MenuSpinbox::IS_POW2); + m_max->setIncrementMode(MenuSpinbox::IS_POW2); + + m_min->scale()->setScalePrefixes( + {{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}, {QString("G"), 1e9}}); + m_max->scale()->setScalePrefixes( + {{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}, {QString("G"), 1e9}}); addAxis(m_plotAxis); minMaxLayout->addWidget(m_min); diff --git a/gui/src/widgets/menuspinbox.cpp b/gui/src/widgets/menuspinbox.cpp index 317543eb07..f81c879159 100644 --- a/gui/src/widgets/menuspinbox.cpp +++ b/gui/src/widgets/menuspinbox.cpp @@ -28,16 +28,23 @@ namespace gui { MenuSpinbox::MenuSpinbox(QString name, double val, QString unit, double min, double max, bool vertical, bool left, QWidget *parent) - : QWidget(parent) + : m_name(name) + , m_min(min) + , m_max(max) + , QWidget(parent) { m_label = new QLabel(name, parent); m_edit = new QLineEdit("0", parent); - m_scaleCb = new QComboBox(parent); m_plus = new QPushButton("", parent); m_minus = new QPushButton("", parent); m_mouseWheelGuard = new MouseWheelWidgetGuard(this); + ////SCALE + m_scale = new Scale(unit, min, max); + + m_incrementStrategy = new IncrementStrategyFixed(); + m_plus->setAutoRepeat(true); m_plus->setAutoRepeatDelay(300); m_plus->setAutoRepeatInterval(20); @@ -52,35 +59,41 @@ MenuSpinbox::MenuSpinbox(QString name, double val, QString unit, double min, dou layoutHorizontally(left); } - m_incrementStrategy = new IncrementStrategyPower2(); + setValue(val); connect(m_plus, &QAbstractButton::clicked, this, [=]() { setValue(m_incrementStrategy->increment(m_value)); }); - connect(m_minus, &QAbstractButton::clicked, this, [=]() { setValue(m_incrementStrategy->decrement(m_value)); }); - - connect(m_edit, &QLineEdit::editingFinished, this, [=]() { userInput(m_edit->text()); }); + connect(m_minus, &QAbstractButton::clicked, this, [=]() { + double newValue = m_incrementStrategy->decrement(m_value); + if(m_scale->scalingEnabled()) { + // if value would be 0 check if lower scale available + int idx = m_scale->scaleCb()->currentIndex(); + if(newValue == 0 && (idx - 1) >= 0) { + // found lower scale update value based on that + setValue(m_value - (1 * m_scale->scaleCb()->itemData(idx - 1).toDouble())); + } else { + setValue(newValue); + } + } else { + setValue(newValue); + } + }); + connect(m_edit, &QLineEdit::editingFinished, this, [=]() { + m_edit->blockSignals(true); + userInput(m_edit->text()); + m_edit->blockSignals(false); + }); - connect(m_scaleCb, qOverload(&QComboBox::currentIndexChanged), this, [=](int idx) { - m_incrementStrategy->setScale(m_scaleCb->itemData(idx).toDouble()); + connect(m_scale->scaleCb(), qOverload(&QComboBox::currentIndexChanged), this, [=]() { userInput(m_edit->text()); + // if the value is 0 we still need to consider scale options + if(m_value == 0) { + m_incrementStrategy->setScale(m_scale->scaleCb()->currentData().toDouble()); + } }); - m_scales.append({QString("n"), 1e-9}); - m_scales.append({QString("u"), 1e-6}); - m_scales.append({QString("m"), 1e-3}); - m_scales.append({QString(""), 1e0}); - m_scales.append({QString("k"), 1e3}); - m_scales.append({QString("M"), 1e6}); - m_scales.append({QString("G"), 1e9}); - - m_name = name; - m_unit = unit; - m_min = min; - m_max = max; - m_scaleMin = min; - m_scaleMax = max; - setScaleRange(m_scaleMin, m_scaleMax); - setValue(val); - m_scalingEnabled = true; + connect(m_scale, &Scale::unitChanged, this, &MenuSpinbox::unitChanged); + connect(m_scale, &Scale::scaleUpdated, this, &MenuSpinbox::populateWidgets); + m_mouseWheelGuard->installEventRecursively(this); } @@ -111,7 +124,7 @@ void MenuSpinbox::layoutVertically(bool left) editLay->addWidget(m_label); editLay->addWidget(m_edit); - editLay->addWidget(m_scaleCb); + editLay->addWidget(m_scale->scaleCb()); if(left) { lay->addLayout(btnLay); @@ -122,7 +135,7 @@ void MenuSpinbox::layoutVertically(bool left) } Style::setStyle(m_label, style::properties::label::subtle); - Style::setStyle(m_scaleCb, style::properties::widget::noBorder); + Style::setStyle(m_scale->scaleCb(), style::properties::widget::noBorder); int size = Style::getDimension(json::global::unit_2_5); m_plus->setIcon(Style::getPixmap(":/gui/icons/plus.svg", Style::getColor(json::theme::content_inverse))); @@ -164,7 +177,7 @@ void MenuSpinbox::layoutHorizontally(bool left) editLay->addWidget(m_label); editLay->addWidget(m_edit); - editLay->addWidget(m_scaleCb); + editLay->addWidget(m_scale->scaleCb()); lineLay->addLayout(lay); if(left) { @@ -193,8 +206,20 @@ void MenuSpinbox::setValue(double newValue) { setValueForce(newValue, 0); } void MenuSpinbox::setValueForce(double newValue, bool force) { - if(qFuzzyCompare(m_value, newValue) || force) + // when force is true value does not consider min/max limits + if(force) { + m_value = newValue; + populateWidgets(); + Q_EMIT valueChanged(m_value); return; + } + + if(qFuzzyCompare(m_value, newValue)) { + // check if text in edit changed even if value does not + if(QString::number(m_value).compare(m_edit->text()) != 0) + populateWidgets(); // reset value + return; + } m_value = clamp(newValue, m_min, m_max); populateWidgets(); @@ -203,16 +228,9 @@ void MenuSpinbox::setValueForce(double newValue, bool force) void MenuSpinbox::setValueString(QString s) { userInput(s); } -QString MenuSpinbox::unit() const { return m_unit; } +QString MenuSpinbox::unit() const { return m_scale->unit(); } -void MenuSpinbox::setUnit(const QString &newUnit) -{ - if(m_unit == newUnit) - return; - m_unit = newUnit; - setScaleRange(m_scaleMin, m_scaleMax); - Q_EMIT unitChanged(newUnit); -} +void MenuSpinbox::setUnit(const QString &newUnit) { m_scale->setUnit(newUnit); } void MenuSpinbox::setMinValue(double min) { m_min = min; } @@ -240,15 +258,27 @@ void MenuSpinbox::setIncrementMode(IncrementMode im) m_incrementStrategy = new IncrementStrategyFixed(); break; } - m_incrementStrategy->setScale(m_scaleCb->currentData().toDouble()); + + // when scalling is not enbaled scale will be set to 1 + if(scallingEnabled()) { + m_incrementStrategy->setScale(m_scale->scaleCb()->currentData().toDouble()); + } else { + m_incrementStrategy->setScale(1); + } } void MenuSpinbox::setScalingEnabled(bool en) { - m_scalingEnabled = en; - m_scaleCb->setVisible(en); + m_scale->setScalingEnabled(en); + if(en) { + m_incrementStrategy->setScale(m_scale->scaleCb()->currentData().toDouble()); + } else { + m_incrementStrategy->setScale(1); + } } +bool MenuSpinbox::scallingEnabled() { return m_scale->scalingEnabled(); } + void MenuSpinbox::userInput(QString s) { // remove whitespace @@ -262,84 +292,57 @@ void MenuSpinbox::userInput(QString s) bool ok; double val = nr.toDouble(&ok); if(!ok) - setValue(m_value); // reset - - if(m_scalingEnabled) { - QString unit = s.mid(i + 1, 1); // isolate prefix and unit from the whole string (mV) - if(unit.length() > 0) { // user wrote a prefix and/or a unit - double scale = getScaleForPrefix(unit, Qt::CaseSensitive); // find the unit in the map - if(scale == -1) { - scale = getScaleForPrefix( - unit, - Qt::CaseInsensitive); // the user may have written 30K instead of 30k - } - - if(scale == -1) { - scale = 1; // do not scale the value at all + populateWidgets(); // reset + + if(m_scale->scalingEnabled()) { + QString unit = s.mid(i + 1, s.length() - 1); // isolate unit from the whole string (min) + if(unit.length() > 0) { // user wrote a unit + double scaleValue = m_scale->getScaleForSymbol(unit); // find the unit in the map + if(scaleValue == -1) { + populateWidgets(); // inputed prefix is invalid } else { - val = val * scale; // scale accordingly + val = val * scaleValue; // scale accordingly } + } else { - val = val * - m_scaleCb->currentData() - .toDouble(); // the user didnt write a scale => use scale in combobox + // Apply current scale to value + double scaleValue = m_scale->scaleCb()->currentData().toDouble(); + val = val * scaleValue; } } + setValue(val); } void MenuSpinbox::populateWidgets() { - // TODO: Review this function - if(!m_scalingEnabled) { - QSignalBlocker sb1(m_edit); - QSignalBlocker sb2(m_scaleCb); - m_edit->setText(Util::doubleToQString(m_value)); + // block all signals that affect value changes before updating widgets + // update values for edittext + m_edit->blockSignals(true); + + if(m_scale->scalingEnabled() && m_value != 0) { + + m_scale->scaleCb()->blockSignals(true); + m_scale->computeScale(m_value); + double scale = m_scale->scaleCb()->currentData().toDouble(); + + // print value based on scale + m_edit->setText(QString::number(m_value / scale, 'f', m_precision)); setToolTip(QString::number(m_value, 'f', 6)); // set tooltip - return; - } - int i = 0; - double scale = 1; - double absvalue = abs(m_value); - if(qFuzzyCompare(absvalue, 0)) { - scale = 1; - for(i = m_scaleCb->count() - 1; i >= 0; i--) { // find most suitable scale - if(m_scaleCb->itemData(i).toDouble() == 1) - break; - } + // update scale for increment strategy + m_incrementStrategy->setScale(scale); + m_scale->scaleCb()->blockSignals(false); + } else { - for(i = m_scaleCb->count() - 1; i >= 0; i--) { // find most suitable scale - scale = m_scaleCb->itemData(i).toDouble(); - if(absvalue / scale >= 10) - break; - } - if(i < 0) { - i = 0; - scale = m_scaleCb->itemData(i).toDouble(); - } + // when no scaling is enabled we just update value + m_edit->setText(QString::number(m_value, 'f', m_precision)); } + m_edit->blockSignals(false); - QSignalBlocker sb1(m_edit); - QSignalBlocker sb2(m_scaleCb); - m_edit->setText(QString::number(m_value / scale)); // reduce number to a meaningful value - m_scaleCb->setCurrentIndex(i); // set apropriate scale in combobox - m_incrementStrategy->setScale(m_scaleCb->currentData().toDouble()); setToolTip(QString::number(m_value, 'f', 6)); // set tooltip } -void MenuSpinbox::setScaleRange(double min, double max) -{ - m_scaleCb->clear(); - for(int i = 0; i < m_scales.count(); i++) { - auto scale = m_scales[i].scale; - if(scale >= min && scale <= max) { - m_scaleCb->addItem(m_scales[i].prefix + m_unit, scale); - } - } - m_incrementStrategy->setScale(m_scaleCb->currentData().toDouble()); -} - int MenuSpinbox::findLastDigit(QString str) { for(int i = str.length() - 1; i >= 0; --i) { @@ -354,9 +357,35 @@ double MenuSpinbox::clamp(double val, double min, double max) { val = std::max(val, min); val = std::min(val, max); + minMaxReached(val); return val; } +void MenuSpinbox::minMaxReached(double val) +{ + // disable decrement button if min is reached + if(val == m_min) { + m_minus->setEnabled(false); + } else { + m_minus->setEnabled(true); + } + + // disable increment button if max is reached + if(val == m_max) { + m_plus->setEnabled(false); + } else { + m_plus->setEnabled(true); + } +} + +int MenuSpinbox::precision() const { return m_precision; } + +void MenuSpinbox::setPrecision(int newPrecision) { m_precision = newPrecision; } + +Scale *MenuSpinbox::scale() const { return m_scale; } + +void MenuSpinbox::setScale(Scale *newScale) { m_scale = newScale; } + QString MenuSpinbox::name() const { return m_name; } void MenuSpinbox::setName(const QString &newName) @@ -368,22 +397,6 @@ void MenuSpinbox::setName(const QString &newName) Q_EMIT nameChanged(newName); } -double MenuSpinbox::getScaleForPrefix(QString prefix, Qt::CaseSensitivity s) -{ - for(int i = 0; i < m_scales.count(); i++) { - if(s == Qt::CaseSensitive) { - if(m_scales[i].prefix == prefix) { - return m_scales[i].scale; - } - } else { - if(m_scales[i].prefix.toLower() == prefix.toLower()) { - return m_scales[i].scale; - } - } - } - return -1; -} - } // namespace gui } // namespace scopy diff --git a/gui/src/widgets/scale.cpp b/gui/src/widgets/scale.cpp new file mode 100644 index 0000000000..e953cc876f --- /dev/null +++ b/gui/src/widgets/scale.cpp @@ -0,0 +1,208 @@ +/* + * Copyright (c) 2024 Analog Devices Inc. + * + * This file is part of Scopy + * (see https://www.github.com/analogdevicesinc/scopy). + * + * 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 . + * + */ + +#include "scale.h" + +namespace scopy { +namespace gui { + +Scale::Scale(QString unit, double min, double max, bool hasPrefix) + : m_unit(unit) + , m_min(min) + , m_max(max) + , m_hasPrefix(hasPrefix) +{ + m_scaleCb = new QComboBox(); + + if(hasPrefix) { + // PRESET METRIC PREFIX + m_scalePrefixes.append({QString("n"), 1e-9}); + m_scalePrefixes.append({QString("u"), 1e-6}); + m_scalePrefixes.append({QString("m"), 1e-3}); + m_scalePrefixes.append({QString(""), 1e0}); + m_scalePrefixes.append({QString("k"), 1e3}); + m_scalePrefixes.append({QString("M"), 1e6}); + m_scalePrefixes.append({QString("G"), 1e9}); + } + + m_scaleOptions.append({m_unit, 1e0}); + populateScaleCb(); + m_scaleCb->setCurrentIndex(0); +} + +Scale::~Scale() +{ + m_scaleOptions.clear(); + m_scalePrefixes.clear(); +} + +double Scale::getScaleForPrefix(QString prefix, Qt::CaseSensitivity s) +{ + for(int i = 0; i < m_scalePrefixes.count(); i++) { + + if(s == Qt::CaseSensitive) { + if(m_scalePrefixes[i].prefix == prefix) { + return m_scalePrefixes[i].scale; + } + } else { + if(m_scalePrefixes[i].prefix.toLower() == prefix.toLower()) { + return m_scalePrefixes[i].scale; + } + } + } + return -1; +} + +double Scale::getScaleForUnit(QString unit, Qt::CaseSensitivity s) +{ + for(int i = 0; i < m_scaleOptions.count(); i++) { + if(s == Qt::CaseSensitive) { + if(m_scaleOptions[i].option == unit) { + return m_scaleOptions[i].scale; + } + } else { + if(m_scaleOptions[i].option.toLower() == unit.toLower()) { + return m_scaleOptions[i].scale; + } + } + } + return -1; +} + +double Scale::getScaleForSymbol(QString symbol) +{ + if(m_hasPrefix) { + // TODO apply some filters for unit of measure ?? + double value = getScaleForPrefix(symbol.mid(0, 1), Qt::CaseSensitive); + if(value == -1) { + value = getScaleForPrefix(symbol.mid(0, 1), Qt::CaseInsensitive); + } + return value; + } else { + double value = getScaleForUnit(symbol, Qt::CaseSensitive); + if(value == -1) { + value = getScaleForUnit(symbol, Qt::CaseInsensitive); + } + return value; + } +} + +bool Scale::scalingEnabled() const { return m_scalingEnabled; } + +void Scale::setScalingEnabled(bool newScalingEnabled) +{ + m_scalingEnabled = newScalingEnabled; + m_scaleCb->setVisible(newScalingEnabled); +} + +QComboBox *Scale::scaleCb() const { return m_scaleCb; } + +QString Scale::unit() const { return m_unit; } + +void Scale::setUnit(const QString &newUnit) +{ + m_unit = newUnit; + // when using custom scales changing the unit also resets the scale + if(!m_hasPrefix) { + // reset scale options to new unit + m_scaleOptions.clear(); + m_scaleOptions.append({m_unit, 1e0}); + } + populateScaleCb(); +} + +void Scale::computeScale(double value) +{ + // if there is only one option in the scale use that + if(m_scaleCb->count() == 0) { + return; + } + // use absolute value when computing scale + double val = abs(value); + // check if value can be upscaled or downscaled if scaled is changed update scale + int curretnScaleIndex = m_scaleCb->currentIndex(); + // value is bigger than current scale + if(val > m_scaleCb->itemData(curretnScaleIndex).toDouble()) { + if(curretnScaleIndex != m_scaleCb->count() - 1) { + int i = 0; + // find coresponding upper scale + while((val >= m_scaleCb->itemData(curretnScaleIndex + i).toDouble()) && + ((curretnScaleIndex + i) <= m_scaleCb->count() - 1)) { + i++; + } + m_scaleCb->setCurrentIndex(curretnScaleIndex + i - 1); + } + } else { + // value is lower than current scale + int i = curretnScaleIndex; + // find coresponding lower scale + while((val < m_scaleCb->itemData(i).toDouble()) && (i > 0)) { + i--; + } + m_scaleCb->setCurrentIndex(i); + } +} + +bool Scale::hasPrefix() const { return m_hasPrefix; } + +void Scale::setHasPrefix(bool newHasPrefix) +{ + m_hasPrefix = newHasPrefix; + populateScaleCb(); +} + +void Scale::populateScaleCb() +{ + m_scaleCb->clear(); + if(m_hasPrefix) { + for(int i = 0; i < m_scalePrefixes.count(); i++) { + auto scale = m_scalePrefixes[i].scale; + m_scaleCb->addItem(m_scalePrefixes[i].prefix + m_unit, scale); + } + } else { + for(int i = 0; i < m_scaleOptions.count(); i++) { + m_scaleCb->addItem(m_scaleOptions[i].option, m_scaleOptions[i].scale); + } + } + + Q_EMIT scaleUpdated(); +} + +QList Scale::scalePrefixes() const { return m_scalePrefixes; } + +void Scale::setScalePrefixes(const QList &newScalePrefixes) +{ + m_scalePrefixes = newScalePrefixes; + populateScaleCb(); +} + +QList Scale::scaleOptions() const { return m_scaleOptions; } + +void Scale::setScaleOptions(const QList &newScaleOptions) +{ + m_scaleOptions = newScaleOptions; + populateScaleCb(); +} + +} // namespace gui +} // namespace scopy + +#include "moc_scale.cpp" diff --git a/iio-widgets/src/guistrategy/rangeguistrategy.cpp b/iio-widgets/src/guistrategy/rangeguistrategy.cpp index 1a01bfcc45..da48929b99 100644 --- a/iio-widgets/src/guistrategy/rangeguistrategy.cpp +++ b/iio-widgets/src/guistrategy/rangeguistrategy.cpp @@ -39,8 +39,6 @@ RangeAttrUi::RangeAttrUi(IIOWidgetFactoryRecipe recipe, bool isCompact, QWidget m_ui->layout()->setContentsMargins(0, 0, 0, 0); m_spinBox = new gui::MenuSpinbox(m_recipe.data.toUpper(), 0, "", 0, 1, true, false, m_ui); - m_spinBox->setIncrementMode(gui::MenuSpinbox::IS_FIXED); - m_spinBox->setScaleRange(1, 1); m_spinBox->setScalingEnabled(false); m_ui->layout()->addWidget(m_spinBox); diff --git a/plugins/adc/src/freq/fftplotcomponentsettings.cpp b/plugins/adc/src/freq/fftplotcomponentsettings.cpp index e778b438f5..60a924395a 100644 --- a/plugins/adc/src/freq/fftplotcomponentsettings.cpp +++ b/plugins/adc/src/freq/fftplotcomponentsettings.cpp @@ -68,6 +68,8 @@ FFTPlotComponentSettings::FFTPlotComponentSettings(FFTPlotComponent *plt, QWidge MenuCollapseSection::MHW_BASEWIDGET, parent); m_yCtrl = new MenuPlotAxisRangeControl(m_plotComponent->fftPlot()->yAxis(), this); + m_yCtrl->minSpinbox()->scale()->setHasPrefix(false); + m_yCtrl->maxSpinbox()->scale()->setHasPrefix(false); m_yCtrl->minSpinbox()->setIncrementMode(MenuSpinbox::IS_FIXED); m_yCtrl->maxSpinbox()->setIncrementMode(MenuSpinbox::IS_FIXED); m_yCtrl->minSpinbox()->setUnit("dB"); @@ -76,8 +78,6 @@ FFTPlotComponentSettings::FFTPlotComponentSettings(FFTPlotComponent *plt, QWidge m_yCtrl->maxSpinbox()->setMinValue(-1000); m_yCtrl->minSpinbox()->setMaxValue(1000); m_yCtrl->maxSpinbox()->setMaxValue(1000); - m_yCtrl->minSpinbox()->setScaleRange(1, 1); - m_yCtrl->maxSpinbox()->setScaleRange(1, 1); MenuOnOffSwitch *m_autoscaleBtn = new MenuOnOffSwitch(tr("AUTOSCALE"), plotMenu, false); m_autoscaler = new PlotAutoscaler(this); @@ -96,8 +96,7 @@ FFTPlotComponentSettings::FFTPlotComponentSettings(FFTPlotComponent *plt, QWidge m_plotComponent->fftPlot()->yAxis()->getFormatter()->setTwoDecimalMode(false); m_yPwrOffset = new MenuSpinbox("Power Offset", 0, "dB", -300, 300, true, false, yaxis); - m_yPwrOffset->setScaleRange(1, 1); - m_yPwrOffset->setIncrementMode(MenuSpinbox::IS_FIXED); + m_yPwrOffset->scale()->setHasPrefix(false); m_windowCb = new MenuCombo("Window", yaxis); diff --git a/plugins/adc/src/freq/fftplotmanagersettings.cpp b/plugins/adc/src/freq/fftplotmanagersettings.cpp index a0b9bae744..0e2f631d35 100644 --- a/plugins/adc/src/freq/fftplotmanagersettings.cpp +++ b/plugins/adc/src/freq/fftplotmanagersettings.cpp @@ -108,7 +108,8 @@ QWidget *FFTPlotManagerSettings::createXAxisMenu(QWidget *parent) MenuCollapseSection::MHW_BASEWIDGET, parent); m_bufferSizeSpin = new MenuSpinbox("Buffer Size", 16, "samples", 0, 4000000, true, false, section); - m_bufferSizeSpin->setScaleRange(1, 1e6); + m_bufferSizeSpin->setIncrementMode(MenuSpinbox::IS_POW2); + m_bufferSizeSpin->scale()->setScalePrefixes({{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); connect(m_bufferSizeSpin, &MenuSpinbox::valueChanged, this, [=](double val) { setBufferSize((uint32_t)val); }); QWidget *xMinMax = new QWidget(section); @@ -118,10 +119,7 @@ QWidget *FFTPlotManagerSettings::createXAxisMenu(QWidget *parent) xMinMax->setLayout(xMinMaxLayout); m_xmin = new MenuSpinbox("XMin", 0, "samples", -DBL_MAX, DBL_MAX, true, false, xMinMax); - m_xmin->setIncrementMode(gui::MenuSpinbox::IS_FIXED); - m_xmax = new MenuSpinbox("XMax", 0, "samples", -DBL_MAX, DBL_MAX, true, false, xMinMax); - m_xmax->setIncrementMode(gui::MenuSpinbox::IS_FIXED); connect(m_xmin, &MenuSpinbox::valueChanged, this, [=](double min) { m_plotManager->setXInterval(m_xmin->value(), m_xmax->value()); }); @@ -194,6 +192,7 @@ QWidget *FFTPlotManagerSettings::createXAxisMenu(QWidget *parent) m_sampleRateSpin = new MenuSpinbox("Sample Rate", 1, "Hz", 0, DBL_MAX, true, false, section); m_sampleRateSpin->setIncrementMode(MenuSpinbox::IS_125); + m_sampleRateSpin->scale()->setHasPrefix(false); m_sampleRateSpin->setValue(10); m_sampleRateSpin->setEnabled(false); diff --git a/plugins/adc/src/freq/grfftchannelcomponent.cpp b/plugins/adc/src/freq/grfftchannelcomponent.cpp index df2d1cc8b0..7ecd239fc4 100644 --- a/plugins/adc/src/freq/grfftchannelcomponent.cpp +++ b/plugins/adc/src/freq/grfftchannelcomponent.cpp @@ -239,8 +239,7 @@ QWidget *GRFFTChannelComponent::createMarkerMenu(QWidget *parent) fixedMarkerEditBtn->setVisible(false); MenuSpinbox *markerCnt = new MenuSpinbox("Marker count", 5, "markers", 0, 9, true, false, section); - markerCnt->setIncrementMode(MenuSpinbox::IS_FIXED); - markerCnt->setScaleRange(1, 10); + markerCnt->scale()->setHasPrefix(false); markerCnt->setValue(5); connect(markerCnt, &MenuSpinbox::valueChanged, this, diff --git a/plugins/adc/src/time/grtimechannelcomponent.cpp b/plugins/adc/src/time/grtimechannelcomponent.cpp index 81c008a646..d7f2165e9a 100644 --- a/plugins/adc/src/time/grtimechannelcomponent.cpp +++ b/plugins/adc/src/time/grtimechannelcomponent.cpp @@ -275,8 +275,8 @@ void GRTimeChannelComponent::setYModeHelper(YMode mode) } scale = 1.0 / ((float)((uint64_t)1 << fmt->bits)); if(fmt->is_signed) { - ymin = -0.5; - ymax = 0.5; + ymin = -1; + ymax = 1; } else { ymin = 0; ymax = 1; diff --git a/plugins/adc/src/time/timeplotcomponentsettings.cpp b/plugins/adc/src/time/timeplotcomponentsettings.cpp index 2fa880a05d..fa0c90ec83 100644 --- a/plugins/adc/src/time/timeplotcomponentsettings.cpp +++ b/plugins/adc/src/time/timeplotcomponentsettings.cpp @@ -301,6 +301,11 @@ void TimePlotComponentSettings::updateYAxis() min = s->yMin(); } } + m_yCtrl->minSpinbox()->setMinValue(min); + m_yCtrl->minSpinbox()->setMaxValue(max); + m_yCtrl->maxSpinbox()->setMinValue(min); + m_yCtrl->maxSpinbox()->setMaxValue(max); + m_yCtrl->setMin(min); m_yCtrl->setMax(max); diff --git a/plugins/adc/src/time/timeplotmanagersettings.cpp b/plugins/adc/src/time/timeplotmanagersettings.cpp index 6909aa68d2..33ffbf1978 100644 --- a/plugins/adc/src/time/timeplotmanagersettings.cpp +++ b/plugins/adc/src/time/timeplotmanagersettings.cpp @@ -109,7 +109,8 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) bufferPlotSize->setLayout(bufferPlotSizeLayout); m_bufferSizeSpin = new MenuSpinbox("Buffer Size", 16, "samples", 16, 4000000, true, false, bufferPlotSize); - m_bufferSizeSpin->setScaleRange(1, 1e6); + m_bufferSizeSpin->setIncrementMode(MenuSpinbox::IS_POW2); + m_bufferSizeSpin->scale()->setScalePrefixes({{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); connect(m_bufferSizeSpin, &MenuSpinbox::valueChanged, this, [=](double val) { if(m_plotSizeSpin->value() < val) { @@ -122,7 +123,8 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) connect(this, &TimePlotManagerSettings::bufferSizeChanged, m_bufferSizeSpin, &MenuSpinbox::setValue); m_plotSizeSpin = new MenuSpinbox("Plot Size", 16, "samples", 0, 4000000, true, false, bufferPlotSize); - m_plotSizeSpin->setScaleRange(1, 1e6); + m_plotSizeSpin->setIncrementMode(MenuSpinbox::IS_POW2); + m_plotSizeSpin->scale()->setScalePrefixes({{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); connect(m_plotSizeSpin, &MenuSpinbox::valueChanged, this, [=](double val) { setPlotSize((uint32_t)val); }); @@ -153,10 +155,7 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) xMinMax->setLayout(xMinMaxLayout); m_xmin = new MenuSpinbox("XMin", -1, "samples", -DBL_MAX, DBL_MAX, true, false, xMinMax); - m_xmin->setIncrementMode(gui::MenuSpinbox::IS_FIXED); - m_xmax = new MenuSpinbox("XMax", -1, "samples", -DBL_MAX, DBL_MAX, true, false, xMinMax); - m_xmax->setIncrementMode(gui::MenuSpinbox::IS_FIXED); connect(m_xmin, &MenuSpinbox::valueChanged, this, [=](double min) { m_plotManager->setXInterval(m_xmin->value(), m_xmax->value()); }); @@ -177,9 +176,14 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) if(xcb->itemData(idx) == XMODE_SAMPLES) { m_sampleRateSpin->setValue(1); m_xmin->setUnit("samples"); - m_xmin->setScaleRange(1, 1e6); + m_xmin->scale()->setHasPrefix(true); + m_xmin->scale()->setScalePrefixes( + {{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); + m_xmax->setUnit("samples"); - m_xmax->setScaleRange(1, 1e6); + m_xmax->scale()->setHasPrefix(true); + m_xmax->scale()->setScalePrefixes( + {{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); m_plotManager->setXUnit("samples"); for(PlotComponent *plt : m_plotManager->plots()) { auto p = dynamic_cast(plt); @@ -191,10 +195,21 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) m_sampleRateSpin->setVisible(true); m_sampleRateSpin->setEnabled(false); m_sampleRateSpin->setValue(readSampleRate()); + m_xmin->setUnit("s"); - m_xmin->setScaleRange(0, 1); + m_xmin->scale()->setHasPrefix(false); + m_xmin->scale()->setScaleOptions({{QString("ns"), 1e-9}, + {QString("us"), 1e-6}, + {QString("ms"), 1e-3}, + {QString("s"), 1}}); + m_xmax->setUnit("s"); - m_xmax->setScaleRange(0, 1); + m_xmax->scale()->setHasPrefix(false); + m_xmax->scale()->setScaleOptions({{QString("ns"), 1e-9}, + {QString("us"), 1e-6}, + {QString("ms"), 1e-3}, + {QString("s"), 1}}); + m_plotManager->setXUnit("s"); for(PlotComponent *plt : m_plotManager->plots()) { @@ -209,9 +224,19 @@ QWidget *TimePlotManagerSettings::createXAxisMenu(QWidget *parent) m_sampleRateSpin->setEnabled(true); m_xmin->setUnit("s"); - m_xmin->setScaleRange(0, 1); + m_xmin->scale()->setHasPrefix(false); + m_xmin->scale()->setScaleOptions({{QString("ns"), 1e-9}, + {QString("us"), 1e-6}, + {QString("ms"), 1e-3}, + {QString("s"), 1}}); + m_xmax->setUnit("s"); - m_xmax->setScaleRange(0, 1); + m_xmax->scale()->setHasPrefix(false); + m_xmax->scale()->setScaleOptions({{QString("ns"), 1e-9}, + {QString("us"), 1e-6}, + {QString("ms"), 1e-3}, + {QString("s"), 1}}); + m_plotManager->setXUnit("s"); for(PlotComponent *plt : m_plotManager->plots()) { auto p = dynamic_cast(plt); diff --git a/plugins/dac/src/bufferdacaddon.cpp b/plugins/dac/src/bufferdacaddon.cpp index 51ae43652b..1c2163e864 100644 --- a/plugins/dac/src/bufferdacaddon.cpp +++ b/plugins/dac/src/bufferdacaddon.cpp @@ -80,6 +80,7 @@ BufferDacAddon::BufferDacAddon(DacDataModel *model, QWidget *parent) buffersizeContainer->setProperty("tutorial_name", "BUFFERSIZE"); m_bufferSizeSpin = new MenuSpinbox("Buffer size", 0, "samples", 16, 16 * 1024 * 1024, true, false, buffersizeContainer); + m_bufferSizeSpin->scale()->setScalePrefixes({{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); StyleHelper::BackgroundWidget(m_bufferSizeSpin); connect(m_bufferSizeSpin, &MenuSpinbox::valueChanged, this, [&](double value) { m_model->setBuffersize(value); }); @@ -91,7 +92,7 @@ BufferDacAddon::BufferDacAddon(DacDataModel *model, QWidget *parent) MenuSectionWidget *kernelContainer = new MenuSectionWidget(this); kernelContainer->setProperty("tutorial_name", "KERNEL_BUFFERS"); m_kernelCountSpin = new MenuSpinbox("Kernel buffers", 0, "", 1, 64, true, false, buffersizeContainer); - m_kernelCountSpin->setIncrementMode(MenuSpinbox::IS_FIXED); + m_kernelCountSpin->setScalingEnabled(false); StyleHelper::BackgroundWidget(m_kernelCountSpin); connect(m_kernelCountSpin, &MenuSpinbox::valueChanged, this, [&](double value) { m_model->setKernelBuffersCount(value); }); @@ -101,6 +102,7 @@ BufferDacAddon::BufferDacAddon(DacDataModel *model, QWidget *parent) // Decimation section - hidden for now MenuSpinbox *decimationSpin = new MenuSpinbox("Decimation", 0, "", 1, 1000, true, false, bufferConfigSection); + decimationSpin->setIncrementMode(MenuSpinbox::IS_POW2); StyleHelper::BackgroundWidget(decimationSpin); connect(decimationSpin, &MenuSpinbox::valueChanged, this, [&](double value) { m_model->setDecimation(value); }); decimationSpin->setValue(1); @@ -152,12 +154,11 @@ BufferDacAddon::BufferDacAddon(DacDataModel *model, QWidget *parent) filesizeContainer->setProperty("tutorial_name", "FILESIZE"); m_fileSizeSpin = new MenuSpinbox("File size", 0, "samples", 16, 16 * 1024 * 1024, false, false, filesizeContainer); - m_fileSizeSpin->setIncrementMode(MenuSpinbox::IS_FIXED); StyleHelper::BackgroundWidget(m_fileSizeSpin); connect( m_fileSizeSpin, &MenuSpinbox::valueChanged, this, [&](double value) { m_model->setFilesize(value); }, Qt::QueuedConnection); - m_fileSizeSpin->setScaleRange(1, 16 * 1024 * 1024); + m_fileSizeSpin->scale()->setScalePrefixes({{QString(""), 1e0}, {QString("k"), 1e3}, {QString("M"), 1e6}}); m_fileSizeSpin->setValue(16); filesizeContainer->contentLayout()->addWidget(m_fileSizeSpin); filesizeContainer->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred); diff --git a/plugins/datalogger/src/menus/datamonitorsettings.cpp b/plugins/datalogger/src/menus/datamonitorsettings.cpp index f54cb16713..55358368ed 100644 --- a/plugins/datalogger/src/menus/datamonitorsettings.cpp +++ b/plugins/datalogger/src/menus/datamonitorsettings.cpp @@ -129,7 +129,6 @@ QWidget *DataMonitorSettings::generateYAxisSettings(QWidget *parent) plotAutoscaler->setTolerance(10); MenuOnOffSwitch *autoscale = new MenuOnOffSwitch(tr("AUTOSCALE"), yAxisSection, false); - autoscale->onOffswitch()->setChecked(true); connect(autoscale->onOffswitch(), &QAbstractButton::toggled, this, [=, this](bool toggled) { plotYAxisController->setEnabled(!toggled); @@ -140,6 +139,8 @@ QWidget *DataMonitorSettings::generateYAxisSettings(QWidget *parent) } }); + autoscale->onOffswitch()->setChecked(true); + auto &&timeTracker = TimeManager::GetInstance(); connect(timeTracker, &TimeManager::toggleRunning, this, [=, this](bool toggled) { diff --git a/plugins/datalogger/src/menus/plottimeaxiscontroller.cpp b/plugins/datalogger/src/menus/plottimeaxiscontroller.cpp index cf7e4ee1a4..5afca03802 100644 --- a/plugins/datalogger/src/menus/plottimeaxiscontroller.cpp +++ b/plugins/datalogger/src/menus/plottimeaxiscontroller.cpp @@ -61,8 +61,8 @@ PlotTimeAxisController::PlotTimeAxisController(MonitorPlot *m_plot, QWidget *par m_xdelta = new gui::MenuSpinbox("Delta", DataMonitorUtils::getAxisDefaultMaxValue(), "s", 0, DBL_MAX, false, false, xAxisContainer); - m_xdelta->setScaleRange(1, 1); - m_xdelta->setIncrementMode(gui::MenuSpinbox::IS_FIXED); + m_xdelta->scale()->setHasPrefix(false); + m_xdelta->scale()->setScaleOptions({{QString("s"), 1}, {QString("min"), 60}, {QString("h"), 3600}}); m_xdelta->setValue(DataMonitorUtils::getAxisDefaultMaxValue()); auto &&timeTracker = TimeManager::GetInstance(); diff --git a/plugins/pqm/src/waveforminstrument.cpp b/plugins/pqm/src/waveforminstrument.cpp index cef56836fc..04556d5ce3 100644 --- a/plugins/pqm/src/waveforminstrument.cpp +++ b/plugins/pqm/src/waveforminstrument.cpp @@ -178,7 +178,6 @@ QWidget *WaveformInstrument::createMenuPlotSection(QWidget *parent) // timespan m_timespanSpin = new gui::MenuSpinbox(tr("Timespan"), 1, "s", 0.02, 10, true, false, plotSection); - m_timespanSpin->setIncrementMode(gui::MenuSpinbox::IS_FIXED); m_timespanSpin->setValue(1); connect(m_timespanSpin, &gui::MenuSpinbox::valueChanged, this, [=, this](double value) { m_voltagePlot->xAxis()->setMin(-value); diff --git a/plugins/swiot/src/ad74413r/ad74413r.cpp b/plugins/swiot/src/ad74413r/ad74413r.cpp index af449c6eee..ce24fe8ed3 100644 --- a/plugins/swiot/src/ad74413r/ad74413r.cpp +++ b/plugins/swiot/src/ad74413r/ad74413r.cpp @@ -705,7 +705,7 @@ QWidget *Ad74413r::createSettingsMenu(QWidget *parent) // timespan m_timespanSpin = new MenuSpinbox(tr("Timespan"), 1, "s", 0.1, 10, true, false, plotTimespanSection); - m_timespanSpin->setIncrementMode(MenuSpinbox::IS_FIXED); + m_timespanSpin->scale()->setHasPrefix(false); connect(m_timespanSpin, &MenuSpinbox::valueChanged, this, [=, this](double value) { m_plot->xAxis()->setMin(-value); }); diff --git a/plugins/swiot/src/ad74413r/buffermenuview.cpp b/plugins/swiot/src/ad74413r/buffermenuview.cpp index 08413cf42d..ff7209314f 100644 --- a/plugins/swiot/src/ad74413r/buffermenuview.cpp +++ b/plugins/swiot/src/ad74413r/buffermenuview.cpp @@ -140,11 +140,7 @@ QWidget *BufferMenuView::createVerticalSettingsMenu(QString unit, double yMin, d "Y-AXIS", MenuCollapseSection::MHCW_NONE, MenuCollapseSection::MHW_BASEWIDGET, verticalContainer); auto m_yMin = new MenuSpinbox("YMin", yMin, unit, -DBL_MAX, DBL_MAX, true, false, verticalContainer); - m_yMin->setIncrementMode(gui::MenuSpinbox::IS_FIXED); - auto m_yMax = new MenuSpinbox("YMax", yMax, unit, -DBL_MAX, DBL_MAX, true, false, verticalContainer); - m_yMax->setIncrementMode(gui::MenuSpinbox::IS_FIXED); - layout->addWidget(m_yMin); layout->addWidget(m_yMax); diff --git a/plugins/swiot/src/max14906/diosettingstab.cpp b/plugins/swiot/src/max14906/diosettingstab.cpp index 6506c3095a..3f02e841ba 100644 --- a/plugins/swiot/src/max14906/diosettingstab.cpp +++ b/plugins/swiot/src/max14906/diosettingstab.cpp @@ -51,8 +51,7 @@ DioSettingsTab::DioSettingsTab(QWidget *parent) // timespan m_maxSpinButton = new MenuSpinbox(tr("Timespan"), 10, "s", 1, 300, true, false, this); - m_maxSpinButton->setIncrementMode(MenuSpinbox::IS_FIXED); - m_maxSpinButton->setScaleRange(1, 1); + m_maxSpinButton->scale()->setHasPrefix(false); connect(m_maxSpinButton, &MenuSpinbox::valueChanged, this, [this]() { Q_EMIT timeValueChanged(m_maxSpinButton->value()); });