X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fviewport.hpp;h=a8062fb650c6e9f8fe11d93c29fd6f4dbb6e3bc7;hp=43905337fefaad1c4b78cc6a71ef432212e15c11;hb=f4e57597347e47a4ea58fbdc7b0a22e07f1c0ede;hpb=c9743553584975b338890c16ef22943d7beaacdd diff --git a/pv/view/viewport.hpp b/pv/view/viewport.hpp index 43905337..a8062fb6 100644 --- a/pv/view/viewport.hpp +++ b/pv/view/viewport.hpp @@ -18,12 +18,15 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PULSEVIEW_PV_VIEW_VIEWPORT_H -#define PULSEVIEW_PV_VIEW_VIEWPORT_H +#ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_VIEWPORT_HPP +#define PULSEVIEW_PV_VIEWS_TRACEVIEW_VIEWPORT_HPP + +#include #include #include +#include "pv/util.hpp" #include "viewwidget.hpp" class QPainter; @@ -31,7 +34,8 @@ class QPaintEvent; class Session; namespace pv { -namespace view { +namespace views { +namespace TraceView { class View; @@ -43,45 +47,65 @@ public: explicit Viewport(View &parent); private: + /** + * Indicates when a view item is being hovered over. + * @param item The item that is being hovered over, or @c nullptr + * if no view item is being hovered over. + */ + void item_hover(const std::shared_ptr &item); + /** * Gets the first view item which has a hit-box 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. */ - std::shared_ptr get_mouse_over_item( - const QPoint &pt); + std::shared_ptr get_mouse_over_item(const QPoint &pt); + + /** + * Sets this item into the dragged state. + */ + void drag(); + + /** + * Drag the background by the delta offset. + * @param delta the drag offset in pixels. + */ + void drag_by(const QPoint &delta); + + /** + * Sets this item into the un-dragged state. + */ + void drag_release(); /** * Gets the items in the view widget. */ - std::vector< std::shared_ptr > items(); + std::vector< std::shared_ptr > items(); /** * Handles touch begin update and end events. * @param e the event that triggered this handler. */ - bool touch_event(QTouchEvent *e); + bool touch_event(QTouchEvent *event); private: void paintEvent(QPaintEvent *event); - void mousePressEvent(QMouseEvent *event); - void mouseReleaseEvent(QMouseEvent *event); - void mouseMoveEvent(QMouseEvent *event); - void mouseDoubleClickEvent(QMouseEvent * event); + void mouseDoubleClickEvent(QMouseEvent *event); void wheelEvent(QWheelEvent *event); + private: - QPoint mouse_down_point_; - double mouse_down_offset_; - bool mouse_down_valid_; + boost::optional drag_offset_; + int drag_v_offset_; double pinch_offset0_; double pinch_offset1_; bool pinch_zoom_active_; }; -} // namespace view +} // namespace TraceView +} // namespace views } // namespace pv -#endif // PULSEVIEW_PV_VIEW_VIEWPORT_H +#endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_VIEWPORT_HPP