From 5b7364b0bdbcac133d9b0b34c65bf566ee139347 Mon Sep 17 00:00:00 2001 From: Victor Zarubkin Date: Wed, 27 Jul 2016 22:52:13 +0300 Subject: [PATCH] Flicker functionality for profiler gui on QWidgets --- profiler_gui/blocks_graphics_view.cpp | 58 ++++++++++++++++++++++++++- profiler_gui/blocks_graphics_view.h | 6 ++- 2 files changed, 61 insertions(+), 3 deletions(-) diff --git a/profiler_gui/blocks_graphics_view.cpp b/profiler_gui/blocks_graphics_view.cpp index 0ce7ada..13227f5 100644 --- a/profiler_gui/blocks_graphics_view.cpp +++ b/profiler_gui/blocks_graphics_view.cpp @@ -875,7 +875,13 @@ qreal ProfGraphicsScene::setTree(ProfGraphicsItem* _item, const BlocksTree::chil ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// -ProfGraphicsView::ProfGraphicsView(bool _test) : QGraphicsView(), m_scale(1), m_scaleCoeff(1.25), m_mouseButtons(Qt::NoButton), m_bUpdatingRect(false) +ProfGraphicsView::ProfGraphicsView(bool _test) + : QGraphicsView() + , m_scale(1) + , m_scaleCoeff(1.25) + , m_mouseButtons(Qt::NoButton) + , m_bUpdatingRect(false) + , m_flickerSpeed(0) { initMode(); setScene(new ProfGraphicsScene(this, _test)); @@ -883,7 +889,13 @@ ProfGraphicsView::ProfGraphicsView(bool _test) : QGraphicsView(), m_scale(1), m_ updateVisibleSceneRect(); } -ProfGraphicsView::ProfGraphicsView(const thread_blocks_tree_t& _blocksTree) : QGraphicsView(), m_scale(1), m_scaleCoeff(1.25), m_mouseButtons(Qt::NoButton), m_bUpdatingRect(false) +ProfGraphicsView::ProfGraphicsView(const thread_blocks_tree_t& _blocksTree) + : QGraphicsView() + , m_scale(1) + , m_scaleCoeff(1.25) + , m_mouseButtons(Qt::NoButton) + , m_bUpdatingRect(false) + , m_flickerSpeed(0) { initMode(); setScene(new ProfGraphicsScene(_blocksTree, this)); @@ -956,6 +968,14 @@ void ProfGraphicsView::mouseMoveEvent(QMouseEvent* _event) // because if scrollbar does not emit valueChanged signal then viewport does not move updateVisibleSceneRect(); // Update scene visible rect only once + + // Update flicker speed + m_flickerSpeed += delta.x() >> 1; + if (!m_flickerTimer.isActive()) + { + // If flicker timer is not started, then start it + m_flickerTimer.start(20); + } } //_event->accept(); @@ -974,6 +994,7 @@ void ProfGraphicsView::initMode() connect(horizontalScrollBar(), &QScrollBar::valueChanged, this, &This::onScrollbarValueChange); connect(verticalScrollBar(), &QScrollBar::valueChanged, this, &This::onScrollbarValueChange); + connect(&m_flickerTimer, &QTimer::timeout, this, &This::onFlickerTimeout); } void ProfGraphicsView::updateVisibleSceneRect() @@ -1019,4 +1040,37 @@ void ProfGraphicsView::onScrollbarValueChange(int) updateVisibleSceneRect(); } +void ProfGraphicsView::onFlickerTimeout() +{ + if (m_mouseButtons & Qt::LeftButton) + { + // Fast slow-down and stop if mouse button is pressed, no flicking. + m_flickerSpeed >>= 1; + } + else + { + // Flick when mouse button is not pressed + + auto hbar = horizontalScrollBar(); + + m_bUpdatingRect = true; // Block scrollbars from updating scene rect to make it possible to do it only once + hbar->setValue(hbar->value() - m_flickerSpeed); + m_bUpdatingRect = false; + // Seems like an ugly stub, but QSignalBlocker is also a bad decision + // because if scrollbar does not emit valueChanged signal then viewport does not move + + updateVisibleSceneRect(); // Update scene visible rect only once + + static const auto sign = [](int _value) { return _value < 0 ? -1 : 1; }; + static const auto absmin = [](int _a, int _b) { return abs(_a) < abs(_b) ? _a : _b; }; + m_flickerSpeed -= absmin(3 * sign(m_flickerSpeed), m_flickerSpeed); + } + + if (m_flickerSpeed == 0) + { + // Flicker stopped, no timer needed. + m_flickerTimer.stop(); + } +} + ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// diff --git a/profiler_gui/blocks_graphics_view.h b/profiler_gui/blocks_graphics_view.h index c2543d8..00f0d8e 100644 --- a/profiler_gui/blocks_graphics_view.h +++ b/profiler_gui/blocks_graphics_view.h @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include "profiler/reader.h" @@ -128,7 +129,7 @@ private: typedef ProfGraphicsScene This; - ::profiler::timestamp_t m_beginTime; + ::profiler::timestamp_t m_beginTime; public: @@ -164,11 +165,13 @@ private: typedef ProfGraphicsView This; + QTimer m_flickerTimer; QRectF m_visibleSceneRect; qreal m_scale; qreal m_scaleCoeff; QPoint m_mousePressPos; Qt::MouseButtons m_mouseButtons; + int m_flickerSpeed; bool m_bUpdatingRect; public: @@ -205,6 +208,7 @@ private: private slots: void onScrollbarValueChange(int); + void onFlickerTimeout(); }; // END of class ProfGraphicsView.