X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fview%2Fcursorpair.hpp;h=fc9f0d1ba6f4a4edc718e869bfe61dd381588641;hb=e456e8e1a8514e2f53c99b63ca92e3612c2058ea;hp=84737d21693ffc048e13db86f0abddb8c83f404f;hpb=361c560ed9ef67278916e086ed0b0649ae01b583;p=pulseview.git diff --git a/pv/view/cursorpair.hpp b/pv/view/cursorpair.hpp index 84737d2..fc9f0d1 100644 --- a/pv/view/cursorpair.hpp +++ b/pv/view/cursorpair.hpp @@ -32,7 +32,7 @@ class QPainter; namespace pv { namespace view { -class CursorPair +class CursorPair : public TimeItem { private: static const int DeltaPadding; @@ -44,6 +44,12 @@ public: */ CursorPair(View &view); +public: + /** + * Returns true if the item is visible and enabled. + */ + bool enabled() const; + /** * Returns a pointer to the first cursor. */ @@ -54,14 +60,34 @@ public: */ std::shared_ptr second() const; -public: - QRectF get_label_rect(const QRect &rect) const; + /** + * Sets the time of the marker. + */ + void set_time(double time); - void draw_markers(QPainter &p, const QRect &rect); + float get_x() const; - void draw_viewport_background(QPainter &p, const QRect &rect); + QPoint point() const; - void draw_viewport_foreground(QPainter &p, const QRect &rect); + pv::widgets::Popup* create_popup(QWidget *parent); + +public: + QRectF label_rect(const QRectF &rect) const; + + /** + * 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 hover true if the label is being hovered over by the mouse. + */ + void paint_label(QPainter &p, const QRect &rect, bool hover); + + /** + * Paints the background layer of the item with a QPainter + * @param p the QPainter to paint into. + * @param pp the painting parameters object to paint with. + **/ + void paint_back(QPainter &p, const ViewItemPaintParams &pp); void compute_text_size(QPainter &p, unsigned int prefix); @@ -69,7 +95,6 @@ public: private: std::shared_ptr first_, second_; - const View &view_; QSizeF text_size_; };