]> sigrok.org Git - pulseview.git/blobdiff - pv/view/marginwidget.hpp
Added ViewWidget as a common ancestor of all view widgets
[pulseview.git] / pv / view / marginwidget.hpp
index 7df6c02d3fbebbcdf8ca5db4222e5a53c41e9713..308d9348d12a0341aa6a203cd1b214a8c74839cf 100644 (file)
 #include <memory>
 
 #include <QPoint>
-#include <QWidget>
+
+#include "viewwidget.hpp"
 
 namespace pv {
 namespace view {
 
-class View;
 class ViewItem;
 
-class MarginWidget : public QWidget
+class MarginWidget : public ViewWidget
 {
        Q_OBJECT
 
@@ -67,11 +67,41 @@ protected:
         */
        void show_popup(const std::shared_ptr<ViewItem> &item);
 
-private:
+       /**
+        * Returns true if the selection of row items allows dragging.
+        * @return Returns true if the drag is acceptable.
+        */
+       virtual bool accept_drag() const = 0;
+
+       /**
+        * Drag the dragging items by the delta offset.
+        * @param delta the drag offset in pixels.
+        */
+       virtual void drag_items(const QPoint &delta) = 0;
+
+       /**
+        * Handles left mouse button press events.
+        * @param event the mouse event that triggered this handler.
+        */
+       void mouse_left_press_event(QMouseEvent *event);
+
+       /**
+        * Handles left mouse button release events.
+        * @param event the mouse event that triggered this handler.
+        */
+       void mouse_left_release_event(QMouseEvent *event);
+
+protected:
+       void mousePressEvent(QMouseEvent * event);
+       void mouseReleaseEvent(QMouseEvent *event);
+       void mouseMoveEvent(QMouseEvent *event);
+
        void leaveEvent(QEvent *event);
 
        virtual void contextMenuEvent(QContextMenuEvent *event);
 
+       virtual void keyPressEvent(QKeyEvent *e);
+
 public Q_SLOTS:
        void clear_selection();
 
@@ -79,7 +109,6 @@ Q_SIGNALS:
        void selection_changed();
 
 protected:
-       pv::view::View &view_;
        QPoint mouse_point_;
        QPoint mouse_down_point_;
        std::shared_ptr<ViewItem> mouse_down_item_;