]> sigrok.org Git - pulseview.git/blobdiff - pv/view/ruler.h
Rename 'probe' to 'channel' (libsigrokdecode change).
[pulseview.git] / pv / view / ruler.h
index f40f8255379166a06084c82c5c906783fb563346..dc4e7bb73139530cf870dacb5f06010e7c432050 100644 (file)
@@ -21,7 +21,9 @@
 #ifndef PULSEVIEW_PV_VIEW_RULER_H
 #define PULSEVIEW_PV_VIEW_RULER_H
 
-#include <QWidget>
+#include <boost/weak_ptr.hpp>
+
+#include "marginwidget.h"
 
 namespace pv {
 namespace view {
@@ -29,11 +31,12 @@ namespace view {
 class TimeMarker;
 class View;
 
-class Ruler : public QWidget
+class Ruler : public MarginWidget
 {
        Q_OBJECT
 
 private:
+       static const int RulerHeight;
        static const int MinorTickSubdivision;
        static const int ScaleUnits[3];
 
@@ -45,9 +48,14 @@ private:
 public:
        Ruler(View &parent);
 
+       void clear_selection();
+
        static QString format_time(double t, unsigned int prefix,
                unsigned precision = 0);
 
+public:
+       QSize sizeHint() const;
+
 private:
        void paintEvent(QPaintEvent *event);
 
@@ -56,8 +64,6 @@ private:
        void mouseReleaseEvent(QMouseEvent *);
 
 private:
-       void draw_cursors(QPainter &p, unsigned int prefix);
-
        /**
         * Draw a hover arrow under the cursor position.
         */
@@ -67,9 +73,9 @@ private slots:
        void hover_point_changed();
 
 private:
-       View &_view;
-
-       TimeMarker *_grabbed_marker;
+       boost::weak_ptr<TimeMarker> _grabbed_marker;
+       QPoint _mouse_down_point;
+       bool _dragging;
 };
 
 } // namespace view