X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fcursorpair.cpp;h=2ff32c53ef9fbbe4d46b2d1d8fb22425ee03626f;hp=12b7bc341160b90f391b2c8d3df3056e3696a67f;hb=2fae5107535c39adde322393d2f6d18098c0154e;hpb=4fabd61a2676246265c12d614cde496bf0a79075 diff --git a/pv/view/cursorpair.cpp b/pv/view/cursorpair.cpp index 12b7bc34..2ff32c53 100644 --- a/pv/view/cursorpair.cpp +++ b/pv/view/cursorpair.cpp @@ -38,12 +38,17 @@ namespace view { const int CursorPair::DeltaPadding = 8; CursorPair::CursorPair(View &view) : + TimeItem(view), first_(new Cursor(view, 0.0)), - second_(new Cursor(view, 1.0)), - view_(view) + second_(new Cursor(view, 1.0)) { } +bool CursorPair::enabled() const +{ + return view_.cursors_shown(); +} + shared_ptr CursorPair::first() const { return first_; @@ -54,7 +59,29 @@ shared_ptr CursorPair::second() const return second_; } -QRectF CursorPair::get_label_rect(const QRect &rect) const +void CursorPair::set_time(double time) { + const double delta = second_->time() - first_->time(); + first_->set_time(time); + second_->set_time(time + delta); +} + +float CursorPair::get_x() const +{ + return (first_->get_x() + second_->get_x()) / 2.0f; +} + +QPoint CursorPair::point() const +{ + return first_->point(); +} + +pv::widgets::Popup* CursorPair::create_popup(QWidget *parent) +{ + (void)parent; + return nullptr; +} + +QRectF CursorPair::label_rect(const QRectF &rect) const { const QSizeF label_size( text_size_.width() + View::LabelPadding.width() * 2, @@ -74,7 +101,7 @@ QRectF CursorPair::get_label_rect(const QRect &rect) const right - left, height); } -void CursorPair::draw_markers(QPainter &p, const QRect &rect) +void CursorPair::paint_label(QPainter &p, const QRect &rect) { assert(first_); assert(second_); @@ -82,7 +109,7 @@ void CursorPair::draw_markers(QPainter &p, const QRect &rect) const unsigned int prefix = view_.tick_prefix(); compute_text_size(p, prefix); - QRectF delta_rect(get_label_rect(rect)); + QRectF delta_rect(label_rect(rect)); const int radius = delta_rect.height() / 2; const QRectF text_rect(delta_rect.intersected( @@ -91,6 +118,12 @@ void CursorPair::draw_markers(QPainter &p, const QRect &rect) { const int highlight_radius = delta_rect.height() / 2 - 2; + if (selected()) { + p.setBrush(Qt::transparent); + p.setPen(highlight_pen()); + p.drawRoundedRect(delta_rect, radius, radius); + } + p.setBrush(Cursor::FillColour); p.setPen(Cursor::FillColour.darker()); p.drawRoundedRect(delta_rect, radius, radius);