X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fpopups%2Fprobes.h;h=0dc324a00ae6071c130619b8b789c49b39df8728;hb=65cbcf462f8bab24ce02c80af64248a0c78c2f6a;hp=33f5d996722c42aa72c9567991eb423f74ae8c53;hpb=51d4a9ab96a6bf64a1fcd1700e7e174498d4c118;p=pulseview.git diff --git a/pv/popups/probes.h b/pv/popups/probes.h index 33f5d99..0dc324a 100644 --- a/pv/popups/probes.h +++ b/pv/popups/probes.h @@ -21,14 +21,31 @@ #ifndef PULSEVIEW_PV_POPUPS_PROBES_H #define PULSEVIEW_PV_POPUPS_PROBES_H -#include -#include -#include -#include +#include + +#include +#include +#include #include +class QCheckBox; +class QGridLayout; + namespace pv { + +class SigSession; + +namespace prop { +namespace binding { +class DeviceOptions; +} +} + +namespace view { +class Signal; +} + namespace popups { class Probes : public pv::widgets::Popup @@ -36,26 +53,43 @@ class Probes : public pv::widgets::Popup Q_OBJECT public: - Probes(sr_dev_inst *sdi, QWidget *parent); + Probes(SigSession &_session, QWidget *parent); private: void set_all_probes(bool set); + void populate_group(const sr_probe_group *group, + const std::vector< boost::shared_ptr > sigs); + + QGridLayout* create_probe_group_grid( + const std::vector< boost::shared_ptr > sigs); + +private: + void showEvent(QShowEvent *e); + private slots: - void item_changed(QListWidgetItem *item); + void on_probe_checked(QWidget *widget); void enable_all_probes(); void disable_all_probes(); private: - sr_dev_inst *_sdi; + pv::SigSession &_session; + + QFormLayout _layout; + + bool _updating_probes; + + std::vector< boost::shared_ptr > + _group_bindings; + std::map< QCheckBox*, boost::shared_ptr > + _check_box_signal_map; - QVBoxLayout _layout; + QHBoxLayout _buttons_bar; + QPushButton _enable_all_probes; + QPushButton _disable_all_probes; - QListWidget _probes; - QToolBar _probes_bar; - QToolButton _enable_all_probes; - QToolButton _disable_all_probes; + QSignalMapper _check_box_mapper; }; } // popups