]> sigrok.org Git - pulseview.git/blob - pv/view/decode/annotation.cpp
Initial decode painting
[pulseview.git] / pv / view / decode / annotation.cpp
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 extern "C" {
22 #include <libsigrokdecode/libsigrokdecode.h>
23 }
24
25 #include <QPainter>
26
27 #include "annotation.h"
28
29 using namespace boost;
30 using namespace std;
31
32 namespace pv {
33 namespace view {
34 namespace decode {
35
36 Annotation::Annotation(const srd_proto_data *const pdata) :
37         _start_sample(pdata->start_sample),
38         _end_sample(pdata->end_sample)
39 {
40         const char *const *annotations = (char**)pdata->data;
41         while(*annotations) {
42                 _annotations.push_back(QString(*annotations));
43                 annotations++;
44         }
45 }
46
47 void Annotation::paint(QPainter &p, int left, int right,
48         double samples_per_pixel, double pixels_offset, int y)
49 {
50         const int AnnotationHeight = 40;
51
52         const double start = _start_sample / samples_per_pixel -
53                 pixels_offset;
54         const double end = _end_sample / samples_per_pixel -
55                 pixels_offset;
56
57         if (start > right)
58                 return;
59         if (end < left)
60                 return;
61
62         QRectF rect(start, y - AnnotationHeight/2,
63                 end - start, AnnotationHeight);
64
65         p.setPen(Qt::black);
66         p.fillRect(rect, QBrush(Qt::red));
67         p.drawRect(rect);
68
69         if(!_annotations.empty())
70                 p.drawText(rect, Qt::AlignCenter, _annotations.front());
71 }
72
73 } // namespace decode
74 } // namespace view
75 } // namespace pv