X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Ftrace%2Fview.cpp;h=ea1c290c8dccf95774d3e9805b77b4c7b8e656bb;hb=81dc02212c05c99554194a15f9b584e6b500cda9;hp=d2e9006075d698f1af96b9ba8a77aa27df02d96f;hpb=0a952555b9d153f42912e47f35fac5dd4643fca9;p=pulseview.git diff --git a/pv/views/trace/view.cpp b/pv/views/trace/view.cpp index d2e90060..ea1c290c 100644 --- a/pv/views/trace/view.cpp +++ b/pv/views/trace/view.cpp @@ -394,6 +394,11 @@ const Viewport* View::viewport() const return viewport_; } +QAbstractScrollArea* View::scrollarea() const +{ + return scrollarea_; +} + const Ruler* View::ruler() const { return ruler_; @@ -1382,6 +1387,7 @@ void View::determine_time_unit() bool View::eventFilter(QObject *object, QEvent *event) { const QEvent::Type type = event->type(); + if (type == QEvent::MouseMove) { if (object) @@ -1399,6 +1405,15 @@ bool View::eventFilter(QObject *object, QEvent *event) update_hover_point(); + } else if (type == QEvent::MouseButtonPress) { + const QMouseEvent *const mouse_event = (QMouseEvent*)event; + if ((object == viewport_) && (mouse_event->button() & Qt::LeftButton)) { + // Send event to all trace tree items + const vector> trace_tree_items( + list_by_type()); + for (const shared_ptr& r : trace_tree_items) + r->mouse_left_press_event(mouse_event); + } } else if (type == QEvent::Leave) { hover_point_ = QPoint(-1, -1); update_hover_point();