From 8a1df1d71266b6bd3775d1432d65d5f405cf0f1b Mon Sep 17 00:00:00 2001 From: Ryzerth Date: Tue, 29 Jun 2021 03:32:40 +0200 Subject: [PATCH] Fixed SNR not updating when waterfall is hidden --- core/src/gui/widgets/waterfall.cpp | 10 ++++------ core/src/gui/widgets/waterfall.h | 2 +- 2 files changed, 5 insertions(+), 7 deletions(-) diff --git a/core/src/gui/widgets/waterfall.cpp b/core/src/gui/widgets/waterfall.cpp index e9c73520..7df4e184 100644 --- a/core/src/gui/widgets/waterfall.cpp +++ b/core/src/gui/widgets/waterfall.cpp @@ -431,7 +431,7 @@ namespace ImGui { ImGui::Text("Bandwidth Locked: %s", _vfo->bandwidthLocked ? "Yes" : "No"); float strength, snr; - if (calculateVFOSignalInfo(_vfo, strength, snr)) { + if (calculateVFOSignalInfo(waterfallVisible ? &rawFFTs[currentFFTLine * rawFFTSize] : rawFFTs, _vfo, strength, snr)) { ImGui::Text("Strength: %0.1fdBFS", strength); ImGui::Text("SNR: %0.1fdB", snr); } @@ -448,8 +448,8 @@ namespace ImGui { } } - bool WaterFall::calculateVFOSignalInfo(WaterfallVFO* _vfo, float& strength, float& snr) { - if (rawFFTs == NULL || fftLines <= 0) { return false; } + bool WaterFall::calculateVFOSignalInfo(float* fftLine, WaterfallVFO* _vfo, float& strength, float& snr) { + if (fftLine == NULL || fftLines <= 0) { return false; } // Calculate FFT index data double vfoMinSizeFreq = _vfo->centerOffset - _vfo->bandwidth; @@ -461,8 +461,6 @@ namespace ImGui { int vfoMaxOffset = std::clamp(((vfoMaxFreq / (wholeBandwidth/2.0)) * (double)(rawFFTSize/2)) + (rawFFTSize/2), 0, rawFFTSize); int vfoMaxSideOffset = std::clamp(((vfoMaxSizeFreq / (wholeBandwidth/2.0)) * (double)(rawFFTSize/2)) + (rawFFTSize/2), 0, rawFFTSize); - float* fftLine = &rawFFTs[currentFFTLine * rawFFTSize]; - double avg = 0; float max = -INFINITY; int avgCount = 0; @@ -804,7 +802,7 @@ namespace ImGui { if (selectedVFO != "" && vfos.size() > 0) { float dummy; - calculateVFOSignalInfo(vfos[selectedVFO], dummy, selectedVFOSNR); + calculateVFOSignalInfo(waterfallVisible ? &rawFFTs[currentFFTLine * rawFFTSize] : rawFFTs, vfos[selectedVFO], dummy, selectedVFOSNR); } buf_mtx.unlock(); diff --git a/core/src/gui/widgets/waterfall.h b/core/src/gui/widgets/waterfall.h index 61a92431..ba73940b 100644 --- a/core/src/gui/widgets/waterfall.h +++ b/core/src/gui/widgets/waterfall.h @@ -165,7 +165,7 @@ namespace ImGui { void updateWaterfallFb(); void updateWaterfallTexture(); void updateAllVFOs(bool checkRedrawRequired = false); - bool calculateVFOSignalInfo(WaterfallVFO* vfo, float& strength, float& snr); + bool calculateVFOSignalInfo(float* fftLine, WaterfallVFO* vfo, float& strength, float& snr); bool waterfallUpdate = false;