]> sigrok.org Git - pulseview.git/blame_incremental - pv/views/trace/viewport.hpp
TabularDecView: Allow return/enter press and don't change scale
[pulseview.git] / pv / views / trace / viewport.hpp
... / ...
CommitLineData
1/*
2 * This file is part of the PulseView project.
3 *
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
18 */
19
20#ifndef PULSEVIEW_PV_VIEWS_TRACE_VIEWPORT_HPP
21#define PULSEVIEW_PV_VIEWS_TRACE_VIEWPORT_HPP
22
23#include <boost/optional.hpp>
24
25#include <QPoint>
26#include <QTimer>
27#include <QTouchEvent>
28
29#include "pv/util.hpp"
30#include "viewwidget.hpp"
31
32using std::shared_ptr;
33using std::vector;
34
35class QPainter;
36class QPaintEvent;
37class Session;
38
39namespace pv {
40namespace views {
41namespace trace {
42
43class View;
44
45class Viewport : public ViewWidget
46{
47 Q_OBJECT
48
49public:
50 explicit Viewport(View &parent);
51
52 /**
53 * Gets the first view item which has a hit-box that contains @c pt .
54 * @param pt the point to search with.
55 * @return the view item that has been found, or and empty
56 * @c shared_ptr if no item was found.
57 */
58 shared_ptr<ViewItem> get_mouse_over_item(const QPoint &pt);
59
60private:
61 /**
62 * Indicates when a view item is being hovered over.
63 * @param item The item that is being hovered over, or @c nullptr
64 * if no view item is being hovered over.
65 */
66 void item_hover(const shared_ptr<ViewItem> &item, QPoint pos);
67
68 /**
69 * Sets this item into the dragged state.
70 */
71 void drag();
72
73 /**
74 * Drag the background by the delta offset.
75 * @param delta the drag offset in pixels.
76 */
77 void drag_by(const QPoint &delta);
78
79 /**
80 * Sets this item into the un-dragged state.
81 */
82 void drag_release();
83
84 /**
85 * Gets the items in the view widget.
86 */
87 vector< shared_ptr<ViewItem> > items();
88
89 /**
90 * Handles touch begin update and end events.
91 * @param e the event that triggered this handler.
92 */
93 bool touch_event(QTouchEvent *event);
94
95private:
96 void paintEvent(QPaintEvent *event);
97
98 void mouseDoubleClickEvent(QMouseEvent *event);
99 void wheelEvent(QWheelEvent *event);
100
101private:
102 boost::optional<pv::util::Timestamp> drag_offset_;
103 int drag_v_offset_;
104
105 double pinch_offset0_;
106 double pinch_offset1_;
107 bool pinch_zoom_active_;
108};
109
110} // namespace trace
111} // namespace views
112} // namespace pv
113
114#endif // PULSEVIEW_PV_VIEWS_TRACE_VIEWPORT_HPP