]> sigrok.org Git - pulseview.git/blobdiff - pv/view/logicsignal.h
Added trigger selection handlers
[pulseview.git] / pv / view / logicsignal.h
index ed561e6fd842cd1dfba56549f37d5e8c47a12829..81a6e7c0c2b3e735c2725c05bb6cd82cda780ad1 100644 (file)
@@ -35,6 +35,8 @@ namespace view {
 
 class LogicSignal : public Signal
 {
+       Q_OBJECT
+
 private:
        static const float Oversampling;
 
@@ -45,7 +47,7 @@ private:
        static const QColor SignalColours[10];
 
 public:
-       LogicSignal(const sr_probe *const probe,
+       LogicSignal(pv::SigSession &session, const sr_probe *const probe,
                boost::shared_ptr<pv::data::Logic> data);
 
        virtual ~LogicSignal();
@@ -72,8 +74,36 @@ private:
                bool level, double samples_per_pixel, double pixels_offset,
                float x_offset, float y_offset);
 
+       static void add_trigger_action(const char *trig_types, char type,
+               QAction *action, std::list<QAction*> &actions);
+
+       void set_trigger(char type);
+
+private slots:
+       void on_trigger_none();
+       void on_trigger_rising();
+       void on_trigger_high();
+       void on_trigger_falling();
+       void on_trigger_low();
+       void on_trigger_change();
+
 private:
        boost::shared_ptr<pv::data::Logic> _data;
+
+       QAction _separator;
+
+       QIcon _icon_trigger_none;
+       QAction _trigger_none;
+       QIcon _icon_trigger_rising;
+       QAction _trigger_rising;
+       QIcon _icon_trigger_high;
+       QAction _trigger_high;
+       QIcon _icon_trigger_falling;
+       QAction _trigger_falling;
+       QIcon _icon_trigger_low;
+       QAction _trigger_low;
+       QIcon _icon_trigger_change;
+       QAction _trigger_change;
 };
 
 } // namespace view