2 * This file is part of the PulseView project.
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
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.
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.
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/>.
20 #ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_DECODETRACE_HPP
21 #define PULSEVIEW_PV_VIEWS_TRACEVIEW_DECODETRACE_HPP
30 #include <QSignalMapper>
32 #include <pv/binding/decoder.hpp>
33 #include <pv/data/decode/row.hpp>
34 #include <pv/data/signalbase.hpp>
39 using std::shared_ptr
;
63 class DecoderGroupBox
;
69 class DecodeTrace
: public Trace
74 struct ChannelSelector
76 const QComboBox
*combo_
;
77 const shared_ptr
<pv::data::decode::Decoder
> decoder_
;
78 const srd_channel
*pdch_
;
82 static const QColor DecodeColours
[4];
83 static const QColor ErrorBgColour
;
84 static const QColor NoDecodeColour
;
86 static const int ArrowSize
;
87 static const double EndCapWidth
;
88 static const int RowTitleMargin
;
89 static const int DrawPadding
;
91 static const QColor Colours
[16];
92 static const QColor OutlineColours
[16];
95 DecodeTrace(pv::Session
&session
, shared_ptr
<data::SignalBase
> signalbase
,
100 const shared_ptr
<pv::data::DecoderStack
>& decoder() const;
102 shared_ptr
<data::SignalBase
> base() const;
105 * Computes the vertical extents of the contents of this row item.
106 * @return A pair containing the minimum and maximum y-values.
108 pair
<int, int> v_extents() const;
111 * Paints the background layer of the trace with a QPainter
112 * @param p the QPainter to paint into.
113 * @param pp the painting parameters object to paint with..
115 void paint_back(QPainter
&p
, ViewItemPaintParams
&pp
);
118 * Paints the mid-layer of the trace with a QPainter
119 * @param p the QPainter to paint into.
120 * @param pp the painting parameters object to paint with.
122 void paint_mid(QPainter
&p
, ViewItemPaintParams
&pp
);
125 * Paints the foreground layer of the trace with a QPainter
126 * @param p the QPainter to paint into.
127 * @param pp the painting parameters object to paint with.
129 void paint_fore(QPainter
&p
, ViewItemPaintParams
&pp
);
131 void populate_popup_form(QWidget
*parent
, QFormLayout
*form
);
133 QMenu
* create_context_menu(QWidget
*parent
);
135 void delete_pressed();
138 void draw_annotations(vector
<pv::data::decode::Annotation
> annotations
,
139 QPainter
&p
, int h
, const ViewItemPaintParams
&pp
, int y
,
140 size_t base_colour
, int row_title_width
);
142 void draw_annotation(const pv::data::decode::Annotation
&a
, QPainter
&p
,
143 int h
, const ViewItemPaintParams
&pp
, int y
,
144 size_t base_colour
, int row_title_width
) const;
146 void draw_annotation_block(vector
<pv::data::decode::Annotation
> annotations
,
147 QPainter
&p
, int h
, int y
, size_t base_colour
) const;
149 void draw_instant(const pv::data::decode::Annotation
&a
, QPainter
&p
,
150 int h
, double x
, int y
) const;
152 void draw_range(const pv::data::decode::Annotation
&a
, QPainter
&p
,
153 int h
, double start
, double end
, int y
, const ViewItemPaintParams
&pp
,
154 int row_title_width
) const;
156 void draw_error(QPainter
&p
, const QString
&message
,
157 const ViewItemPaintParams
&pp
);
159 void draw_unresolved_period(QPainter
&p
, int h
, int left
,
162 pair
<double, double> get_pixels_offset_samples_per_pixel() const;
165 * Determines the start and end sample for a given pixel range.
166 * @param x_start the X coordinate of the start sample in the view
167 * @param x_end the X coordinate of the end sample in the view
168 * @return Returns a pair containing the start sample and the end
169 * sample that correspond to the start and end coordinates.
171 pair
<uint64_t, uint64_t> get_sample_range(int x_start
, int x_end
) const;
173 int get_row_at_point(const QPoint
&point
);
175 const QString
get_annotation_at_point(const QPoint
&point
);
177 void create_decoder_form(int index
,
178 shared_ptr
<pv::data::decode::Decoder
> &dec
,
179 QWidget
*parent
, QFormLayout
*form
);
181 QComboBox
* create_channel_selector(QWidget
*parent
,
182 const shared_ptr
<pv::data::decode::Decoder
> &dec
,
183 const srd_channel
*const pdch
);
185 void commit_decoder_channels(shared_ptr
<data::decode::Decoder
> &dec
);
187 void commit_channels();
190 void hover_point_changed();
193 void on_new_decode_data();
197 void on_channel_selected(int);
199 void on_stack_decoder(srd_decoder
*decoder
);
201 void on_delete_decoder(int index
);
203 void on_show_hide_decoder(int index
);
206 pv::Session
&session_
;
208 vector
<data::decode::Row
> visible_rows_
;
209 uint64_t decode_start_
, decode_end_
;
211 list
< shared_ptr
<pv::binding::Decoder
> > bindings_
;
213 list
<ChannelSelector
> channel_selectors_
;
214 vector
<pv::widgets::DecoderGroupBox
*> decoder_forms_
;
216 map
<data::decode::Row
, int> row_title_widths_
;
217 int row_height_
, max_visible_rows_
;
219 int min_useful_label_width_
;
221 QSignalMapper delete_mapper_
, show_hide_mapper_
;
224 } // namespace TraceView
228 #endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_DECODETRACE_HPP