1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-10-25 01:50:21 -04:00

Change frequency zoom so that frequency under cursor remains the same

This commit is contained in:
Jon Beniston 2022-06-22 18:33:53 +01:00
parent 8b443037d1
commit 4d78fdaa81

View File

@ -3399,6 +3399,21 @@ void GLSpectrum::zoom(QWheelEvent *event)
if ((pwx >= 0.0f) && (pwx <= 1.0f)) if ((pwx >= 0.0f) && (pwx <= 1.0f))
{ {
// When we zoom, we want the frequency under the cursor to remain the same
// Determine frequency at cursor position
float zoomFreq = m_frequencyScale.getRangeMin() + pwx*m_frequencyScale.getRange();
//float zoomFreq2 = ((pwx - 0.5) * m_sampleRate/m_frequencyZoomFactor + ((m_frequencyZoomPos - 0.5)* m_sampleRate + m_centerFrequency));
// Calculate current centre frequency
float currentCF = (m_frequencyZoomFactor == 1) ? m_centerFrequency : ((m_frequencyZoomPos - 0.5) * m_sampleRate + m_centerFrequency);
// Calculate difference from frequency under cursor to centre frequency
float freqDiff = (currentCF - zoomFreq);
// Calculate what that difference would be if there was no zoom
float freqDiffZoom1 = freqDiff * m_frequencyZoomFactor;
if (event->angleDelta().y() > 0) // zoom in if (event->angleDelta().y() > 0) // zoom in
{ {
if (m_frequencyZoomFactor < m_maxFrequencyZoom) { if (m_frequencyZoomFactor < m_maxFrequencyZoom) {
@ -3416,7 +3431,17 @@ void GLSpectrum::zoom(QWheelEvent *event)
} }
} }
frequencyZoom(pwx); // Calculate what frequency difference should be at new zoom
float zoomedFreqDiff = freqDiffZoom1 / m_frequencyZoomFactor;
// Then calculate what the center frequency should be
float zoomedCF = zoomFreq + zoomedFreqDiff;
// Calculate zoom position which will set the desired center frequency
float zoomPos = (zoomedCF - m_centerFrequency) / m_sampleRate + 0.5;
zoomPos = std::max(0.0f, zoomPos);
zoomPos = std::min(1.0f, zoomPos);
frequencyZoom(zoomPos);
} }
else else
{ {
@ -3445,13 +3470,9 @@ void GLSpectrum::zoom(QWheelEvent *event)
} }
} }
void GLSpectrum::frequencyZoom(float pw) void GLSpectrum::frequencyZoom(float zoomPos)
{ {
m_frequencyZoomPos += (pw - 0.5f) * (1.0f / m_frequencyZoomFactor); m_frequencyZoomPos = zoomPos;
float lim = 0.5f / m_frequencyZoomFactor;
m_frequencyZoomPos = m_frequencyZoomPos < lim ? lim : m_frequencyZoomPos > 1 - lim ? 1 - lim : m_frequencyZoomPos;
qDebug("GLSpectrum::frequencyZoom: pw: %f p: %f z: %f", pw, m_frequencyZoomPos, m_frequencyZoomFactor);
updateFFTLimits(); updateFFTLimits();
} }