]> sigrok.org Git - pulseview.git/blame - pv/view/timemarker.hpp
Signal: Save and load signal names as UTF-8 strings.
[pulseview.git] / pv / view / timemarker.hpp
CommitLineData
cd6c8ee2
JH
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, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
21#ifndef PULSEVIEW_PV_VIEW_MARKER_H
22#define PULSEVIEW_PV_VIEW_MARKER_H
23
24#include <QColor>
1e256e16 25#include <QDoubleSpinBox>
3efda736 26#include <QObject>
ca4ec3ea 27#include <QRectF>
1e256e16 28#include <QWidgetAction>
cd6c8ee2 29
2acdb232 30#include "selectableitem.hpp"
2a2512b2 31
cd6c8ee2
JH
32class QPainter;
33class QRect;
34
35namespace pv {
36namespace view {
37
38class View;
39
2a2512b2 40class TimeMarker : public SelectableItem
cd6c8ee2 41{
3efda736
JH
42 Q_OBJECT
43
cd6c8ee2
JH
44protected:
45 /**
46 * Constructor.
47 * @param view A reference to the view that owns this marker.
48 * @param colour A reference to the colour of this cursor.
49 * @param time The time to set the flag to.
50 */
8debe10d 51 TimeMarker(View &view, const QColor &colour, double time);
cd6c8ee2
JH
52
53public:
54 /**
55 * Gets the time of the marker.
56 */
57 double time() const;
58
59 /**
60 * Sets the time of the marker.
61 */
62 void set_time(double time);
63
509727eb
JH
64 float get_x() const;
65
0dda6fe5
JH
66 /**
67 * Gets the drag point of the row item.
68 */
69 QPoint point() const;
70
cd6c8ee2
JH
71 /**
72 * Paints the marker to the viewport.
73 * @param p The painter to draw with.
74 * @param rect The rectangle of the viewport client area.
75 */
76 virtual void paint(QPainter &p, const QRect &rect);
77
ca4ec3ea
JH
78 /**
79 * Gets the marker label rectangle.
80 * @param rect The rectangle of the ruler client area.
81 * @return Returns the label rectangle.
82 */
83 virtual QRectF get_label_rect(const QRect &rect) const = 0;
84
cd6c8ee2
JH
85 /**
86 * Paints the marker's label to the ruler.
87 * @param p The painter to draw with.
88 * @param rect The rectangle of the ruler client area.
89 */
361c560e 90 virtual void paint_label(QPainter &p, const QRect &rect) = 0;
cd6c8ee2 91
a28a212c
JH
92 pv::widgets::Popup* create_popup(QWidget *parent);
93
e9213170 94private Q_SLOTS:
1e256e16
JH
95 void on_value_changed(double value);
96
e9213170 97Q_SIGNALS:
ca4ec3ea
JH
98 void time_changed();
99
cd6c8ee2 100protected:
8dbbc7f0
JH
101 View &view_;
102 const QColor &colour_;
cd6c8ee2 103
8dbbc7f0 104 double time_;
34c1ef02 105
8dbbc7f0 106 QSizeF text_size_;
1e256e16 107
8dbbc7f0
JH
108 QWidgetAction *value_action_;
109 QDoubleSpinBox *value_widget_;
110 bool updating_value_widget_;
cd6c8ee2
JH
111};
112
113} // namespace view
114} // namespace pv
115
8782a1fd 116#endif // PULSEVIEW_PV_VIEW_MARKER_H