X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Ftimemarker.h;h=8d8ae162e909c3738e628477fbdc327b77f59bc0;hb=a55c544b0fefead0786633d6d7c2356002b192ae;hp=616221b23ba139afd1992b9ac7d6acc9332db1d8;hpb=cd6c8ee24fe845fc7d4fcbf8672bb8cdd3afea1a;p=pulseview.git diff --git a/pv/view/timemarker.h b/pv/view/timemarker.h index 616221b..8d8ae16 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. @@ -60,21 +66,41 @@ 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; + + /** + * Returns a list of context menu items to show in the context + * bar. + */ + const std::list get_context_bar_actions(); + +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