X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=pv%2Fview%2Fdecode%2Fannotation.cpp;h=4ad04f23caf34b155d0f938e18bc7d338de73e16;hb=bb4c67698d836703257e9559d1a98cb3819c61a5;hp=741569b2e055f18ed5948ed738c3981dac56eeab;hpb=9472f4476b27336e9187635015169e308bfe8af7;p=pulseview.git diff --git a/pv/view/decode/annotation.cpp b/pv/view/decode/annotation.cpp index 741569b2..4ad04f23 100644 --- a/pv/view/decode/annotation.cpp +++ b/pv/view/decode/annotation.cpp @@ -22,6 +22,10 @@ extern "C" { #include } +#include + +#include + #include #include "annotation.h" @@ -33,6 +37,8 @@ namespace pv { namespace view { namespace decode { +const double Annotation::EndCapWidth = 5; + Annotation::Annotation(const srd_proto_data *const pdata) : _start_sample(pdata->start_sample), _end_sample(pdata->end_sample) @@ -44,30 +50,58 @@ Annotation::Annotation(const srd_proto_data *const pdata) : } } -void Annotation::paint(QPainter &p, int left, int right, +void Annotation::paint(QPainter &p, QColor fill, QColor outline, + QColor text_color, int text_height, int left, int right, double samples_per_pixel, double pixels_offset, int y) { - const int AnnotationHeight = 40; + const int h = (text_height * 3) / 2; const double start = _start_sample / samples_per_pixel - pixels_offset; const double end = _end_sample / samples_per_pixel - pixels_offset; - if (start > right) + if (start > right || end < left) return; - if (end < left) + + const double cap_width = min((end - start) / 2, EndCapWidth); + + QPointF pts[] = { + QPointF(start, y + .5f), + QPointF(start + cap_width, y + .5f - h / 2), + QPointF(end - cap_width, y + .5f - h / 2), + QPointF(end, y + .5f), + QPointF(end - cap_width, y + .5f + h / 2), + QPointF(start + cap_width, y + .5f + h / 2) + }; + + p.setPen(outline); + p.setBrush(fill); + p.drawConvexPolygon(pts, countof(pts)); + + if (_annotations.empty()) return; - QRectF rect(start, y - AnnotationHeight/2, - end - start, AnnotationHeight); + QRectF rect(start + cap_width, y - h / 2, + end - start - cap_width * 2, h); + p.setPen(text_color); + + // Try to find an annotation that will fit + QString best_annotation; + int best_width = 0; + + BOOST_FOREACH(QString &a, _annotations) { + const int w = p.boundingRect(QRectF(), 0, a).width(); + if (w <= rect.width() && w > best_width) + best_annotation = a, best_width = w; + } - p.setPen(Qt::black); - p.fillRect(rect, QBrush(Qt::red)); - p.drawRect(rect); + if (best_annotation.isEmpty()) + best_annotation = _annotations.back(); - if(!_annotations.empty()) - p.drawText(rect, Qt::AlignCenter, _annotations.front()); + // If not ellide the last in the list + p.drawText(rect, Qt::AlignCenter, p.fontMetrics().elidedText( + best_annotation, Qt::ElideRight, rect.width())); } } // namespace decode