X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Ftimemarker.h;h=37e10a3f0e386e14feb688193bed686c99c60e6b;hb=2a2512b21581ea346fea7d96bd3deeb37f1cfed4;hp=616221b23ba139afd1992b9ac7d6acc9332db1d8;hpb=cd6c8ee24fe845fc7d4fcbf8672bb8cdd3afea1a;p=pulseview.git diff --git a/pv/view/timemarker.h b/pv/view/timemarker.h index 616221b..37e10a3 100644 --- a/pv/view/timemarker.h +++ b/pv/view/timemarker.h @@ -22,6 +22,10 @@ #define PULSEVIEW_PV_VIEW_MARKER_H #include +#include +#include + +#include "selectableitem.h" class QPainter; class QRect; @@ -31,8 +35,10 @@ namespace view { class View; -class TimeMarker +class TimeMarker : public SelectableItem { + Q_OBJECT + protected: /** * Constructor. @@ -42,6 +48,11 @@ protected: */ TimeMarker(const View &view, const QColor &colour, double time); + /** + * Copy constructor + */ + TimeMarker(const TimeMarker &s); + public: /** * Gets the time of the marker. @@ -60,21 +71,35 @@ public: */ virtual void paint(QPainter &p, const QRect &rect); + /** + * Gets the marker label rectangle. + * @param rect The rectangle of the ruler client area. + * @return Returns the label rectangle. + */ + virtual QRectF get_label_rect(const QRect &rect) const = 0; + /** * 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; + +signals: + void time_changed(); protected: const View &_view; const QColor &_colour; double _time; + + QSizeF _text_size; }; } // namespace view } // namespace pv -#endif // PULSEVIEW_PV_VIEW_MARKER_H \ No newline at end of file +#endif // PULSEVIEW_PV_VIEW_MARKER_H