]> sigrok.org Git - pulseview.git/blobdiff - pv/view/viewitem.hpp
ViewWidget: Added mouse_down
[pulseview.git] / pv / view / viewitem.hpp
index 12e1f44fc7659ac538ea6d8725ca60fcc3b4b116..7579b555cdc460b36207c1f64fcab7f260eca2a9 100644 (file)
@@ -44,6 +44,7 @@ class ViewItem : public QObject
        Q_OBJECT
 
 public:
+       static const QSizeF LabelPadding;
        static const int HighlightRadius;
 
 public:
@@ -70,11 +71,6 @@ public:
         */
        bool dragging() const;
 
-       /**
-        * Retunrns the current drag point.
-        */
-       QPoint drag_point() const;
-
        /**
         * Sets this item into the dragged state.
         */
@@ -85,10 +81,17 @@ public:
         */
        void drag_release();
 
+       /**
+        * Drags the item to a delta relative to the drag point.
+        * @param delta the offset from the drag point.
+        */
+       virtual void drag_by(const QPoint &delta) = 0;
+
        /**
         * Get the drag point.
+        * @param rect the rectangle of the widget area.
         */
-       virtual QPoint point() const = 0;
+       virtual QPoint point(const QRect &rect) const = 0;
 
        /**
         * Computes the outline rectangle of a label.
@@ -97,6 +100,22 @@ public:
         */
        virtual QRectF label_rect(const QRectF &rect) const = 0;
 
+       /**
+        * Computes the outline rectangle of the viewport hit-box.
+        * @param rect the rectangle of the viewport area.
+        * @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;
+
+       /**
+        * Paints the signal label.
+        * @param p the QPainter to paint into.
+        * @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;
+
        /**
         * Paints the background layer of the item with a QPainter
         * @param p the QPainter to paint into.
@@ -139,10 +158,10 @@ protected:
 
 protected:
        QWidget *context_parent_;
+       QPoint drag_point_;
 
 private:
        bool selected_;
-       QPoint drag_point_;
 };
 
 } // namespace view