mirror of
https://github.com/AlexandreRouma/SDRPlusPlus.git
synced 2025-01-12 19:27:11 +01:00
Potential fix for windows 7 not detecting the home key and the radio not saving the bandwidth when set through the frequency manager
This commit is contained in:
parent
85eb08e422
commit
f16c296f38
@ -82,8 +82,9 @@ namespace displaymenu {
|
|||||||
|
|
||||||
void draw(void* ctx) {
|
void draw(void* ctx) {
|
||||||
float menuWidth = ImGui::GetContentRegionAvailWidth();
|
float menuWidth = ImGui::GetContentRegionAvailWidth();
|
||||||
if (ImGui::Checkbox("Show Waterfall##_sdrpp", &showWaterfall) || ImGui::IsKeyPressed(GLFW_KEY_HOME, false)) {
|
bool homePressed = ImGui::IsKeyPressed(GLFW_KEY_HOME, false);
|
||||||
if (ImGui::IsKeyPressed(GLFW_KEY_HOME, false)) { showWaterfall = !showWaterfall; }
|
if (ImGui::Checkbox("Show Waterfall##_sdrpp", &showWaterfall) || homePressed) {
|
||||||
|
if (homePressed) { showWaterfall = !showWaterfall; }
|
||||||
showWaterfall ? gui::waterfall.showWaterfall() : gui::waterfall.hideWaterfall();
|
showWaterfall ? gui::waterfall.showWaterfall() : gui::waterfall.hideWaterfall();
|
||||||
core::configManager.acquire();
|
core::configManager.acquire();
|
||||||
core::configManager.conf["showWaterfall"] = showWaterfall;
|
core::configManager.conf["showWaterfall"] = showWaterfall;
|
||||||
|
@ -389,8 +389,9 @@ namespace ImGui {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// If the left and right keys are pressed while hovering the freq scale, move it too
|
// If the left and right keys are pressed while hovering the freq scale, move it too
|
||||||
if ((ImGui::IsKeyPressed(GLFW_KEY_LEFT) || ImGui::IsKeyPressed(GLFW_KEY_RIGHT)) && mouseInFreq) {
|
bool leftKeyPressed = ImGui::IsKeyPressed(GLFW_KEY_LEFT);
|
||||||
viewOffset += ImGui::IsKeyPressed(GLFW_KEY_LEFT) ? (viewBandwidth / 20.0) : (-viewBandwidth / 20.0);
|
if ((leftKeyPressed || ImGui::IsKeyPressed(GLFW_KEY_RIGHT)) && mouseInFreq) {
|
||||||
|
viewOffset += leftKeyPressed ? (viewBandwidth / 20.0) : (-viewBandwidth / 20.0);
|
||||||
|
|
||||||
if (viewOffset + (viewBandwidth / 2.0) > wholeBandwidth / 2.0) {
|
if (viewOffset + (viewBandwidth / 2.0) > wholeBandwidth / 2.0) {
|
||||||
double freqOffset = (viewOffset + (viewBandwidth / 2.0)) - (wholeBandwidth / 2.0);
|
double freqOffset = (viewOffset + (viewBandwidth / 2.0)) - (wholeBandwidth / 2.0);
|
||||||
|
@ -173,6 +173,14 @@ public:
|
|||||||
resamp.updateWindow(&win);
|
resamp.updateWindow(&win);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -176,6 +176,14 @@ public:
|
|||||||
resamp.updateWindow(&win);
|
resamp.updateWindow(&win);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -168,6 +168,14 @@ public:
|
|||||||
_vfo->setBandwidth(bw, updateWaterfall);
|
_vfo->setBandwidth(bw, updateWaterfall);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -162,6 +162,14 @@ public:
|
|||||||
setAudioSampleRate(audioSampRate);
|
setAudioSampleRate(audioSampRate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -173,6 +173,14 @@ public:
|
|||||||
resamp.updateWindow(&win);
|
resamp.updateWindow(&win);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -179,6 +179,7 @@ private:
|
|||||||
else if (code == RADIO_IFACE_CMD_SET_BANDWIDTH) {
|
else if (code == RADIO_IFACE_CMD_SET_BANDWIDTH) {
|
||||||
float* _in = (float*)in;
|
float* _in = (float*)in;
|
||||||
_this->currentDemod->setBandwidth(*_in, true);
|
_this->currentDemod->setBandwidth(*_in, true);
|
||||||
|
_this->currentDemod->saveParameters();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,4 +15,5 @@ public:
|
|||||||
virtual void setBandwidth(float bandWidth, bool updateWaterfall = true) = 0;
|
virtual void setBandwidth(float bandWidth, bool updateWaterfall = true) = 0;
|
||||||
virtual dsp::stream<dsp::stereo_t>* getOutput() = 0;
|
virtual dsp::stream<dsp::stereo_t>* getOutput() = 0;
|
||||||
virtual void showMenu() = 0;
|
virtual void showMenu() = 0;
|
||||||
|
virtual void saveParameters(bool lock = true) = 0;
|
||||||
};
|
};
|
@ -118,6 +118,13 @@ public:
|
|||||||
// Do nothing
|
// Do nothing
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -173,6 +173,14 @@ public:
|
|||||||
resamp.updateWindow(&win);
|
resamp.updateWindow(&win);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setSnapInterval(float snapInt) {
|
void setSnapInterval(float snapInt) {
|
||||||
snapInterval = snapInt;
|
snapInterval = snapInt;
|
||||||
|
@ -246,6 +246,16 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void saveParameters(bool lock = true) {
|
||||||
|
if (lock) { _config->acquire(); }
|
||||||
|
_config->conf[uiPrefix]["WFM"]["bandwidth"] = bw;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["snapInterval"] = snapInterval;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["deempMode"] = deempId;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["squelchLevel"] = squelchLevel;
|
||||||
|
_config->conf[uiPrefix]["WFM"]["stereo"] = stereo;
|
||||||
|
if (lock) { _config->release(true); }
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
const float bwMax = 250000;
|
const float bwMax = 250000;
|
||||||
|
Loading…
Reference in New Issue
Block a user