Initialise Trace widgets when the trace is received by the View
[pulseview.git] / pv / view / logicsignal.h
index ed561e6fd842cd1dfba56549f37d5e8c47a12829..3b37c5d322ffe2b4b388f8c87cf1c82c0c88ac00 100644 (file)
@@ -35,6 +35,8 @@ namespace view {
 
 class LogicSignal : public Signal
 {
+       Q_OBJECT
+
 private:
        static const float Oversampling;
 
@@ -45,11 +47,13 @@ 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();
 
+       void init_context_bar_actions(QWidget *parent);
+
        const std::list<QAction*> get_context_bar_actions();
 
        /**
@@ -72,8 +76,32 @@ 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 update_trigger_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;
+
+       QAction *_trigger_none;
+       QAction *_trigger_rising;
+       QAction *_trigger_high;
+       QAction *_trigger_falling;
+       QAction *_trigger_low;
+       QAction *_trigger_change;
 };
 
 } // namespace view