X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fview%2Fview.cpp;h=9c793bb8e635c4443c7b762186f1969df0752886;hb=b42d25c43e52c900cbdd3e5cde0282961b8721e7;hp=b52d689f22c12d988ef3d2f56499bc0b3e9f4629;hpb=149e359e48ede480f3734cfc5c04bd1399d0d4be;p=pulseview.git diff --git a/pv/view/view.cpp b/pv/view/view.cpp index b52d689f..9c793bb8 100644 --- a/pv/view/view.cpp +++ b/pv/view/view.cpp @@ -70,13 +70,13 @@ View::View(SigSession &session, QWidget *parent) : _scale(1e-6), _offset(0), _v_offset(0), + _updating_scroll(false), _show_cursors(false), - _cursors(pair(Cursor(*this, 0.0), - Cursor(*this, 1.0))), + _cursors(*this), _hover_point(-1, -1) { - connect(horizontalScrollBar(), SIGNAL(sliderMoved(int)), - this, SLOT(h_scroll_moved(int))); + connect(horizontalScrollBar(), SIGNAL(valueChanged(int)), + this, SLOT(h_scroll_value_changed(int))); connect(verticalScrollBar(), SIGNAL(valueChanged(int)), this, SLOT(v_scroll_value_changed(int))); @@ -85,9 +85,9 @@ View::View(SigSession &session, QWidget *parent) : connect(&_session, SIGNAL(data_updated()), this, SLOT(data_updated())); - connect(&_cursors.first, SIGNAL(time_changed()), + connect(&_cursors.first(), SIGNAL(time_changed()), this, SLOT(marker_time_changed())); - connect(&_cursors.second, SIGNAL(time_changed()), + connect(&_cursors.second(), SIGNAL(time_changed()), this, SLOT(marker_time_changed())); connect(_header, SIGNAL(signals_moved()), @@ -161,7 +161,7 @@ void View::show_cursors(bool show) _viewport->update(); } -std::pair& View::cursors() +CursorPair& View::cursors() { return _cursors; } @@ -208,7 +208,9 @@ void View::update_scroll() get_scroll_layout(length, offset); length = max(length - areaSize.width(), 0.0); - horizontalScrollBar()->setPageStep(areaSize.width()); + horizontalScrollBar()->setPageStep(areaSize.width() / 2); + + _updating_scroll = true; if (length < MaxScrollValue) { horizontalScrollBar()->setRange(0, length); @@ -219,6 +221,8 @@ void View::update_scroll() _offset * MaxScrollValue / (_scale * length)); } + _updating_scroll = false; + // Set the vertical scrollbar verticalScrollBar()->setPageStep(areaSize.height()); verticalScrollBar()->setRange(0, @@ -288,8 +292,11 @@ void View::resizeEvent(QResizeEvent*) update_scroll(); } -void View::h_scroll_moved(int value) +void View::h_scroll_value_changed(int value) { + if (_updating_scroll) + return; + const int range = horizontalScrollBar()->maximum(); if (range < MaxScrollValue) _offset = _scale * value;