X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Fruler.h;h=ba03f312103fce4c42dfcb518c63ab82c35cade6;hb=a2ae0205f2737dfd8f7647f9eae2fdcb47a0ad25;hp=f855185b904a75209ce521ec12c4399913bd6d5e;hpb=640d091b45b196cc586fbc6a7bec71c5c7d75544;p=pulseview.git diff --git a/pv/view/ruler.h b/pv/view/ruler.h index f855185..ba03f31 100644 --- a/pv/view/ruler.h +++ b/pv/view/ruler.h @@ -21,14 +21,15 @@ #ifndef PULSEVIEW_PV_VIEW_RULER_H #define PULSEVIEW_PV_VIEW_RULER_H -#include +#include "marginwidget.h" namespace pv { namespace view { +class TimeMarker; class View; -class Ruler : public QWidget +class Ruler : public MarginWidget { Q_OBJECT @@ -39,14 +40,34 @@ private: static const QString SIPrefixes[9]; static const int FirstSIPrefixPower; + static const int HoverArrowSize; + public: Ruler(View &parent); + void clear_selection(); + + static QString format_time(double t, unsigned int prefix, + unsigned precision = 0); + 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. + */ + void draw_hover_mark(QPainter &p); + +private slots: + void hover_point_changed(); + private: - View &_view; + TimeMarker *_grabbed_marker; }; } // namespace view