X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fprop%2Fdouble.cpp;h=188286ae1c4ff08a22687c0ac11704c69920ff23;hp=d7c79ca7db19ce6481d3b8293c06848fcd5364d0;hb=6e89374a6796f8d5d9cc61b0a2f7e98562a034ae;hpb=9f6af8bd3a6bc12f9b32b91cd2a173a8a7763f5c diff --git a/pv/prop/double.cpp b/pv/prop/double.cpp index d7c79ca7..188286ae 100644 --- a/pv/prop/double.cpp +++ b/pv/prop/double.cpp @@ -35,33 +35,44 @@ Double::Double(QString name, QString suffix, optional< pair > range, optional step, - function getter, - function setter) : - Property(name), + Getter getter, + Setter setter) : + Property(name, getter, setter), _decimals(decimals), _suffix(suffix), _range(range), _step(step), - _getter(getter), - _setter(setter), _spin_box(NULL) { } -QWidget* Double::get_widget(QWidget *parent) +Double::~Double() { - if(_spin_box) +} + +QWidget* Double::get_widget(QWidget *parent, bool auto_commit) +{ + if (_spin_box) return _spin_box; _spin_box = new QDoubleSpinBox(parent); _spin_box->setDecimals(_decimals); _spin_box->setSuffix(_suffix); - if(_range) + if (_range) _spin_box->setRange(_range->first, _range->second); - if(_step) + if (_step) _spin_box->setSingleStep(*_step); - _spin_box->setValue(_getter ? _getter() : 0.0); + GVariant *const value = _getter ? _getter() : NULL; + + if (value) { + _spin_box->setValue(g_variant_get_double(value)); + g_variant_unref(value); + } + + if (auto_commit) + connect(_spin_box, SIGNAL(valueChanged(double)), + this, SLOT(on_value_changed(double))); return _spin_box; } @@ -70,10 +81,15 @@ void Double::commit() { assert(_setter); - if(!_spin_box) + if (!_spin_box) return; - _setter(_spin_box->value()); + _setter(g_variant_new_double(_spin_box->value())); +} + +void Double::on_value_changed(double) +{ + commit(); } } // prop