]> sigrok.org Git - pulseview.git/blobdiff - pv/view/logicsignal.h
LogicSignal: Ported triggers to new API
[pulseview.git] / pv / view / logicsignal.h
index a9c24b44da7bd13b27896ffc5cdc2e2173f54fad..958abd8f1890c26f7661ee75884b9d3cc096b3ed 100644 (file)
  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
  */
 
-#ifndef PULSEVIEW_PV_LOGICSIGNAL_H
-#define PULSEVIEW_PV_LOGICSIGNAL_H
+#ifndef PULSEVIEW_PV_VIEW_LOGICSIGNAL_H
+#define PULSEVIEW_PV_VIEW_LOGICSIGNAL_H
 
 #include "signal.h"
 
-#include <boost/shared_ptr.hpp>
+#include <memory>
+
+class QToolBar;
+
+namespace sigrok {
+       class Device;
+       class TriggerMatchType;
+}
 
 namespace pv {
 
@@ -35,6 +42,8 @@ namespace view {
 
 class LogicSignal : public Signal
 {
+       Q_OBJECT
+
 private:
        static const float Oversampling;
 
@@ -45,36 +54,64 @@ private:
        static const QColor SignalColours[10];
 
 public:
-       LogicSignal(QString name,
-               boost::shared_ptr<pv::data::Logic> data,
-               int probe_index);
+       LogicSignal(pv::SigSession &session,
+               std::shared_ptr<sigrok::Device> device,
+               std::shared_ptr<sigrok::Channel> channel,
+               std::shared_ptr<pv::data::Logic> data);
+
+       virtual ~LogicSignal();
+
+       std::shared_ptr<pv::data::SignalData> data() const;
+
+       std::shared_ptr<pv::data::Logic> logic_data() const;
 
        /**
-        * Paints the signal with a QPainter
+        * Paints the background layer of the signal with a QPainter
         * @param p the QPainter to paint into.
-        * @param y the y-coordinate to draw the signal at.
         * @param left the x-coordinate of the left edge of the signal.
         * @param right the x-coordinate of the right edge of the signal.
-        * @param scale the scale in seconds per pixel.
-        * @param offset the time to show at the left hand edge of
-        *   the view in seconds.
         **/
-       void paint(QPainter &p, int y, int left, int right, double scale,
-               double offset);
+       void paint_back(QPainter &p, int left, int right);
 
-private:
+       /**
+        * Paints the mid-layer of the signal with a QPainter
+        * @param p the QPainter to paint into.
+        * @param left the x-coordinate of the left edge of the signal.
+        * @param right the x-coordinate of the right edge of the signal.
+        **/
+       void paint_mid(QPainter &p, int left, int right);
 
+private:
        void paint_caps(QPainter &p, QLineF *const lines,
                std::vector< std::pair<int64_t, bool> > &edges,
                bool level, double samples_per_pixel, double pixels_offset,
                float x_offset, float y_offset);
 
+       void init_trigger_actions(QWidget *parent);
+
+       QAction* match_action(const sigrok::TriggerMatchType *match);
+       const sigrok::TriggerMatchType *action_match(QAction *action);
+       void populate_popup_form(QWidget *parent, QFormLayout *form);
+       void modify_trigger();
+
+private Q_SLOTS:
+       void on_trigger();
+
 private:
-       int _probe_index;
-       boost::shared_ptr<pv::data::Logic> _data;
+       std::shared_ptr<sigrok::Device> _device;
+       std::shared_ptr<pv::data::Logic> _data;
+
+       const sigrok::TriggerMatchType *_trigger_match;
+       QToolBar *_trigger_bar;
+       QAction *_trigger_none;
+       QAction *_trigger_rising;
+       QAction *_trigger_high;
+       QAction *_trigger_falling;
+       QAction *_trigger_low;
+       QAction *_trigger_change;
 };
 
 } // namespace view
 } // namespace pv
 
-#endif // PULSEVIEW_PV_LOGICSIGNAL_H
+#endif // PULSEVIEW_PV_VIEW_LOGICSIGNAL_H