]> sigrok.org Git - pulseview.git/blame_incremental - pv/views/trace/viewport.hpp
Session: Fix issue #67 by improving error handling
[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/globalsettings.hpp>
30
31#include "pv/util.hpp"
32#include "viewwidget.hpp"
33
34using std::shared_ptr;
35using std::vector;
36
37class QPainter;
38class QPaintEvent;
39class Session;
40
41namespace pv {
42namespace views {
43namespace trace {
44
45class View;
46
47class Viewport : public ViewWidget, public GlobalSettingsInterface
48{
49 Q_OBJECT
50
51public:
52 explicit Viewport(View &parent);
53 ~Viewport();
54
55 /**
56 * Gets the first view item which has a hit-box that contains @c pt .
57 * @param pt the point to search with.
58 * @return the view item that has been found, or and empty
59 * @c shared_ptr if no item was found.
60 */
61 shared_ptr<ViewItem> get_mouse_over_item(const QPoint &pt);
62
63private:
64 /**
65 * Indicates when a view item is being hovered over.
66 * @param item The item that is being hovered over, or @c nullptr
67 * if no view item is being hovered over.
68 */
69 void item_hover(const shared_ptr<ViewItem> &item, QPoint pos);
70
71 /**
72 * Sets this item into the dragged state.
73 */
74 void drag();
75
76 /**
77 * Drag the background by the delta offset.
78 * @param delta the drag offset in pixels.
79 */
80 void drag_by(const QPoint &delta);
81
82 /**
83 * Sets this item into the un-dragged state.
84 */
85 void drag_release();
86
87 /**
88 * Gets the items in the view widget.
89 */
90 vector< shared_ptr<ViewItem> > items();
91
92 /**
93 * Handles touch begin update and end events.
94 * @param e the event that triggered this handler.
95 */
96 bool touch_event(QTouchEvent *event);
97
98 void paintEvent(QPaintEvent *event);
99
100 void mouseDoubleClickEvent(QMouseEvent *event);
101
102 void wheelEvent(QWheelEvent *event);
103
104 void on_setting_changed(const QString &key, const QVariant &value);
105
106private:
107 boost::optional<pv::util::Timestamp> drag_offset_;
108 int drag_v_offset_;
109 bool allow_vertical_dragging_;
110
111 double pinch_offset0_;
112 double pinch_offset1_;
113 bool pinch_zoom_active_;
114};
115
116} // namespace trace
117} // namespace views
118} // namespace pv
119
120#endif // PULSEVIEW_PV_VIEWS_TRACE_VIEWPORT_HPP