]> sigrok.org Git - pulseview.git/blobdiff - pv/view/view.h
Added pv::view::View::normalize_layout to normalize out-of-bounds drags
[pulseview.git] / pv / view / view.h
index ac2835a49cb4b6157075741d436c6708bd165727..3cd2646e91e8016cbe8543cc3d86717488b5e6f6 100644 (file)
 
 #include <stdint.h>
 
+#include <utility>
+
 #include <QAbstractScrollArea>
+#include <QSizeF>
+
+#include "cursor.h"
 
 namespace pv {
 
@@ -49,6 +54,12 @@ private:
 
 public:
        static const int SignalHeight;
+       static const int SignalMargin;
+       static const int SignalSnapGridSize;
+
+       static const QColor CursorAreaColour;
+
+       static const QSizeF LabelPadding;
 
 public:
        explicit View(SigSession &session, QWidget *parent = 0);
@@ -77,16 +88,37 @@ public:
         */
        void set_scale_offset(double scale, double offset);
 
+       /**
+        * Returns true if cursors are displayed. false otherwise.
+        */
+       bool cursors_shown() const;
+
+       /**
+        * Shows or hides the cursors.
+        */
+       void show_cursors(bool show = true);
+
+       /**
+        * Returns a reference to the pair of cursors.
+        */
+       std::pair<Cursor, Cursor>& cursors();
+
        const QPoint& hover_point() const;
 
+       void normalize_layout();
+
 signals:
        void hover_point_changed();
 
+       void signals_moved();
+
 private:
        void get_scroll_layout(double &length, double &offset) const;
        
        void update_scroll();
 
+       void reset_signal_layout();
+
 private:
        bool eventFilter(QObject *object, QEvent *event);
 
@@ -101,6 +133,10 @@ private slots:
 
        void data_updated();
 
+       void marker_time_changed();
+
+       void on_signals_moved();
+
 private:
        SigSession &_session;
 
@@ -118,6 +154,9 @@ private:
 
        int _v_offset;
 
+       bool _show_cursors;
+       std::pair<Cursor, Cursor> _cursors;
+
        QPoint _hover_point;
 };