X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fmarginwidget.hpp;h=1194696548e4cd57def831bb05e59efb69daeabf;hp=b4f0eb72c45e84abc4703a5b3e46f8031aca7e0a;hb=bb4a0e8e0b337988264e43a368b6ce5950d2d6cd;hpb=f4433aa958fb9c85ce82ef5545d722625cb64f9e diff --git a/pv/view/marginwidget.hpp b/pv/view/marginwidget.hpp index b4f0eb72..11946965 100644 --- a/pv/view/marginwidget.hpp +++ b/pv/view/marginwidget.hpp @@ -21,6 +21,8 @@ #ifndef PULSEVIEW_PV_MARGINWIDGET_H #define PULSEVIEW_PV_MARGINWIDGET_H +#include + #include #include @@ -28,6 +30,7 @@ namespace pv { namespace view { class View; +class ViewItem; class MarginWidget : public QWidget { @@ -36,8 +39,51 @@ class MarginWidget : public QWidget public: MarginWidget(pv::view::View &parent); + /** + * The extended area that the margin widget would like to be sized to. + * @remarks This area is the area specified by sizeHint, extended by + * the area to overlap the viewport. + */ + virtual QSize extended_size_hint() const = 0; + +protected: + /** + * Gets the items in the margin widget. + */ + virtual std::vector< std::shared_ptr > items() = 0; + + /** + * Gets the first view item which has a label that contains @c pt . + * @param pt the point to search with. + * @return the view item that has been found, or and empty + * @c shared_ptr if no item was found. + */ + virtual std::shared_ptr get_mouse_over_item( + const QPoint &pt) = 0; + + /** + * Shows the popup of a the specified @c ViewItem . + * @param item The item to show the popup for. + */ + void show_popup(const std::shared_ptr &item); + + /** + * Handles left mouse button press events. + * @param event the mouse event that triggered this handler. + */ + void mouse_left_press_event(QMouseEvent *event); + +protected: + void mousePressEvent(QMouseEvent * event); + + void leaveEvent(QEvent *event); + + virtual void contextMenuEvent(QContextMenuEvent *event); + + virtual void keyPressEvent(QKeyEvent *e); + public Q_SLOTS: - virtual void clear_selection(); + void clear_selection(); Q_SIGNALS: void selection_changed(); @@ -46,6 +92,7 @@ protected: pv::view::View &view_; QPoint mouse_point_; QPoint mouse_down_point_; + std::shared_ptr mouse_down_item_; bool dragging_; };