X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Fruler.h;h=c48f25a0bb8a826dbcd8f4234ce805a001115845;hb=f0c9f81c03d2c1d1fa59c357a88d25f6a3128651;hp=1bda06427d253787389d1c87ca59dda26ad9fe71;hpb=b3a7c0136e427d823eec18b14780182740e9de5d;p=pulseview.git diff --git a/pv/view/ruler.h b/pv/view/ruler.h index 1bda064..c48f25a 100644 --- a/pv/view/ruler.h +++ b/pv/view/ruler.h @@ -21,32 +21,42 @@ #ifndef PULSEVIEW_PV_VIEW_RULER_H #define PULSEVIEW_PV_VIEW_RULER_H -#include +#include + +#include "marginwidget.h" namespace pv { 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]; - static const QString SIPrefixes[9]; - static const int FirstSIPrefixPower; - static const int HoverArrowSize; public: Ruler(View &parent); + void clear_selection(); + +public: + QSize sizeHint() const; + private: void paintEvent(QPaintEvent *event); + void mouseMoveEvent(QMouseEvent *e); + void mousePressEvent(QMouseEvent *e); + void mouseReleaseEvent(QMouseEvent *); + private: /** * Draw a hover arrow under the cursor position. @@ -57,7 +67,9 @@ private slots: void hover_point_changed(); private: - View &_view; + boost::weak_ptr _grabbed_marker; + QPoint _mouse_down_point; + bool _dragging; }; } // namespace view