]> sigrok.org Git - pulseview.git/blobdiff - pv/view/timemarker.h
Removed context bar
[pulseview.git] / pv / view / timemarker.h
index e8dac5d470792c1234e0708369ff6c69c2f9921d..54b9c248529ff3e4a6c87d3fef5a1f274c626ca2 100644 (file)
 #define PULSEVIEW_PV_VIEW_MARKER_H
 
 #include <QColor>
+#include <QDoubleSpinBox>
 #include <QObject>
 #include <QRectF>
+#include <QWidgetAction>
+
+#include "selectableitem.h"
 
 class QPainter;
 class QRect;
@@ -33,7 +37,7 @@ namespace view {
 
 class View;
 
-class TimeMarker : public QObject
+class TimeMarker : public SelectableItem
 {
        Q_OBJECT
 
@@ -44,12 +48,7 @@ protected:
         * @param colour A reference to the colour of this cursor.
         * @param time The time to set the flag to.
         */
-       TimeMarker(const View &view, const QColor &colour, double time);
-
-       /**
-        * Copy constructor
-        */
-       TimeMarker(const TimeMarker &s);
+       TimeMarker(View &view, const QColor &colour, double time);
 
 public:
        /**
@@ -80,22 +79,31 @@ public:
         * Paints the marker's label to the ruler.
         * @param p The painter to draw with.
         * @param rect The rectangle of the ruler client area.
+        * @param prefix The SI prefix to paint time value with.
         */
-       virtual void paint_label(QPainter &p, const QRect &rect) = 0;
+       virtual void paint_label(QPainter &p, const QRect &rect,
+               unsigned int prefix) = 0;
+
+private slots:
+       void on_value_changed(double value);
 
 signals:
        void time_changed();
 
 protected:
-       const View &_view;
+       View &_view;
        const QColor &_colour;
 
        double _time;
 
        QSizeF _text_size;
+
+       QWidgetAction *_value_action;
+       QDoubleSpinBox *_value_widget;
+       bool _updating_value_widget;
 };
 
 } // namespace view
 } // namespace pv
 
-#endif // PULSEVIEW_PV_VIEW_MARKER_H
\ No newline at end of file
+#endif // PULSEVIEW_PV_VIEW_MARKER_H