X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fprop%2Fbool.cpp;h=6c89741ff6f6657779d74f4a6e30d0c7675d72d4;hb=2836487f7500f9775356f67711754df92cb4e282;hp=61b2f17adaa9848cc28d6735a49cbff3d024001a;hpb=efdec55aec1a137460fa362a381ed1904182bfed;p=pulseview.git
diff --git a/pv/prop/bool.cpp b/pv/prop/bool.cpp
index 61b2f17..6c89741 100644
--- a/pv/prop/bool.cpp
+++ b/pv/prop/bool.cpp
@@ -17,7 +17,7 @@
* along with this program; if not, see .
*/
-#include
+#include
#include
@@ -26,8 +26,8 @@
namespace pv {
namespace prop {
-Bool::Bool(QString name, Getter getter, Setter setter) :
- Property(name, getter, setter),
+Bool::Bool(QString name, QString desc, Getter getter, Setter setter) :
+ Property(name, desc, getter, setter),
check_box_(nullptr)
{
}
@@ -44,11 +44,10 @@ QWidget* Bool::get_widget(QWidget *parent, bool auto_commit)
if (!variant.gobj())
return nullptr;
- bool value = Glib::VariantBase::cast_dynamic>(
- variant).get();
-
check_box_ = new QCheckBox(name(), parent);
- check_box_->setCheckState(value ? Qt::Checked : Qt::Unchecked);
+ check_box_->setToolTip(desc());
+
+ update_widget();
if (auto_commit)
connect(check_box_, SIGNAL(stateChanged(int)),
@@ -62,6 +61,20 @@ bool Bool::labeled_widget() const
return true;
}
+void Bool::update_widget()
+{
+ if (!check_box_)
+ return;
+
+ Glib::VariantBase variant = getter_();
+ assert(variant.gobj());
+
+ bool value = Glib::VariantBase::cast_dynamic>(
+ variant).get();
+
+ check_box_->setCheckState(value ? Qt::Checked : Qt::Unchecked);
+}
+
void Bool::commit()
{
assert(setter_);
@@ -78,5 +91,5 @@ void Bool::on_state_changed(int)
commit();
}
-} // prop
-} // pv
+} // namespace prop
+} // namespace pv