Use emplace_back() where possible.
[pulseview.git] / pv / view / cursorpair.hpp
1 /*
2  * This file is part of the PulseView project.
3  *
4  * Copyright (C) 2013 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_TRACEVIEW_CURSORPAIR_HPP
21 #define PULSEVIEW_PV_VIEWS_TRACEVIEW_CURSORPAIR_HPP
22
23 #include "cursor.hpp"
24
25 #include <memory>
26
27 #include <QPainter>
28
29 class QPainter;
30
31 namespace pv {
32 namespace views {
33 namespace TraceView {
34
35 class CursorPair : public TimeItem
36 {
37 private:
38         static const int DeltaPadding;
39         static const QColor ViewportFillColour;
40
41 public:
42         /**
43          * Constructor.
44          * @param view A reference to the view that owns this cursor pair.
45          */
46         CursorPair(View &view);
47
48 public:
49         /**
50          * Returns true if the item is visible and enabled.
51          */
52         bool enabled() const override;
53
54         /**
55          * Returns a pointer to the first cursor.
56          */
57         std::shared_ptr<Cursor> first() const;
58
59         /**
60          * Returns a pointer to the second cursor.
61          */
62         std::shared_ptr<Cursor> second() const;
63
64         /**
65          * Sets the time of the marker.
66          */
67         void set_time(const pv::util::Timestamp& time) override;
68
69         float get_x() const override;
70
71         QPoint point(const QRect &rect) const override;
72
73         pv::widgets::Popup* create_popup(QWidget *parent) override;
74
75 public:
76         QRectF label_rect(const QRectF &rect) const override;
77
78         /**
79          * Paints the marker's label to the ruler.
80          * @param p The painter to draw with.
81          * @param rect The rectangle of the ruler client area.
82          * @param hover true if the label is being hovered over by the mouse.
83          */
84         void paint_label(QPainter &p, const QRect &rect, bool hover) override;
85
86         /**
87          * Paints the background layer of the item with a QPainter
88          * @param p the QPainter to paint into.
89          * @param pp the painting parameters object to paint with.
90          */
91         void paint_back(QPainter &p, const ViewItemPaintParams &pp) override;
92
93         /**
94          * Constructs the string to display.
95          */
96         QString format_string();
97
98         void compute_text_size(QPainter &p);
99
100         std::pair<float, float> get_cursor_offsets() const;
101
102 private:
103         std::shared_ptr<Cursor> first_, second_;
104
105         QSizeF text_size_;
106 };
107
108 } // namespace TraceView
109 } // namespace views
110 } // namespace pv
111
112 #endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_CURSORPAIR_HPP