mirror of
https://github.com/cjcliffe/CubicSDR.git
synced 2024-11-26 21:58:37 -05:00
Persist modem settings on new instances
This commit is contained in:
parent
1fb5dc4236
commit
4fa0cb7c67
@ -826,7 +826,7 @@ void AppFrame::OnIdle(wxIdleEvent& event) {
|
|||||||
|
|
||||||
DemodulatorInstance *demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
DemodulatorInstance *demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
||||||
|
|
||||||
if (demod) {
|
if (demod && demod->isModemInitialized()) {
|
||||||
if (demod->isTracking()) {
|
if (demod->isTracking()) {
|
||||||
if (spectrumCanvas->getViewState()) {
|
if (spectrumCanvas->getViewState()) {
|
||||||
long long diff = abs(demod->getFrequency() - spectrumCanvas->getCenterFrequency()) + (demod->getBandwidth()/2) + (demod->getBandwidth()/4);
|
long long diff = abs(demod->getFrequency() - spectrumCanvas->getCenterFrequency()) + (demod->getBandwidth()/2) + (demod->getBandwidth()/4);
|
||||||
@ -845,6 +845,10 @@ void AppFrame::OnIdle(wxIdleEvent& event) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (demod->getBandwidth() != wxGetApp().getDemodMgr().getLastBandwidth()) {
|
||||||
|
wxGetApp().getDemodMgr().setLastBandwidth(demod->getBandwidth());
|
||||||
|
}
|
||||||
|
|
||||||
if (demod != activeDemodulator) {
|
if (demod != activeDemodulator) {
|
||||||
demodSignalMeter->setInputValue(demod->getSquelchLevel());
|
demodSignalMeter->setInputValue(demod->getSquelchLevel());
|
||||||
demodGainMeter->setInputValue(demod->getGain());
|
demodGainMeter->setInputValue(demod->getGain());
|
||||||
@ -857,7 +861,6 @@ void AppFrame::OnIdle(wxIdleEvent& event) {
|
|||||||
demodModeSelectorAdv->setSelection(dType);
|
demodModeSelectorAdv->setSelection(dType);
|
||||||
#endif
|
#endif
|
||||||
demodMuteButton->setSelection(demod->isMuted()?1:-1);
|
demodMuteButton->setSelection(demod->isMuted()?1:-1);
|
||||||
newModemArgs = demod->getModemArgs();
|
|
||||||
modemPropertiesUpdated.store(true);
|
modemPropertiesUpdated.store(true);
|
||||||
}
|
}
|
||||||
if (demodWaterfallCanvas->getDragState() == WaterfallCanvas::WF_DRAG_NONE) {
|
if (demodWaterfallCanvas->getDragState() == WaterfallCanvas::WF_DRAG_NONE) {
|
||||||
@ -893,16 +896,25 @@ void AppFrame::OnIdle(wxIdleEvent& event) {
|
|||||||
if (dSelection != "" && dSelection != demod->getDemodulatorType()) {
|
if (dSelection != "" && dSelection != demod->getDemodulatorType()) {
|
||||||
demod->setDemodulatorType(dSelection);
|
demod->setDemodulatorType(dSelection);
|
||||||
demodModeSelectorAdv->setSelection(-1);
|
demodModeSelectorAdv->setSelection(-1);
|
||||||
|
if (int lastDemodBw = wxGetApp().getDemodMgr().getLastBandwidth(dSelection)) {
|
||||||
|
demod->setBandwidth(lastDemodBw);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// advanced demodulators
|
// advanced demodulators
|
||||||
else if (dSelectionadv != "" && dSelectionadv != demod->getDemodulatorType()) {
|
else if (dSelectionadv != "" && dSelectionadv != demod->getDemodulatorType()) {
|
||||||
demod->setDemodulatorType(dSelectionadv);
|
demod->setDemodulatorType(dSelectionadv);
|
||||||
demodModeSelector->setSelection(-1);
|
demodModeSelector->setSelection(-1);
|
||||||
|
if (int lastDemodBw = wxGetApp().getDemodMgr().getLastBandwidth(dSelection)) {
|
||||||
|
demod->setBandwidth(lastDemodBw);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
// basic demodulators
|
// basic demodulators
|
||||||
if (dSelection != "" && dSelection != demod->getDemodulatorType()) {
|
if (dSelection != "" && dSelection != demod->getDemodulatorType()) {
|
||||||
demod->setDemodulatorType(dSelection);
|
demod->setDemodulatorType(dSelection);
|
||||||
|
if (int lastDemodBw = wxGetApp().getDemodMgr().getLastBandwidth(dSelection)) {
|
||||||
|
demod->setBandwidth(lastDemodBw);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1050,8 +1062,10 @@ void AppFrame::OnIdle(wxIdleEvent& event) {
|
|||||||
wproc->setCenterFrequency(waterfallCanvas->getCenterFrequency());
|
wproc->setCenterFrequency(waterfallCanvas->getCenterFrequency());
|
||||||
wxGetApp().getSDRPostThread()->setIQVisualRange(waterfallCanvas->getCenterFrequency(), waterfallCanvas->getBandwidth());
|
wxGetApp().getSDRPostThread()->setIQVisualRange(waterfallCanvas->getCenterFrequency(), waterfallCanvas->getBandwidth());
|
||||||
|
|
||||||
|
demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
||||||
|
|
||||||
if (modemPropertiesUpdated.load()) {
|
if (modemPropertiesUpdated.load()) {
|
||||||
modemProps->initProperties(newModemArgs);
|
modemProps->initProperties(demod->getModemArgs());
|
||||||
modemPropertiesUpdated.store(false);
|
modemPropertiesUpdated.store(false);
|
||||||
demodTray->Layout();
|
demodTray->Layout();
|
||||||
}
|
}
|
||||||
|
@ -127,7 +127,6 @@ public:
|
|||||||
bool isDeviceSelectorOpen();
|
bool isDeviceSelectorOpen();
|
||||||
void closeDeviceSelector();
|
void closeDeviceSelector();
|
||||||
|
|
||||||
|
|
||||||
void setAGCMode(bool mode);
|
void setAGCMode(bool mode);
|
||||||
bool getAGCMode();
|
bool getAGCMode();
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "DemodulatorInstance.h"
|
#include "DemodulatorInstance.h"
|
||||||
|
#include "CubicSDR.h"
|
||||||
|
|
||||||
DemodulatorInstance::DemodulatorInstance() :
|
DemodulatorInstance::DemodulatorInstance() :
|
||||||
t_PreDemod(NULL), t_Demod(NULL), t_Audio(NULL) {
|
t_PreDemod(NULL), t_Demod(NULL), t_Audio(NULL) {
|
||||||
@ -20,6 +21,8 @@ DemodulatorInstance::DemodulatorInstance() :
|
|||||||
pipeIQDemodData = new DemodulatorThreadPostInputQueue;
|
pipeIQDemodData = new DemodulatorThreadPostInputQueue;
|
||||||
pipeDemodNotify = new DemodulatorThreadCommandQueue;
|
pipeDemodNotify = new DemodulatorThreadCommandQueue;
|
||||||
|
|
||||||
|
audioThread = new AudioThread();
|
||||||
|
|
||||||
demodulatorPreThread = new DemodulatorPreThread(this);
|
demodulatorPreThread = new DemodulatorPreThread(this);
|
||||||
demodulatorPreThread->setInputQueue("IQDataInput",pipeIQInputData);
|
demodulatorPreThread->setInputQueue("IQDataInput",pipeIQInputData);
|
||||||
demodulatorPreThread->setOutputQueue("IQDataOutput",pipeIQDemodData);
|
demodulatorPreThread->setOutputQueue("IQDataOutput",pipeIQDemodData);
|
||||||
@ -34,7 +37,6 @@ DemodulatorInstance::DemodulatorInstance() :
|
|||||||
demodulatorThread->setOutputQueue("NotifyQueue",pipeDemodNotify);
|
demodulatorThread->setOutputQueue("NotifyQueue",pipeDemodNotify);
|
||||||
demodulatorThread->setOutputQueue("AudioDataOutput", pipeAudioData);
|
demodulatorThread->setOutputQueue("AudioDataOutput", pipeAudioData);
|
||||||
|
|
||||||
audioThread = new AudioThread();
|
|
||||||
audioThread->setInputQueue("AudioDataInput", pipeAudioData);
|
audioThread->setInputQueue("AudioDataInput", pipeAudioData);
|
||||||
audioThread->setOutputQueue("NotifyQueue", pipeDemodNotify);
|
audioThread->setOutputQueue("NotifyQueue", pipeDemodNotify);
|
||||||
}
|
}
|
||||||
@ -204,6 +206,8 @@ float DemodulatorInstance::getSignalLevel() {
|
|||||||
|
|
||||||
void DemodulatorInstance::setSquelchLevel(float signal_level_in) {
|
void DemodulatorInstance::setSquelchLevel(float signal_level_in) {
|
||||||
demodulatorThread->setSquelchLevel(signal_level_in);
|
demodulatorThread->setSquelchLevel(signal_level_in);
|
||||||
|
wxGetApp().getDemodMgr().setLastSquelchLevel(signal_level_in);
|
||||||
|
wxGetApp().getDemodMgr().setLastSquelchEnabled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
float DemodulatorInstance::getSquelchLevel() {
|
float DemodulatorInstance::getSquelchLevel() {
|
||||||
@ -263,6 +267,7 @@ int DemodulatorInstance::getDemodulatorLock() {
|
|||||||
|
|
||||||
void DemodulatorInstance::setBandwidth(int bw) {
|
void DemodulatorInstance::setBandwidth(int bw) {
|
||||||
demodulatorPreThread->setBandwidth(bw);
|
demodulatorPreThread->setBandwidth(bw);
|
||||||
|
wxGetApp().getDemodMgr().setLastBandwidth(bw);
|
||||||
}
|
}
|
||||||
|
|
||||||
int DemodulatorInstance::getBandwidth() {
|
int DemodulatorInstance::getBandwidth() {
|
||||||
@ -296,6 +301,7 @@ int DemodulatorInstance::getAudioSampleRate() {
|
|||||||
void DemodulatorInstance::setGain(float gain_in) {
|
void DemodulatorInstance::setGain(float gain_in) {
|
||||||
currentAudioGain = gain_in;
|
currentAudioGain = gain_in;
|
||||||
audioThread->setGain(gain_in);
|
audioThread->setGain(gain_in);
|
||||||
|
wxGetApp().getDemodMgr().setLastGain(gain_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
float DemodulatorInstance::getGain() {
|
float DemodulatorInstance::getGain() {
|
||||||
@ -325,6 +331,7 @@ bool DemodulatorInstance::isMuted() {
|
|||||||
void DemodulatorInstance::setMuted(bool muted) {
|
void DemodulatorInstance::setMuted(bool muted) {
|
||||||
this->muted = muted;
|
this->muted = muted;
|
||||||
demodulatorThread->setMuted(muted);
|
demodulatorThread->setMuted(muted);
|
||||||
|
wxGetApp().getDemodMgr().setLastMuted(muted);
|
||||||
}
|
}
|
||||||
|
|
||||||
DemodulatorThreadInputQueue *DemodulatorInstance::getIQInputDataPipe() {
|
DemodulatorThreadInputQueue *DemodulatorInstance::getIQInputDataPipe() {
|
||||||
@ -342,18 +349,21 @@ ModemArgInfoList DemodulatorInstance::getModemArgs() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string DemodulatorInstance::readModemSetting(std::string setting) {
|
std::string DemodulatorInstance::readModemSetting(std::string setting) {
|
||||||
Modem *m = demodulatorPreThread->getModem();
|
return demodulatorPreThread->readModemSetting(setting);
|
||||||
|
|
||||||
if (m) {
|
|
||||||
return m->readSetting(setting);
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DemodulatorInstance::writeModemSetting(std::string setting, std::string value) {
|
void DemodulatorInstance::writeModemSetting(std::string setting, std::string value) {
|
||||||
Modem *m = demodulatorPreThread->getModem();
|
demodulatorPreThread->writeModemSetting(setting, value);
|
||||||
|
}
|
||||||
if (m) {
|
|
||||||
m->writeSetting(setting, value);
|
ModemSettings DemodulatorInstance::readModemSettings() {
|
||||||
}
|
return demodulatorPreThread->readModemSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DemodulatorInstance::writeModemSettings(ModemSettings settings) {
|
||||||
|
demodulatorPreThread->writeModemSettings(settings);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool DemodulatorInstance::isModemInitialized() {
|
||||||
|
return demodulatorPreThread->isInitialized();
|
||||||
}
|
}
|
@ -84,7 +84,11 @@ public:
|
|||||||
|
|
||||||
ModemArgInfoList getModemArgs();
|
ModemArgInfoList getModemArgs();
|
||||||
std::string readModemSetting(std::string setting);
|
std::string readModemSetting(std::string setting);
|
||||||
|
ModemSettings readModemSettings();
|
||||||
void writeModemSetting(std::string setting, std::string value);
|
void writeModemSetting(std::string setting, std::string value);
|
||||||
|
void writeModemSettings(ModemSettings settings);
|
||||||
|
|
||||||
|
bool isModemInitialized();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
DemodulatorThreadInputQueue* pipeIQInputData;
|
DemodulatorThreadInputQueue* pipeIQInputData;
|
||||||
|
@ -8,7 +8,13 @@
|
|||||||
DemodulatorMgr::DemodulatorMgr() :
|
DemodulatorMgr::DemodulatorMgr() :
|
||||||
activeDemodulator(NULL), lastActiveDemodulator(NULL), activeVisualDemodulator(NULL), lastBandwidth(DEFAULT_DEMOD_BW), lastDemodType(
|
activeDemodulator(NULL), lastActiveDemodulator(NULL), activeVisualDemodulator(NULL), lastBandwidth(DEFAULT_DEMOD_BW), lastDemodType(
|
||||||
DEFAULT_DEMOD_TYPE), lastSquelchEnabled(false), lastSquelch(-100), lastGain(1.0), lastMuted(false) {
|
DEFAULT_DEMOD_TYPE), lastSquelchEnabled(false), lastSquelch(-100), lastGain(1.0), lastMuted(false) {
|
||||||
|
setLastBandwidth("FM",200000);
|
||||||
|
setLastBandwidth("FMS",200000);
|
||||||
|
setLastBandwidth("AM",6000);
|
||||||
|
setLastBandwidth("USB",5400);
|
||||||
|
setLastBandwidth("LSB",5400);
|
||||||
|
setLastBandwidth("DSB",5400);
|
||||||
|
setLastBandwidth("IQ",48000);
|
||||||
}
|
}
|
||||||
|
|
||||||
DemodulatorMgr::~DemodulatorMgr() {
|
DemodulatorMgr::~DemodulatorMgr() {
|
||||||
@ -88,6 +94,7 @@ void DemodulatorMgr::setActiveDemodulator(DemodulatorInstance *demod, bool tempo
|
|||||||
if (!temporary) {
|
if (!temporary) {
|
||||||
if (activeDemodulator != NULL) {
|
if (activeDemodulator != NULL) {
|
||||||
lastActiveDemodulator = activeDemodulator;
|
lastActiveDemodulator = activeDemodulator;
|
||||||
|
updateLastState();
|
||||||
} else {
|
} else {
|
||||||
lastActiveDemodulator = demod;
|
lastActiveDemodulator = demod;
|
||||||
}
|
}
|
||||||
@ -121,8 +128,6 @@ DemodulatorInstance *DemodulatorMgr::getActiveDemodulator() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
DemodulatorInstance *DemodulatorMgr::getLastActiveDemodulator() {
|
DemodulatorInstance *DemodulatorMgr::getLastActiveDemodulator() {
|
||||||
updateLastState();
|
|
||||||
|
|
||||||
return lastActiveDemodulator;
|
return lastActiveDemodulator;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,6 +170,8 @@ void DemodulatorMgr::updateLastState() {
|
|||||||
lastSquelchEnabled = lastActiveDemodulator->isSquelchEnabled();
|
lastSquelchEnabled = lastActiveDemodulator->isSquelchEnabled();
|
||||||
lastSquelch = lastActiveDemodulator->getSquelchLevel();
|
lastSquelch = lastActiveDemodulator->getSquelchLevel();
|
||||||
lastGain = lastActiveDemodulator->getGain();
|
lastGain = lastActiveDemodulator->getGain();
|
||||||
|
lastModemSettings[lastDemodType] = lastActiveDemodulator->readModemSettings();
|
||||||
|
lastBandwidthNamed[lastDemodType] = lastBandwidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -222,3 +229,17 @@ void DemodulatorMgr::setLastMuted(bool lastMuted) {
|
|||||||
this->lastMuted = lastMuted;
|
this->lastMuted = lastMuted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ModemSettings DemodulatorMgr::getLastModemSettings(std::string modemType) {
|
||||||
|
return lastModemSettings[modemType];
|
||||||
|
}
|
||||||
|
|
||||||
|
void DemodulatorMgr::setLastModemSettings(std::string modemType, ModemSettings settings) {
|
||||||
|
lastModemSettings[modemType] = settings;
|
||||||
|
}
|
||||||
|
|
||||||
|
int DemodulatorMgr::getLastBandwidth(std::string modemType) {
|
||||||
|
return lastBandwidthNamed[modemType];
|
||||||
|
}
|
||||||
|
void DemodulatorMgr::setLastBandwidth(std::string modemType, int lastBandwidth_in) {
|
||||||
|
lastBandwidthNamed[modemType] = lastBandwidth_in;
|
||||||
|
}
|
||||||
|
@ -25,6 +25,9 @@ public:
|
|||||||
int getLastBandwidth() const;
|
int getLastBandwidth() const;
|
||||||
void setLastBandwidth(int lastBandwidth);
|
void setLastBandwidth(int lastBandwidth);
|
||||||
|
|
||||||
|
int getLastBandwidth(std::string modemType);
|
||||||
|
void setLastBandwidth(std::string modemType, int lastBandwidth);
|
||||||
|
|
||||||
std::string getLastDemodulatorType() const;
|
std::string getLastDemodulatorType() const;
|
||||||
void setLastDemodulatorType(std::string lastDemodType);
|
void setLastDemodulatorType(std::string lastDemodType);
|
||||||
|
|
||||||
@ -40,9 +43,13 @@ public:
|
|||||||
bool isLastMuted() const;
|
bool isLastMuted() const;
|
||||||
void setLastMuted(bool lastMuted);
|
void setLastMuted(bool lastMuted);
|
||||||
|
|
||||||
|
ModemSettings getLastModemSettings(std::string);
|
||||||
|
void setLastModemSettings(std::string, ModemSettings);
|
||||||
|
|
||||||
|
void updateLastState();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void garbageCollect();
|
void garbageCollect();
|
||||||
void updateLastState();
|
|
||||||
|
|
||||||
std::vector<DemodulatorInstance *> demods;
|
std::vector<DemodulatorInstance *> demods;
|
||||||
std::vector<DemodulatorInstance *> demods_deleted;
|
std::vector<DemodulatorInstance *> demods_deleted;
|
||||||
@ -50,6 +57,7 @@ private:
|
|||||||
DemodulatorInstance *lastActiveDemodulator;
|
DemodulatorInstance *lastActiveDemodulator;
|
||||||
DemodulatorInstance *activeVisualDemodulator;
|
DemodulatorInstance *activeVisualDemodulator;
|
||||||
|
|
||||||
|
std::map<std::string, int> lastBandwidthNamed;
|
||||||
int lastBandwidth;
|
int lastBandwidth;
|
||||||
std::string lastDemodType;
|
std::string lastDemodType;
|
||||||
bool lastDemodLock;
|
bool lastDemodLock;
|
||||||
@ -57,4 +65,6 @@ private:
|
|||||||
float lastSquelch;
|
float lastSquelch;
|
||||||
float lastGain;
|
float lastGain;
|
||||||
bool lastMuted;
|
bool lastMuted;
|
||||||
|
|
||||||
|
std::map<std::string, ModemSettings> lastModemSettings;
|
||||||
};
|
};
|
||||||
|
@ -33,10 +33,11 @@ DemodulatorPreThread::DemodulatorPreThread(DemodulatorInstance *parent) : IOThre
|
|||||||
frequencyChanged.store(false);
|
frequencyChanged.store(false);
|
||||||
bandwidthChanged.store(false);
|
bandwidthChanged.store(false);
|
||||||
audioSampleRateChanged.store(false);
|
audioSampleRateChanged.store(false);
|
||||||
|
modemSettingsChanged.store(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DemodulatorPreThread::initialize() {
|
bool DemodulatorPreThread::isInitialized() {
|
||||||
initialized.store(true);
|
return initialized.load();
|
||||||
}
|
}
|
||||||
|
|
||||||
DemodulatorPreThread::~DemodulatorPreThread() {
|
DemodulatorPreThread::~DemodulatorPreThread() {
|
||||||
@ -50,10 +51,6 @@ void DemodulatorPreThread::run() {
|
|||||||
pthread_setschedparam(tID, SCHED_FIFO, &prio);
|
pthread_setschedparam(tID, SCHED_FIFO, &prio);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!initialized) {
|
|
||||||
initialize();
|
|
||||||
}
|
|
||||||
|
|
||||||
std::cout << "Demodulator preprocessor thread started.." << std::endl;
|
std::cout << "Demodulator preprocessor thread started.." << std::endl;
|
||||||
|
|
||||||
ReBuffer<DemodulatorThreadPostIQData> buffers;
|
ReBuffer<DemodulatorThreadPostIQData> buffers;
|
||||||
@ -103,10 +100,17 @@ void DemodulatorPreThread::run() {
|
|||||||
command.demodType = newDemodType;
|
command.demodType = newDemodType;
|
||||||
command.bandwidth = newBandwidth;
|
command.bandwidth = newBandwidth;
|
||||||
command.audioSampleRate = newAudioSampleRate;
|
command.audioSampleRate = newAudioSampleRate;
|
||||||
workerQueue->push(command);
|
|
||||||
demodType = newDemodType;
|
demodType = newDemodType;
|
||||||
sampleRateChanged.store(false);
|
sampleRateChanged.store(false);
|
||||||
audioSampleRateChanged.store(false);
|
audioSampleRateChanged.store(false);
|
||||||
|
if (modemSettingsBuffered.size()) {
|
||||||
|
command.settings = modemSettingsBuffered;
|
||||||
|
}
|
||||||
|
modemSettingsBuffered.clear();
|
||||||
|
modemSettingsChanged.store(false);
|
||||||
|
workerQueue->push(command);
|
||||||
|
cModem = nullptr;
|
||||||
|
cModemKit = nullptr;
|
||||||
demodTypeChanged.store(false);
|
demodTypeChanged.store(false);
|
||||||
}
|
}
|
||||||
else if (
|
else if (
|
||||||
@ -122,14 +126,10 @@ void DemodulatorPreThread::run() {
|
|||||||
bandwidthChanged.store(false);
|
bandwidthChanged.store(false);
|
||||||
sampleRateChanged.store(false);
|
sampleRateChanged.store(false);
|
||||||
audioSampleRateChanged.store(false);
|
audioSampleRateChanged.store(false);
|
||||||
|
modemSettingsBuffered.clear();
|
||||||
workerQueue->push(command);
|
workerQueue->push(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!initialized) {
|
|
||||||
inp->decRefCount();
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Requested frequency is not center, shift it into the center!
|
// Requested frequency is not center, shift it into the center!
|
||||||
if ((currentFrequency - inp->frequency) != shiftFrequency) {
|
if ((currentFrequency - inp->frequency) != shiftFrequency) {
|
||||||
shiftFrequency = currentFrequency - inp->frequency;
|
shiftFrequency = currentFrequency - inp->frequency;
|
||||||
@ -239,12 +239,19 @@ void DemodulatorPreThread::run() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
shiftFrequency = inp->frequency-1;
|
shiftFrequency = inp->frequency-1;
|
||||||
|
initialized.store(cModem != nullptr);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((cModem != nullptr) && modemSettingsChanged.load()) {
|
||||||
|
cModem->writeSettings(modemSettingsBuffered);
|
||||||
|
modemSettingsBuffered.clear();
|
||||||
|
modemSettingsChanged.store(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
buffers.purge();
|
buffers.purge();
|
||||||
@ -297,10 +304,6 @@ void DemodulatorPreThread::setBandwidth(int bandwidth) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int DemodulatorPreThread::getBandwidth() {
|
int DemodulatorPreThread::getBandwidth() {
|
||||||
// if (bandwidthChanged.load()) {
|
|
||||||
// return newBandwidth;
|
|
||||||
// }
|
|
||||||
|
|
||||||
return currentBandwidth;
|
return currentBandwidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,3 +340,31 @@ Modem *DemodulatorPreThread::getModem() {
|
|||||||
ModemKit *DemodulatorPreThread::getModemKit() {
|
ModemKit *DemodulatorPreThread::getModemKit() {
|
||||||
return cModemKit;
|
return cModemKit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::string DemodulatorPreThread::readModemSetting(std::string setting) {
|
||||||
|
if (cModem) {
|
||||||
|
return cModem->readSetting(setting);
|
||||||
|
} else if (modemSettingsBuffered.find(setting) != modemSettingsBuffered.end()) {
|
||||||
|
return modemSettingsBuffered[setting];
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void DemodulatorPreThread::writeModemSetting(std::string setting, std::string value) {
|
||||||
|
modemSettingsBuffered[setting] = value;
|
||||||
|
modemSettingsChanged.store(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
ModemSettings DemodulatorPreThread::readModemSettings() {
|
||||||
|
if (cModem) {
|
||||||
|
return cModem->readSettings();
|
||||||
|
} else {
|
||||||
|
return modemSettingsBuffered;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void DemodulatorPreThread::writeModemSettings(ModemSettings settings) {
|
||||||
|
modemSettingsBuffered = settings;
|
||||||
|
modemSettingsChanged.store(true);
|
||||||
|
}
|
||||||
|
@ -32,12 +32,18 @@ public:
|
|||||||
void setAudioSampleRate(int rate);
|
void setAudioSampleRate(int rate);
|
||||||
int getAudioSampleRate();
|
int getAudioSampleRate();
|
||||||
|
|
||||||
void initialize();
|
bool isInitialized();
|
||||||
|
|
||||||
void terminate();
|
void terminate();
|
||||||
|
|
||||||
Modem *getModem();
|
Modem *getModem();
|
||||||
ModemKit *getModemKit();
|
ModemKit *getModemKit();
|
||||||
|
|
||||||
|
std::string readModemSetting(std::string setting);
|
||||||
|
void writeModemSetting(std::string setting, std::string value);
|
||||||
|
ModemSettings readModemSettings();
|
||||||
|
void writeModemSettings(ModemSettings settings);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
DemodulatorInstance *parent;
|
DemodulatorInstance *parent;
|
||||||
msresamp_crcf iqResampler;
|
msresamp_crcf iqResampler;
|
||||||
@ -54,6 +60,9 @@ protected:
|
|||||||
|
|
||||||
std::atomic_bool sampleRateChanged, frequencyChanged, bandwidthChanged, audioSampleRateChanged;
|
std::atomic_bool sampleRateChanged, frequencyChanged, bandwidthChanged, audioSampleRateChanged;
|
||||||
|
|
||||||
|
ModemSettings modemSettingsBuffered;
|
||||||
|
std::atomic_bool modemSettingsChanged;
|
||||||
|
|
||||||
nco_crcf freqShifter;
|
nco_crcf freqShifter;
|
||||||
int shiftFrequency;
|
int shiftFrequency;
|
||||||
|
|
||||||
|
@ -52,6 +52,9 @@ void DemodulatorWorkerThread::run() {
|
|||||||
if (makeDemod) {
|
if (makeDemod) {
|
||||||
cModem = Modem::makeModem(demodCommand.demodType);
|
cModem = Modem::makeModem(demodCommand.demodType);
|
||||||
cModemType = demodCommand.demodType;
|
cModemType = demodCommand.demodType;
|
||||||
|
if (demodCommand.settings.size()) {
|
||||||
|
cModem->writeSettings(demodCommand.settings);
|
||||||
|
}
|
||||||
result.sampleRate = demodCommand.sampleRate;
|
result.sampleRate = demodCommand.sampleRate;
|
||||||
wxGetApp().getAppFrame()->updateModemProperties(cModem->getSettings());
|
wxGetApp().getAppFrame()->updateModemProperties(cModem->getSettings());
|
||||||
}
|
}
|
||||||
|
@ -62,6 +62,7 @@ public:
|
|||||||
unsigned int bandwidth;
|
unsigned int bandwidth;
|
||||||
unsigned int audioSampleRate;
|
unsigned int audioSampleRate;
|
||||||
std::string demodType;
|
std::string demodType;
|
||||||
|
ModemSettings settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef ThreadQueue<DemodulatorWorkerThreadCommand> DemodulatorThreadWorkerCommandQueue;
|
typedef ThreadQueue<DemodulatorWorkerThreadCommand> DemodulatorThreadWorkerCommandQueue;
|
||||||
|
@ -28,6 +28,14 @@ ModemArgInfo::ModemArgInfo(void) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Modem::Modem() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Modem::~Modem() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void Modem::addModemFactory(Modem *factorySingle) {
|
void Modem::addModemFactory(Modem *factorySingle) {
|
||||||
modemFactories[factorySingle->getName()] = factorySingle;
|
modemFactories[factorySingle->getName()] = factorySingle;
|
||||||
}
|
}
|
||||||
@ -58,12 +66,19 @@ std::string Modem::readSetting(std::string setting) {
|
|||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
Modem::Modem() {
|
void Modem::writeSettings(ModemSettings settings) {
|
||||||
|
for (ModemSettings::const_iterator i = settings.begin(); i != settings.end(); i++) {
|
||||||
|
writeSetting(i->first, i->second);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Modem::~Modem() {
|
ModemSettings Modem::readSettings() {
|
||||||
|
ModemArgInfoList args = getSettings();
|
||||||
|
ModemSettings rs;
|
||||||
|
for (ModemArgInfoList::const_iterator i = args.begin(); i != args.end(); i++) {
|
||||||
|
rs[i->key] = readSetting(i->key);
|
||||||
|
}
|
||||||
|
return rs;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Modem::shouldRebuildKit() {
|
bool Modem::shouldRebuildKit() {
|
||||||
|
@ -105,6 +105,8 @@ typedef std::vector<ModemArgInfo> ModemArgInfoList;
|
|||||||
class Modem;
|
class Modem;
|
||||||
typedef std::map<std::string,Modem *> ModemFactoryList;
|
typedef std::map<std::string,Modem *> ModemFactoryList;
|
||||||
|
|
||||||
|
typedef std::map<std::string, std::string> ModemSettings;
|
||||||
|
|
||||||
class Modem {
|
class Modem {
|
||||||
public:
|
public:
|
||||||
static void addModemFactory(Modem *factorySingle);
|
static void addModemFactory(Modem *factorySingle);
|
||||||
@ -122,7 +124,9 @@ public:
|
|||||||
|
|
||||||
virtual ModemArgInfoList getSettings();
|
virtual ModemArgInfoList getSettings();
|
||||||
virtual void writeSetting(std::string setting, std::string value);
|
virtual void writeSetting(std::string setting, std::string value);
|
||||||
|
virtual void writeSettings(ModemSettings settings);
|
||||||
virtual std::string readSetting(std::string setting);
|
virtual std::string readSetting(std::string setting);
|
||||||
|
virtual ModemSettings readSettings();
|
||||||
|
|
||||||
virtual int checkSampleRate(long long sampleRate, int audioSampleRate) = 0;
|
virtual int checkSampleRate(long long sampleRate, int audioSampleRate) = 0;
|
||||||
|
|
||||||
|
@ -597,6 +597,7 @@ void WaterfallCanvas::OnMouseDown(wxMouseEvent& event) {
|
|||||||
InteractiveCanvas::OnMouseDown(event);
|
InteractiveCanvas::OnMouseDown(event);
|
||||||
|
|
||||||
dragState = nextDragState;
|
dragState = nextDragState;
|
||||||
|
wxGetApp().getDemodMgr().updateLastState();
|
||||||
|
|
||||||
if (dragState && dragState != WF_DRAG_RANGE) {
|
if (dragState && dragState != WF_DRAG_RANGE) {
|
||||||
DemodulatorInstance *demod = wxGetApp().getDemodMgr().getActiveDemodulator();
|
DemodulatorInstance *demod = wxGetApp().getDemodMgr().getActiveDemodulator();
|
||||||
@ -617,6 +618,7 @@ void WaterfallCanvas::OnMouseWheelMoved(wxMouseEvent& event) {
|
|||||||
|
|
||||||
void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
||||||
InteractiveCanvas::OnMouseReleased(event);
|
InteractiveCanvas::OnMouseReleased(event);
|
||||||
|
wxGetApp().getDemodMgr().updateLastState();
|
||||||
|
|
||||||
bool isNew = shiftDown || (wxGetApp().getDemodMgr().getLastActiveDemodulator() == NULL)
|
bool isNew = shiftDown || (wxGetApp().getDemodMgr().getLastActiveDemodulator() == NULL)
|
||||||
|| (wxGetApp().getDemodMgr().getLastActiveDemodulator() && !wxGetApp().getDemodMgr().getLastActiveDemodulator()->isActive());
|
|| (wxGetApp().getDemodMgr().getLastActiveDemodulator() && !wxGetApp().getDemodMgr().getLastActiveDemodulator()->isActive());
|
||||||
@ -653,6 +655,7 @@ void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
|||||||
|
|
||||||
if (dragState == WF_DRAG_NONE) {
|
if (dragState == WF_DRAG_NONE) {
|
||||||
if (!isNew && wxGetApp().getDemodMgr().getDemodulators().size()) {
|
if (!isNew && wxGetApp().getDemodMgr().getDemodulators().size()) {
|
||||||
|
mgr->updateLastState();
|
||||||
demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
||||||
} else {
|
} else {
|
||||||
isNew = true;
|
isNew = true;
|
||||||
@ -660,12 +663,16 @@ void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
|||||||
demod->setFrequency(freq);
|
demod->setFrequency(freq);
|
||||||
|
|
||||||
demod->setDemodulatorType(mgr->getLastDemodulatorType());
|
demod->setDemodulatorType(mgr->getLastDemodulatorType());
|
||||||
|
if (int lastDemodBw = mgr->getLastBandwidth(mgr->getLastDemodulatorType())) {
|
||||||
|
demod->setBandwidth(lastDemodBw);
|
||||||
|
} else {
|
||||||
demod->setBandwidth(mgr->getLastBandwidth());
|
demod->setBandwidth(mgr->getLastBandwidth());
|
||||||
|
}
|
||||||
demod->setSquelchLevel(mgr->getLastSquelchLevel());
|
demod->setSquelchLevel(mgr->getLastSquelchLevel());
|
||||||
demod->setSquelchEnabled(mgr->isLastSquelchEnabled());
|
demod->setSquelchEnabled(mgr->isLastSquelchEnabled());
|
||||||
demod->setGain(mgr->getLastGain());
|
demod->setGain(mgr->getLastGain());
|
||||||
demod->setMuted(mgr->isLastMuted());
|
demod->setMuted(mgr->isLastMuted());
|
||||||
|
demod->writeModemSettings(mgr->getLastModemSettings(mgr->getLastDemodulatorType()));
|
||||||
demod->run();
|
demod->run();
|
||||||
|
|
||||||
wxGetApp().bindDemodulator(demod);
|
wxGetApp().bindDemodulator(demod);
|
||||||
@ -693,6 +700,7 @@ void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
|||||||
} else {
|
} else {
|
||||||
if (activeDemod) {
|
if (activeDemod) {
|
||||||
wxGetApp().getDemodMgr().setActiveDemodulator(activeDemod, false);
|
wxGetApp().getDemodMgr().setActiveDemodulator(activeDemod, false);
|
||||||
|
mgr->updateLastState();
|
||||||
activeDemod->setTracking(true);
|
activeDemod->setTracking(true);
|
||||||
nextDragState = WF_DRAG_FREQUENCY;
|
nextDragState = WF_DRAG_FREQUENCY;
|
||||||
} else {
|
} else {
|
||||||
@ -742,15 +750,22 @@ void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
|||||||
|
|
||||||
|
|
||||||
if (!isNew && wxGetApp().getDemodMgr().getDemodulators().size()) {
|
if (!isNew && wxGetApp().getDemodMgr().getDemodulators().size()) {
|
||||||
|
mgr->updateLastState();
|
||||||
demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
demod = wxGetApp().getDemodMgr().getLastActiveDemodulator();
|
||||||
} else {
|
} else {
|
||||||
demod = wxGetApp().getDemodMgr().newThread();
|
demod = wxGetApp().getDemodMgr().newThread();
|
||||||
demod->setFrequency(freq);
|
demod->setFrequency(freq);
|
||||||
demod->setDemodulatorType(mgr->getLastDemodulatorType());
|
demod->setDemodulatorType(mgr->getLastDemodulatorType());
|
||||||
demod->setBandwidth(bw);
|
if (int lastDemodBw = mgr->getLastBandwidth(mgr->getLastDemodulatorType())) {
|
||||||
|
demod->setBandwidth(lastDemodBw);
|
||||||
|
} else {
|
||||||
|
demod->setBandwidth(mgr->getLastBandwidth());
|
||||||
|
}
|
||||||
demod->setSquelchLevel(mgr->getLastSquelchLevel());
|
demod->setSquelchLevel(mgr->getLastSquelchLevel());
|
||||||
demod->setSquelchEnabled(mgr->isLastSquelchEnabled());
|
demod->setSquelchEnabled(mgr->isLastSquelchEnabled());
|
||||||
demod->setGain(mgr->getLastGain());
|
demod->setGain(mgr->getLastGain());
|
||||||
|
demod->setMuted(mgr->isLastMuted());
|
||||||
|
demod->writeModemSettings(mgr->getLastModemSettings(mgr->getLastDemodulatorType()));
|
||||||
|
|
||||||
demod->run();
|
demod->run();
|
||||||
|
|
||||||
@ -767,7 +782,8 @@ void WaterfallCanvas::OnMouseReleased(wxMouseEvent& event) {
|
|||||||
demod->updateLabel(freq);
|
demod->updateLabel(freq);
|
||||||
demod->setFrequency(freq);
|
demod->setFrequency(freq);
|
||||||
demod->setBandwidth(bw);
|
demod->setBandwidth(bw);
|
||||||
wxGetApp().getDemodMgr().setActiveDemodulator(demod, false);
|
mgr->setActiveDemodulator(demod, false);
|
||||||
|
mgr->updateLastState();
|
||||||
}
|
}
|
||||||
|
|
||||||
dragState = WF_DRAG_NONE;
|
dragState = WF_DRAG_NONE;
|
||||||
|
Loading…
Reference in New Issue
Block a user