X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fviewitem.hpp;h=648be84e64384a6fa382a503ee28f0892a480619;hp=7579b555cdc460b36207c1f64fcab7f260eca2a9;hb=cbf0f87e496c9d9157591c94dc445aaa960fe79d;hpb=7708eb92ca87836f5d4987899e0fbb7a4e2335b4 diff --git a/pv/view/viewitem.hpp b/pv/view/viewitem.hpp index 7579b555..648be84e 100644 --- a/pv/view/viewitem.hpp +++ b/pv/view/viewitem.hpp @@ -18,8 +18,8 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PULSEVIEW_PV_VIEWITEM_H -#define PULSEVIEW_PV_VIEWITEM_H +#ifndef PULSEVIEW_PV_VIEWITEM_HPP +#define PULSEVIEW_PV_VIEWITEM_HPP #include @@ -39,6 +39,8 @@ class Popup; namespace view { +class ViewItemOwner; + class ViewItem : public QObject { Q_OBJECT @@ -64,7 +66,7 @@ public: /** * Selects or deselects the signal. */ - void select(bool select = true); + virtual void select(bool select = true); /** * Returns true if the item is being dragged. @@ -79,7 +81,7 @@ public: /** * Sets this item into the un-dragged state. */ - void drag_release(); + virtual void drag_release(); /** * Drags the item to a delta relative to the drag point. @@ -97,8 +99,9 @@ public: * Computes the outline rectangle of a label. * @param rect the rectangle of the header area. * @return Returns the rectangle of the signal label. + * @remarks The default implementation returns an empty rectangle. */ - virtual QRectF label_rect(const QRectF &rect) const = 0; + virtual QRectF label_rect(const QRectF &rect) const; /** * Computes the outline rectangle of the viewport hit-box. @@ -106,7 +109,7 @@ public: * @return Returns the rectangle of the hit-box. * @remarks The default implementation returns an empty hit-box. */ - virtual QRectF hit_box_rect(const QRectF &rect) const; + virtual QRectF hit_box_rect(const ViewItemPaintParams &pp) const; /** * Paints the signal label. @@ -114,7 +117,7 @@ public: * @param rect the rectangle of the header area. * @param hover true if the label is being hovered over by the mouse. */ - virtual void paint_label(QPainter &p, const QRect &rect, bool hover) = 0; + virtual void paint_label(QPainter &p, const QRect &rect, bool hover); /** * Paints the background layer of the item with a QPainter @@ -149,7 +152,7 @@ public: public: virtual QMenu* create_context_menu(QWidget *parent); - virtual pv::widgets::Popup* create_popup(QWidget *parent) = 0; + virtual pv::widgets::Popup* create_popup(QWidget *parent); virtual void delete_pressed(); @@ -167,4 +170,4 @@ private: } // namespace view } // namespace pv -#endif // PULSEVIEW_PV_VIEWITEM_H +#endif // PULSEVIEW_PV_VIEWITEM_HPP