From 303d6ea697468ee79f4c3f73afc57db0ce6319a8 Mon Sep 17 00:00:00 2001 From: Joel Holdsworth Date: Tue, 13 Oct 2015 22:01:49 -0600 Subject: [PATCH 1/1] LogicSignal: Apply scale handle dragging --- pv/view/logicsignal.cpp | 15 ++++++++------- pv/view/logicsignal.hpp | 4 ++-- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/pv/view/logicsignal.cpp b/pv/view/logicsignal.cpp index 2967147f..717360b8 100644 --- a/pv/view/logicsignal.cpp +++ b/pv/view/logicsignal.cpp @@ -60,8 +60,6 @@ using sigrok::TriggerMatchType; namespace pv { namespace view { -const int LogicSignal::SignalHeight = 30; - const float LogicSignal::Oversampling = 2.0f; const QColor LogicSignal::EdgeColour(0x80, 0x80, 0x80); @@ -103,6 +101,7 @@ LogicSignal::LogicSignal( shared_ptr channel, shared_ptr data) : Signal(session, channel), + signal_height_(QFontMetrics(QApplication::font()).height() * 2), device_(device), data_(data), trigger_none_(nullptr), @@ -149,17 +148,19 @@ std::pair LogicSignal::v_extents() const { const int signal_margin = QFontMetrics(QApplication::font()).height() / 2; - return make_pair(-SignalHeight - signal_margin, signal_margin); + return make_pair(-signal_height_ - signal_margin, signal_margin); } int LogicSignal::scale_handle_offset() const { - return SignalHeight; + return -signal_height_; } void LogicSignal::scale_handle_dragged(int offset) { - (void)offset; + const int font_height = QFontMetrics(QApplication::font()).height(); + const int units = (-offset / font_height); + signal_height_ = ((units < 1) ? 1 : units) * font_height; } void LogicSignal::paint_back(QPainter &p, const ViewItemPaintParams &pp) @@ -183,7 +184,7 @@ void LogicSignal::paint_mid(QPainter &p, const ViewItemPaintParams &pp) if (!channel_->enabled()) return; - const float high_offset = y - SignalHeight + 0.5f; + const float high_offset = y - signal_height_ + 0.5f; const float low_offset = y + 0.5f; const deque< shared_ptr > &segments = @@ -270,7 +271,7 @@ void LogicSignal::paint_fore(QPainter &p, const ViewItemPaintParams &pp) const QSize size = pixmap->size(); const QPoint point( pp.right() - size.width() - pad * 2, - y - (SignalHeight + size.height()) / 2); + y - (signal_height_ + size.height()) / 2); p.setPen(QPen(TriggerMarkerBackgroundColour.darker())); p.setBrush(TriggerMarkerBackgroundColour); diff --git a/pv/view/logicsignal.hpp b/pv/view/logicsignal.hpp index 63d2ec4a..dfc883f5 100644 --- a/pv/view/logicsignal.hpp +++ b/pv/view/logicsignal.hpp @@ -51,8 +51,6 @@ class LogicSignal : public Signal Q_OBJECT private: - static const int SignalHeight; - static const float Oversampling; static const QColor EdgeColour; @@ -140,6 +138,8 @@ private Q_SLOTS: void on_trigger(); private: + int signal_height_; + std::shared_ptr device_; std::shared_ptr data_; -- 2.30.2