1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-05-31 14:22:26 -04:00

DSD demod: use settings in GUI

This commit is contained in:
f4exb 2017-10-03 23:42:56 +02:00
parent eccea4a4fc
commit 2bcf9e0933
2 changed files with 206 additions and 134 deletions

View File

@ -73,112 +73,116 @@ void DSDDemodGUI::setCenterFrequency(qint64 centerFrequency)
void DSDDemodGUI::resetToDefaults() void DSDDemodGUI::resetToDefaults()
{ {
m_settings.resetToDefaults();
blockApplySettings(true); blockApplySettings(true);
displaySettings();
ui->rfBW->setValue(100); // x100 Hz
ui->demodGain->setValue(100); // 100ths
ui->fmDeviation->setValue(50); // x100 Hz
ui->volume->setValue(20); // /10.0
ui->baudRate->setCurrentIndex(DSDDemodBaudRates::getDefaultRateIndex());
ui->squelchGate->setValue(5);
ui->squelch->setValue(-40);
ui->deltaFrequency->setValue(0);
ui->symbolPLLLock->setChecked(true);
blockApplySettings(false); blockApplySettings(false);
applySettings(); applySettings();
} }
QByteArray DSDDemodGUI::serialize() const QByteArray DSDDemodGUI::serialize() const
{ {
SimpleSerializer s(1); return m_settings.serialize();
s.writeS32(1, m_channelMarker.getCenterFrequency()); // SimpleSerializer s(1);
s.writeS32(2, ui->rfBW->value()); // s.writeS32(1, m_channelMarker.getCenterFrequency());
s.writeS32(3, ui->demodGain->value()); // s.writeS32(2, ui->rfBW->value());
s.writeS32(4, ui->fmDeviation->value()); // s.writeS32(3, ui->demodGain->value());
s.writeS32(5, ui->squelch->value()); // s.writeS32(4, ui->fmDeviation->value());
s.writeU32(7, m_channelMarker.getColor().rgb()); // s.writeS32(5, ui->squelch->value());
s.writeS32(8, ui->squelchGate->value()); // s.writeU32(7, m_channelMarker.getColor().rgb());
s.writeS32(9, ui->volume->value()); // s.writeS32(8, ui->squelchGate->value());
s.writeBlob(10, ui->scopeGUI->serialize()); // s.writeS32(9, ui->volume->value());
s.writeS32(11, ui->baudRate->currentIndex()); // s.writeBlob(10, ui->scopeGUI->serialize());
s.writeBool(12, m_enableCosineFiltering); // s.writeS32(11, ui->baudRate->currentIndex());
s.writeBool(13, m_syncOrConstellation); // s.writeBool(12, m_enableCosineFiltering);
s.writeBool(14, m_slot1On); // s.writeBool(13, m_syncOrConstellation);
s.writeBool(15, m_slot2On); // s.writeBool(14, m_slot1On);
s.writeBool(16, m_tdmaStereo); // s.writeBool(15, m_slot2On);
s.writeBlob(17, m_channelMarker.serialize()); // s.writeBool(16, m_tdmaStereo);
return s.final(); // s.writeBlob(17, m_channelMarker.serialize());
// return s.final();
} }
bool DSDDemodGUI::deserialize(const QByteArray& data) bool DSDDemodGUI::deserialize(const QByteArray& data)
{ {
SimpleDeserializer d(data); if (m_settings.deserialize(data))
{
displaySettings();
applySettings(true);
return true;
}
else
{
resetToDefaults();
return false;
}
if (!d.isValid()) // SimpleDeserializer d(data);
{ //
resetToDefaults(); // if (!d.isValid())
return false; // {
} // resetToDefaults();
// return false;
if (d.getVersion() == 1) // }
{ //
QByteArray bytetmp; // if (d.getVersion() == 1)
QString strtmp; // {
quint32 u32tmp; // QByteArray bytetmp;
qint32 tmp; // QString strtmp;
// quint32 u32tmp;
blockApplySettings(true); // qint32 tmp;
m_channelMarker.blockSignals(true); //
// blockApplySettings(true);
d.readBlob(17, &bytetmp); // m_channelMarker.blockSignals(true);
m_channelMarker.deserialize(bytetmp); //
// d.readBlob(17, &bytetmp);
d.readS32(1, &tmp, 0); // m_channelMarker.deserialize(bytetmp);
m_channelMarker.setCenterFrequency(tmp); //
d.readS32(2, &tmp, 4); // d.readS32(1, &tmp, 0);
ui->rfBW->setValue(tmp); // m_channelMarker.setCenterFrequency(tmp);
d.readS32(3, &tmp, 3); // d.readS32(2, &tmp, 4);
ui->demodGain->setValue(tmp); // ui->rfBW->setValue(tmp);
d.readS32(4, &tmp, 20); // d.readS32(3, &tmp, 3);
ui->fmDeviation->setValue(tmp); // ui->demodGain->setValue(tmp);
d.readS32(5, &tmp, -40); // d.readS32(4, &tmp, 20);
ui->squelch->setValue(tmp); // ui->fmDeviation->setValue(tmp);
// d.readS32(5, &tmp, -40);
if(d.readU32(7, &u32tmp)) // ui->squelch->setValue(tmp);
{ //
m_channelMarker.setColor(u32tmp); // if(d.readU32(7, &u32tmp))
} // {
// m_channelMarker.setColor(u32tmp);
d.readS32(8, &tmp, 5); // }
ui->squelchGate->setValue(tmp); //
d.readS32(9, &tmp, 20); // d.readS32(8, &tmp, 5);
ui->volume->setValue(tmp); // ui->squelchGate->setValue(tmp);
d.readBlob(10, &bytetmp); // d.readS32(9, &tmp, 20);
ui->scopeGUI->deserialize(bytetmp); // ui->volume->setValue(tmp);
d.readS32(11, &tmp, 20); // d.readBlob(10, &bytetmp);
ui->baudRate->setCurrentIndex(tmp); // ui->scopeGUI->deserialize(bytetmp);
d.readBool(12, &m_enableCosineFiltering, false); // d.readS32(11, &tmp, 20);
d.readBool(13, &m_syncOrConstellation, false); // ui->baudRate->setCurrentIndex(tmp);
d.readBool(14, &m_slot1On, false); // d.readBool(12, &m_enableCosineFiltering, false);
d.readBool(15, &m_slot2On, false); // d.readBool(13, &m_syncOrConstellation, false);
d.readBool(16, &m_tdmaStereo, false); // d.readBool(14, &m_slot1On, false);
// d.readBool(15, &m_slot2On, false);
this->setWindowTitle(m_channelMarker.getTitle()); // d.readBool(16, &m_tdmaStereo, false);
displayUDPAddress(); //
// this->setWindowTitle(m_channelMarker.getTitle());
blockApplySettings(false); // displayUDPAddress();
m_channelMarker.blockSignals(false); //
// blockApplySettings(false);
updateMyPosition(); // we do it also here to be able to refresh with latest settings // m_channelMarker.blockSignals(false);
applySettings(true); //
return true; // updateMyPosition(); // we do it also here to be able to refresh with latest settings
} // applySettings(true);
else // return true;
{ // }
resetToDefaults(); // else
return false; // {
} // resetToDefaults();
// return false;
// }
} }
bool DSDDemodGUI::handleMessage(const Message& message __attribute__((unused))) bool DSDDemodGUI::handleMessage(const Message& message __attribute__((unused)))
@ -189,79 +193,92 @@ bool DSDDemodGUI::handleMessage(const Message& message __attribute__((unused)))
void DSDDemodGUI::on_deltaFrequency_changed(qint64 value) void DSDDemodGUI::on_deltaFrequency_changed(qint64 value)
{ {
m_channelMarker.setCenterFrequency(value); m_channelMarker.setCenterFrequency(value);
m_settings.m_inputFrequencyOffset = m_channelMarker.getCenterFrequency();
applySettings();
} }
void DSDDemodGUI::on_rfBW_valueChanged(int value) void DSDDemodGUI::on_rfBW_valueChanged(int value)
{ {
qDebug() << "DSDDemodGUI::on_rfBW_valueChanged" << value * 100;
m_channelMarker.setBandwidth(value * 100); m_channelMarker.setBandwidth(value * 100);
m_settings.m_rfBandwidth = value * 100.0;
ui->rfBWText->setText(QString("%1k").arg(value / 10.0, 0, 'f', 1));
applySettings(); applySettings();
} }
void DSDDemodGUI::on_demodGain_valueChanged(int value __attribute__((unused))) void DSDDemodGUI::on_demodGain_valueChanged(int value)
{ {
m_settings.m_demodGain = value / 100.0;
ui->demodGainText->setText(QString("%1").arg(value / 100.0, 0, 'f', 2));
applySettings(); applySettings();
} }
void DSDDemodGUI::on_fmDeviation_valueChanged(int value __attribute__((unused))) void DSDDemodGUI::on_fmDeviation_valueChanged(int value)
{ {
m_settings.m_fmDeviation = value * 100.0;
ui->fmDeviationText->setText(QString("%1k").arg(value / 10.0, 0, 'f', 1));
applySettings(); applySettings();
} }
void DSDDemodGUI::on_volume_valueChanged(int value __attribute__((unused))) void DSDDemodGUI::on_volume_valueChanged(int value)
{ {
m_settings.m_volume= value / 10.0;
ui->volumeText->setText(QString("%1").arg(value / 10.0, 0, 'f', 1));
applySettings(); applySettings();
} }
void DSDDemodGUI::on_baudRate_currentIndexChanged(int index __attribute__((unused))) void DSDDemodGUI::on_baudRate_currentIndexChanged(int index)
{ {
m_settings.m_baudRate = DSDDemodBaudRates::getRate(index);
applySettings(); applySettings();
} }
void DSDDemodGUI::on_enableCosineFiltering_toggled(bool enable) void DSDDemodGUI::on_enableCosineFiltering_toggled(bool enable)
{ {
m_enableCosineFiltering = enable; m_settings.m_enableCosineFiltering = enable;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_syncOrConstellation_toggled(bool checked) void DSDDemodGUI::on_syncOrConstellation_toggled(bool checked)
{ {
m_syncOrConstellation = checked; m_settings.m_syncOrConstellation = checked;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_slot1On_toggled(bool checked) void DSDDemodGUI::on_slot1On_toggled(bool checked)
{ {
m_slot1On = checked; m_settings.m_slot1On = checked;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_slot2On_toggled(bool checked) void DSDDemodGUI::on_slot2On_toggled(bool checked)
{ {
m_slot2On = checked; m_settings.m_slot2On = checked;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_tdmaStereoSplit_toggled(bool checked) void DSDDemodGUI::on_tdmaStereoSplit_toggled(bool checked)
{ {
m_tdmaStereo = checked; m_settings.m_tdmaStereo = checked;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_squelchGate_valueChanged(int value __attribute__((unused))) void DSDDemodGUI::on_squelchGate_valueChanged(int value)
{ {
m_settings.m_squelchGate = value;
ui->squelchGateText->setText(QString("%1").arg(value * 10.0, 0, 'f', 0));
applySettings(); applySettings();
} }
void DSDDemodGUI::on_squelch_valueChanged(int value) void DSDDemodGUI::on_squelch_valueChanged(int value)
{ {
ui->squelchText->setText(QString("%1").arg(value / 10.0, 0, 'f', 1)); ui->squelchText->setText(QString("%1").arg(value / 10.0, 0, 'f', 1));
m_settings.m_squelch = value / 10.0;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_audioMute_toggled(bool checked) void DSDDemodGUI::on_audioMute_toggled(bool checked)
{ {
m_audioMute = checked; m_settings.m_audioMute = checked;
applySettings(); applySettings();
} }
@ -272,11 +289,13 @@ void DSDDemodGUI::on_symbolPLLLock_toggled(bool checked)
} else { } else {
ui->symbolPLLLock->setStyleSheet("QToolButton { background:rgb(53,53,53); }"); ui->symbolPLLLock->setStyleSheet("QToolButton { background:rgb(53,53,53); }");
} }
m_settings.m_pllLock = checked;
applySettings(); applySettings();
} }
void DSDDemodGUI::on_udpOutput_toggled(bool checked __attribute__((unused))) void DSDDemodGUI::on_udpOutput_toggled(bool checked)
{ {
m_settings.m_udpCopyAudio = checked;
applySettings(); applySettings();
} }
@ -352,7 +371,11 @@ DSDDemodGUI::DSDDemodGUI(PluginAPI* pluginAPI, DeviceSourceAPI *deviceAPI, QWidg
ui->scopeGUI->setBuddies(m_scopeVis->getInputMessageQueue(), m_scopeVis, ui->glScope); ui->scopeGUI->setBuddies(m_scopeVis->getInputMessageQueue(), m_scopeVis, ui->glScope);
m_settings.setChannelMarker(&m_channelMarker);
m_settings.setScopeGUI(ui->scopeGUI);
updateMyPosition(); updateMyPosition();
displaySettings();
displayUDPAddress(); displayUDPAddress();
applySettings(true); applySettings(true);
} }
@ -382,46 +405,91 @@ void DSDDemodGUI::displayUDPAddress()
ui->udpOutput->setToolTip(QString("Copy audio output to UDP %1:%2").arg(m_channelMarker.getUDPAddress()).arg(m_channelMarker.getUDPSendPort())); ui->udpOutput->setToolTip(QString("Copy audio output to UDP %1:%2").arg(m_channelMarker.getUDPAddress()).arg(m_channelMarker.getUDPSendPort()));
} }
void DSDDemodGUI::displaySettings()
{
blockApplySettings(true);
m_channelMarker.blockSignals(true);
m_channelMarker.setCenterFrequency(m_settings.m_inputFrequencyOffset);
m_channelMarker.setUDPAddress(m_settings.m_udpAddress);
m_channelMarker.setUDPSendPort(m_settings.m_udpPort);
m_channelMarker.setColor(m_settings.m_rgbColor);
this->setWindowTitle(m_channelMarker.getTitle());
setTitleColor(m_settings.m_rgbColor);
m_channelMarker.blockSignals(false);
ui->deltaFrequency->setValue(m_channelMarker.getCenterFrequency());
ui->rfBW->setValue(m_settings.m_rfBandwidth / 100.0);
ui->rfBWText->setText(QString("%1k").arg(ui->rfBW->value() / 10.0, 0, 'f', 1));
ui->fmDeviation->setValue(m_settings.m_fmDeviation / 100.0);
ui->fmDeviationText->setText(QString("%1k").arg(ui->fmDeviation->value() / 10.0, 0, 'f', 1));
ui->squelch->setValue(m_settings.m_squelch * 10.0);
ui->squelchText->setText(QString("%1").arg(ui->squelch->value() / 10.0, 0, 'f', 1));
ui->squelchGate->setValue(m_settings.m_squelchGate);
ui->squelchGateText->setText(QString("%1").arg(ui->squelchGate->value() * 10.0, 0, 'f', 0));
ui->demodGain->setValue(m_settings.m_demodGain * 100.0);
ui->demodGainText->setText(QString("%1").arg(ui->demodGain->value() / 100.0, 0, 'f', 2));
ui->volume->setValue(m_settings.m_volume * 10.0);
ui->volumeText->setText(QString("%1").arg(ui->volume->value() / 10.0, 0, 'f', 1));
ui->enableCosineFiltering->setChecked(m_settings.m_enableCosineFiltering);
ui->syncOrConstellation->setChecked(m_settings.m_syncOrConstellation);
ui->slot1On->setChecked(m_settings.m_slot1On);
ui->slot2On->setChecked(m_settings.m_slot2On);
ui->tdmaStereoSplit->setChecked(m_settings.m_tdmaStereo);
ui->audioMute->setChecked(m_settings.m_audioMute);
ui->udpOutput->setChecked(m_settings.m_udpCopyAudio);
ui->symbolPLLLock->setChecked(m_settings.m_pllLock);
ui->baudRate->setCurrentIndex(DSDDemodBaudRates::getRateIndex(m_settings.m_baudRate));
blockApplySettings(false);
}
void DSDDemodGUI::applySettings(bool force) void DSDDemodGUI::applySettings(bool force)
{ {
if (m_doApplySettings) if (m_doApplySettings)
{ {
qDebug() << "DSDDemodGUI::applySettings"; qDebug() << "DSDDemodGUI::applySettings";
setTitleColor(m_channelMarker.getColor());
DSDDemod::MsgConfigureChannelizer* channelConfigMsg = DSDDemod::MsgConfigureChannelizer::create( DSDDemod::MsgConfigureChannelizer* channelConfigMsg = DSDDemod::MsgConfigureChannelizer::create(
48000, m_channelMarker.getCenterFrequency()); 48000, m_channelMarker.getCenterFrequency());
m_dsdDemod->getInputMessageQueue()->push(channelConfigMsg); m_dsdDemod->getInputMessageQueue()->push(channelConfigMsg);
ui->deltaFrequency->setValue(m_channelMarker.getCenterFrequency()); // ui->deltaFrequency->setValue(m_channelMarker.getCenterFrequency());
ui->rfBWText->setText(QString("%1k").arg(ui->rfBW->value() / 10.0, 0, 'f', 1)); // ui->rfBWText->setText(QString("%1k").arg(ui->rfBW->value() / 10.0, 0, 'f', 1));
ui->demodGainText->setText(QString("%1").arg(ui->demodGain->value() / 100.0, 0, 'f', 2)); // ui->demodGainText->setText(QString("%1").arg(ui->demodGain->value() / 100.0, 0, 'f', 2));
ui->fmDeviationText->setText(QString("%1k").arg(ui->fmDeviation->value() / 10.0, 0, 'f', 1)); // ui->fmDeviationText->setText(QString("%1k").arg(ui->fmDeviation->value() / 10.0, 0, 'f', 1));
ui->squelchGateText->setText(QString("%1").arg(ui->squelchGate->value() * 10.0, 0, 'f', 0)); // ui->squelchGateText->setText(QString("%1").arg(ui->squelchGate->value() * 10.0, 0, 'f', 0));
ui->volumeText->setText(QString("%1").arg(ui->volume->value() / 10.0, 0, 'f', 1)); // ui->volumeText->setText(QString("%1").arg(ui->volume->value() / 10.0, 0, 'f', 1));
ui->enableCosineFiltering->setChecked(m_enableCosineFiltering); // ui->enableCosineFiltering->setChecked(m_enableCosineFiltering);
ui->syncOrConstellation->setChecked(m_syncOrConstellation); // ui->syncOrConstellation->setChecked(m_syncOrConstellation);
ui->slot1On->setChecked(m_slot1On); // ui->slot1On->setChecked(m_slot1On);
ui->slot2On->setChecked(m_slot2On); // ui->slot2On->setChecked(m_slot2On);
ui->tdmaStereoSplit->setChecked(m_tdmaStereo); // ui->tdmaStereoSplit->setChecked(m_tdmaStereo);
m_dsdDemod->configure(m_dsdDemod->getInputMessageQueue(), m_dsdDemod->configure(m_dsdDemod->getInputMessageQueue(),
ui->rfBW->value() * 100.0, m_settings.m_rfBandwidth,
ui->fmDeviation->value() * 100.0, m_settings.m_fmDeviation,
ui->demodGain->value() / 100.0, m_settings.m_demodGain,
ui->volume->value() / 10.0, m_settings.m_volume,
DSDDemodBaudRates::getRate(ui->baudRate->currentIndex()), DSDDemodBaudRates::getRate(ui->baudRate->currentIndex()),
ui->squelchGate->value(), // in 10ths of ms m_settings.m_squelchGate, // in 10ths of ms
ui->squelch->value() / 10.0, m_settings.m_squelch,
ui->audioMute->isChecked(), m_settings.m_audioMute,
m_enableCosineFiltering, m_settings.m_enableCosineFiltering,
m_syncOrConstellation, m_settings.m_syncOrConstellation,
m_slot1On, m_settings.m_slot1On,
m_slot2On, m_settings.m_slot2On,
m_tdmaStereo, m_settings.m_tdmaStereo,
ui->symbolPLLLock->isChecked(), m_settings.m_pllLock,
ui->udpOutput->isChecked(), m_settings.m_udpCopyAudio,
m_channelMarker.getUDPAddress(), m_channelMarker.getUDPAddress(),
m_channelMarker.getUDPSendPort(), m_channelMarker.getUDPSendPort(),
force); force);

View File

@ -27,6 +27,8 @@
#include "dsp/movingaverage.h" #include "dsp/movingaverage.h"
#include "util/messagequeue.h" #include "util/messagequeue.h"
#include "dsddemodsettings.h"
class PluginAPI; class PluginAPI;
class DeviceSourceAPI; class DeviceSourceAPI;
@ -94,6 +96,7 @@ private:
PluginAPI* m_pluginAPI; PluginAPI* m_pluginAPI;
DeviceSourceAPI* m_deviceAPI; DeviceSourceAPI* m_deviceAPI;
ChannelMarker m_channelMarker; ChannelMarker m_channelMarker;
DSDDemodSettings m_settings;
bool m_doApplySettings; bool m_doApplySettings;
char m_formatStatusText[82+1]; //!< Fixed signal format dependent status text char m_formatStatusText[82+1]; //!< Fixed signal format dependent status text
SignalFormat m_signalFormat; SignalFormat m_signalFormat;
@ -120,6 +123,7 @@ private:
void blockApplySettings(bool block); void blockApplySettings(bool block);
void applySettings(bool force = false); void applySettings(bool force = false);
void displaySettings();
void updateMyPosition(); void updateMyPosition();
void displayUDPAddress(); void displayUDPAddress();