PlutoSDR output: use settings in GUI (1)

This commit is contained in:
f4exb 2017-10-10 06:59:13 +02:00
parent 1ae75824ac
commit 0b7f62866f
4 changed files with 124 additions and 83 deletions

View File

@ -68,83 +68,75 @@ void AMModGUI::setCenterFrequency(qint64 centerFrequency)
void AMModGUI::resetToDefaults() void AMModGUI::resetToDefaults()
{ {
blockApplySettings(true); m_settings.resetToDefaults();
displaySettings();
ui->rfBW->setValue(50); applySettings(true);
ui->modPercent->setValue(20);
ui->volume->setValue(10);
ui->toneFrequency->setValue(100);
ui->deltaFrequency->setValue(0);
blockApplySettings(false);
applySettings();
} }
QByteArray AMModGUI::serialize() const QByteArray AMModGUI::serialize() const
{ {
SimpleSerializer s(1); return m_settings.serialize();
s.writeS32(1, m_channelMarker.getCenterFrequency());
s.writeS32(2, ui->rfBW->value());
s.writeS32(3, ui->toneFrequency->value());
s.writeS32(4, ui->modPercent->value());
s.writeU32(5, m_channelMarker.getColor().rgb());
s.writeS32(6, ui->volume->value());
s.writeBlob(7, ui->cwKeyerGUI->serialize());
return s.final();
} }
bool AMModGUI::deserialize(const QByteArray& data) bool AMModGUI::deserialize(const QByteArray& data)
{ {
SimpleDeserializer d(data); if(m_settings.deserialize(data)) {
displaySettings();
if(!d.isValid()) applySettings(true);
{
resetToDefaults();
return false;
}
if(d.getVersion() == 1)
{
QByteArray bytetmp;
quint32 u32tmp;
qint32 tmp;
blockApplySettings(true);
m_channelMarker.blockSignals(true);
d.readS32(1, &tmp, 0);
m_channelMarker.setCenterFrequency(tmp);
d.readS32(2, &tmp, 4);
ui->rfBW->setValue(tmp);
d.readS32(3, &tmp, 100);
ui->toneFrequency->setValue(tmp);
d.readS32(4, &tmp, 20);
ui->modPercent->setValue(tmp);
if(d.readU32(5, &u32tmp))
{
m_channelMarker.setColor(u32tmp);
}
d.readS32(6, &tmp, 10);
ui->volume->setValue(tmp);
d.readBlob(7, &bytetmp);
ui->cwKeyerGUI->deserialize(bytetmp);
blockApplySettings(false);
m_channelMarker.blockSignals(false);
applySettings();
return true; return true;
} } else {
else
{
resetToDefaults(); resetToDefaults();
return false; return false;
} }
// SimpleDeserializer d(data);
//
// if(!d.isValid())
// {
// resetToDefaults();
// return false;
// }
//
// if(d.getVersion() == 1)
// {
// QByteArray bytetmp;
// quint32 u32tmp;
// qint32 tmp;
//
// blockApplySettings(true);
// m_channelMarker.blockSignals(true);
//
// d.readS32(1, &tmp, 0);
// m_channelMarker.setCenterFrequency(tmp);
// d.readS32(2, &tmp, 4);
// ui->rfBW->setValue(tmp);
// d.readS32(3, &tmp, 100);
// ui->toneFrequency->setValue(tmp);
// d.readS32(4, &tmp, 20);
// ui->modPercent->setValue(tmp);
//
// if(d.readU32(5, &u32tmp))
// {
// m_channelMarker.setColor(u32tmp);
// }
//
// d.readS32(6, &tmp, 10);
// ui->volume->setValue(tmp);
//
// d.readBlob(7, &bytetmp);
// ui->cwKeyerGUI->deserialize(bytetmp);
//
// blockApplySettings(false);
// m_channelMarker.blockSignals(false);
//
// applySettings();
// return true;
// }
// else
// {
// resetToDefaults();
// return false;
// }
} }
bool AMModGUI::handleMessage(const Message& message) bool AMModGUI::handleMessage(const Message& message)
@ -190,11 +182,14 @@ void AMModGUI::handleSourceMessages()
void AMModGUI::on_deltaFrequency_changed(qint64 value) void AMModGUI::on_deltaFrequency_changed(qint64 value)
{ {
m_channelMarker.setCenterFrequency(value); m_channelMarker.setCenterFrequency(value);
m_settings.m_inputFrequencyOffset = m_channelMarker.getCenterFrequency();
applySettings();
} }
void AMModGUI::on_rfBW_valueChanged(int value) void AMModGUI::on_rfBW_valueChanged(int value)
{ {
ui->rfBWText->setText(QString("%1 kHz").arg(value / 10.0, 0, 'f', 1)); ui->rfBWText->setText(QString("%1 kHz").arg(value / 10.0, 0, 'f', 1));
m_settings.m_rfBandwidth = value * 100.0;
m_channelMarker.setBandwidth(value * 100); m_channelMarker.setBandwidth(value * 100);
applySettings(); applySettings();
} }
@ -202,29 +197,34 @@ void AMModGUI::on_rfBW_valueChanged(int value)
void AMModGUI::on_modPercent_valueChanged(int value) void AMModGUI::on_modPercent_valueChanged(int value)
{ {
ui->modPercentText->setText(QString("%1").arg(value)); ui->modPercentText->setText(QString("%1").arg(value));
m_settings.m_modFactor = value / 100.0;
applySettings(); applySettings();
} }
void AMModGUI::on_volume_valueChanged(int value) void AMModGUI::on_volume_valueChanged(int value)
{ {
ui->volumeText->setText(QString("%1").arg(value / 10.0, 0, 'f', 1)); ui->volumeText->setText(QString("%1").arg(value / 10.0, 0, 'f', 1));
m_settings.m_volumeFactor = value / 10.0;
applySettings(); applySettings();
} }
void AMModGUI::on_toneFrequency_valueChanged(int value) void AMModGUI::on_toneFrequency_valueChanged(int value)
{ {
ui->toneFrequencyText->setText(QString("%1k").arg(value / 100.0, 0, 'f', 2)); ui->toneFrequencyText->setText(QString("%1k").arg(value / 100.0, 0, 'f', 2));
m_settings.m_toneFrequency = value * 10.0;
applySettings(); applySettings();
} }
void AMModGUI::on_channelMute_toggled(bool checked __attribute__((unused))) void AMModGUI::on_channelMute_toggled(bool checked)
{ {
m_settings.m_channelMute = checked;
applySettings(); applySettings();
} }
void AMModGUI::on_playLoop_toggled(bool checked __attribute__((unused))) void AMModGUI::on_playLoop_toggled(bool checked)
{ {
m_settings.m_playLoop = checked;
applySettings(); applySettings();
} }
@ -357,6 +357,9 @@ AMModGUI::AMModGUI(PluginAPI* pluginAPI, DeviceSinkAPI *deviceAPI, QWidget* pare
m_channelMarker.setCenterFrequency(0); m_channelMarker.setCenterFrequency(0);
m_channelMarker.setVisible(true); m_channelMarker.setVisible(true);
m_settings.setChannelMarker(&m_channelMarker);
m_settings.setCWKeyerGUI(ui->cwKeyerGUI);
connect(&m_channelMarker, SIGNAL(changed()), this, SLOT(viewChanged())); connect(&m_channelMarker, SIGNAL(changed()), this, SLOT(viewChanged()));
m_deviceAPI->registerChannelInstance(m_channelID, this); m_deviceAPI->registerChannelInstance(m_channelID, this);
@ -393,7 +396,7 @@ void AMModGUI::blockApplySettings(bool block)
m_doApplySettings = !block; m_doApplySettings = !block;
} }
void AMModGUI::applySettings() void AMModGUI::applySettings(bool force __attribute((unused)))
{ {
if (m_doApplySettings) if (m_doApplySettings)
{ {
@ -406,15 +409,46 @@ void AMModGUI::applySettings()
ui->deltaFrequency->setValue(m_channelMarker.getCenterFrequency()); ui->deltaFrequency->setValue(m_channelMarker.getCenterFrequency());
m_amMod->configure(m_amMod->getInputMessageQueue(), m_amMod->configure(m_amMod->getInputMessageQueue(),
ui->rfBW->value() * 100.0, m_settings.m_rfBandwidth,
ui->modPercent->value() / 100.0f, m_settings.m_modFactor,
ui->toneFrequency->value() * 10.0f, m_settings.m_toneFrequency,
ui->volume->value() / 10.0f , m_settings.m_volumeFactor,
ui->channelMute->isChecked(), m_settings.m_channelMute,
ui->playLoop->isChecked()); m_settings.m_playLoop);
} }
} }
void AMModGUI::displaySettings()
{
blockApplySettings(true);
ui->rfBW->setValue(m_settings.m_rfBandwidth / 100.0);
ui->rfBWText->setText(QString("%1 kHz").arg(m_settings.m_rfBandwidth / 1000.0, 0, 'f', 1));
int modPercent = m_settings.m_modFactor * 100.0;
ui->modPercent->setValue(modPercent);
ui->modPercentText->setText(QString("%1").arg(modPercent));
ui->toneFrequency->setValue(m_settings.m_toneFrequency / 10.0);
ui->toneFrequencyText->setText(QString("%1k").arg(m_settings.m_toneFrequency / 1000.0, 0, 'f', 2));
int volume = m_settings.m_volumeFactor * 10.0;
ui->volume->setValue(volume);
ui->volumeText->setText(QString("%1").arg(m_settings.m_volumeFactor, 0, 'f', 1));
ui->channelMute->setChecked(m_settings.m_channelMute);
ui->playLoop->setChecked(m_settings.m_playLoop);
m_channelMarker.blockSignals(true);
m_channelMarker.setCenterFrequency(m_settings.m_inputFrequencyOffset);
m_channelMarker.setBandwidth(m_settings.m_rfBandwidth);
m_channelMarker.setColor(m_settings.m_rgbColor);
setTitleColor(m_settings.m_rgbColor);
m_channelMarker.blockSignals(false);
blockApplySettings(false);
}
void AMModGUI::leaveEvent(QEvent*) void AMModGUI::leaveEvent(QEvent*)
{ {
blockApplySettings(true); blockApplySettings(true);

View File

@ -24,6 +24,7 @@
#include "util/messagequeue.h" #include "util/messagequeue.h"
#include "ammod.h" #include "ammod.h"
#include "ammodsettings.h"
class PluginAPI; class PluginAPI;
class DeviceSinkAPI; class DeviceSinkAPI;
@ -86,6 +87,7 @@ private:
PluginAPI* m_pluginAPI; PluginAPI* m_pluginAPI;
DeviceSinkAPI* m_deviceAPI; DeviceSinkAPI* m_deviceAPI;
ChannelMarker m_channelMarker; ChannelMarker m_channelMarker;
AMModSettings m_settings;
bool m_basicSettingsShown; bool m_basicSettingsShown;
bool m_doApplySettings; bool m_doApplySettings;
@ -107,7 +109,8 @@ private:
virtual ~AMModGUI(); virtual ~AMModGUI();
void blockApplySettings(bool block); void blockApplySettings(bool block);
void applySettings(); void applySettings(bool force = false);
void displaySettings();
void updateWithStreamData(); void updateWithStreamData();
void updateWithStreamTime(); void updateWithStreamTime();

View File

@ -14,13 +14,16 @@
// along with this program. If not, see <http://www.gnu.org/licenses/>. // // along with this program. If not, see <http://www.gnu.org/licenses/>. //
/////////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////////
#include <QColor>
#include "dsp/dspengine.h" #include "dsp/dspengine.h"
#include "util/simpleserializer.h" #include "util/simpleserializer.h"
#include "settings/serializable.h" #include "settings/serializable.h"
#include "ammodsettings.h" #include "ammodsettings.h"
AMModSettings::AMModSettings() : AMModSettings::AMModSettings() :
m_channelMarker(0) m_channelMarker(0),
m_cwKeyerGUI(0)
{ {
resetToDefaults(); resetToDefaults();
} }
@ -37,6 +40,7 @@ void AMModSettings::resetToDefaults()
m_volumeFactor = 1.0f; m_volumeFactor = 1.0f;
m_channelMute = false; m_channelMute = false;
m_playLoop = false; m_playLoop = false;
m_rgbColor = QColor(255, 255, 0).rgb();
} }
QByteArray AMModSettings::serialize() const QByteArray AMModSettings::serialize() const
@ -74,7 +78,6 @@ bool AMModSettings::deserialize(const QByteArray& data)
if(d.getVersion() == 1) if(d.getVersion() == 1)
{ {
QByteArray bytetmp; QByteArray bytetmp;
quint32 u32tmp;
qint32 tmp; qint32 tmp;
d.readS32(1, &tmp, 0); d.readS32(1, &tmp, 0);
@ -84,10 +87,10 @@ bool AMModSettings::deserialize(const QByteArray& data)
d.readS32(3, &tmp, 100); d.readS32(3, &tmp, 100);
m_toneFrequency = tmp * 10; m_toneFrequency = tmp * 10;
d.readS32(4, &tmp, 20); d.readS32(4, &tmp, 20);
m_modFactor = tmp * 100; m_modFactor = tmp / 100.0;
d.readU32(5, &m_rgbColor); d.readU32(5, &m_rgbColor);
d.readS32(6, &tmp, 10); d.readS32(6, &tmp, 10);
m_volumeFactor = tmp * 10.0; m_volumeFactor = tmp / 10.0;
if (m_cwKeyerGUI) { if (m_cwKeyerGUI) {
d.readBlob(7, &bytetmp); d.readBlob(7, &bytetmp);

View File

@ -21,6 +21,7 @@
#include <QWidget> #include <QWidget>
#include "dsp/dsptypes.h" #include "dsp/dsptypes.h"
#include "util/export.h" #include "util/export.h"
#include "settings/serializable.h"
namespace Ui { namespace Ui {
class CWKeyerGUI; class CWKeyerGUI;
@ -29,7 +30,7 @@ namespace Ui {
class MessageQueue; class MessageQueue;
class CWKeyer; class CWKeyer;
class SDRANGEL_API CWKeyerGUI : public QWidget { class SDRANGEL_API CWKeyerGUI : public QWidget, public Serializable {
Q_OBJECT Q_OBJECT
public: public: