From 47a483039f49484d564a7f1f9beacdb23ce463d7 Mon Sep 17 00:00:00 2001 From: ronso0 Date: Wed, 15 Jun 2022 01:29:07 +0200 Subject: [PATCH] Waveform: avoid QPaitner glitch with ranges < 1 px --- src/waveform/renderers/waveformrendermarkrange.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/waveform/renderers/waveformrendermarkrange.cpp b/src/waveform/renderers/waveformrendermarkrange.cpp index a6761c5f6e6..bf5e5da4fdc 100644 --- a/src/waveform/renderers/waveformrendermarkrange.cpp +++ b/src/waveform/renderers/waveformrendermarkrange.cpp @@ -64,6 +64,10 @@ void WaveformRenderMarkRange::draw(QPainter *painter, QPaintEvent * /*event*/) { double startPosition = m_waveformRenderer->transformSamplePositionInRendererWorld(startSample); double endPosition = m_waveformRenderer->transformSamplePositionInRendererWorld(endSample); + // The painter would extend the rectangle to the entire width while + // span is < 1 AND span != 0.25 * [1;3], i.e. works with span = [.25; 0.75] px + // TODO(xxx) Figure what's wrong with QPainter / the renderer + const double span = std::max(endPosition - startPosition, 1.0); //range not in the current display if (startPosition > m_waveformRenderer->getLength() || endPosition < 0) { @@ -78,9 +82,9 @@ void WaveformRenderMarkRange::draw(QPainter *painter, QPaintEvent * /*event*/) { // this shouldn't involve *any* scaling it should be fast even in software mode QRectF rect; if (m_waveformRenderer->getOrientation() == Qt::Horizontal) { - rect.setRect(startPosition, 0, endPosition - startPosition, m_waveformRenderer->getHeight()); + rect.setRect(startPosition, 0, span, m_waveformRenderer->getHeight()); } else { - rect.setRect(0, startPosition, m_waveformRenderer->getWidth(), endPosition - startPosition); + rect.setRect(0, startPosition, m_waveformRenderer->getWidth(), span); } painter->drawImage(rect, *selectedImage, rect); }