mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-10-01 01:06:35 -04:00
PlutoSDR output: use settings in GUI (1)
This commit is contained in:
parent
1ae75824ac
commit
0b7f62866f
@ -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();
|
||||||
|
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)
|
||||||
quint32 u32tmp;
|
// {
|
||||||
qint32 tmp;
|
// QByteArray bytetmp;
|
||||||
|
// quint32 u32tmp;
|
||||||
blockApplySettings(true);
|
// qint32 tmp;
|
||||||
m_channelMarker.blockSignals(true);
|
//
|
||||||
|
// blockApplySettings(true);
|
||||||
d.readS32(1, &tmp, 0);
|
// m_channelMarker.blockSignals(true);
|
||||||
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, 100);
|
// d.readS32(2, &tmp, 4);
|
||||||
ui->toneFrequency->setValue(tmp);
|
// ui->rfBW->setValue(tmp);
|
||||||
d.readS32(4, &tmp, 20);
|
// d.readS32(3, &tmp, 100);
|
||||||
ui->modPercent->setValue(tmp);
|
// ui->toneFrequency->setValue(tmp);
|
||||||
|
// d.readS32(4, &tmp, 20);
|
||||||
if(d.readU32(5, &u32tmp))
|
// ui->modPercent->setValue(tmp);
|
||||||
{
|
//
|
||||||
m_channelMarker.setColor(u32tmp);
|
// if(d.readU32(5, &u32tmp))
|
||||||
}
|
// {
|
||||||
|
// m_channelMarker.setColor(u32tmp);
|
||||||
d.readS32(6, &tmp, 10);
|
// }
|
||||||
ui->volume->setValue(tmp);
|
//
|
||||||
|
// d.readS32(6, &tmp, 10);
|
||||||
d.readBlob(7, &bytetmp);
|
// ui->volume->setValue(tmp);
|
||||||
ui->cwKeyerGUI->deserialize(bytetmp);
|
//
|
||||||
|
// d.readBlob(7, &bytetmp);
|
||||||
blockApplySettings(false);
|
// ui->cwKeyerGUI->deserialize(bytetmp);
|
||||||
m_channelMarker.blockSignals(false);
|
//
|
||||||
|
// blockApplySettings(false);
|
||||||
applySettings();
|
// m_channelMarker.blockSignals(false);
|
||||||
return true;
|
//
|
||||||
}
|
// applySettings();
|
||||||
else
|
// return true;
|
||||||
{
|
// }
|
||||||
resetToDefaults();
|
// else
|
||||||
return false;
|
// {
|
||||||
}
|
// 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);
|
||||||
|
@ -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();
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user