mirror of
https://github.com/f4exb/sdrangel.git
synced 2025-03-29 15:48:52 -04:00
HackRF output: implemented transverter mode
This commit is contained in:
parent
f8d367c569
commit
3cf8a2e826
@ -419,19 +419,28 @@ bool HackRFOutput::applySettings(const HackRFOutputSettings& settings, bool forc
|
|||||||
if ((m_settings.m_fcPos != settings.m_fcPos) || force) {
|
if ((m_settings.m_fcPos != settings.m_fcPos) || force) {
|
||||||
reverseAPIKeys.append("fcPos");
|
reverseAPIKeys.append("fcPos");
|
||||||
}
|
}
|
||||||
|
if ((m_settings.m_transverterMode != settings.m_transverterMode) || force) {
|
||||||
|
reverseAPIKeys.append("transverterMode");
|
||||||
|
}
|
||||||
|
if ((m_settings.m_transverterDeltaFrequency != settings.m_transverterDeltaFrequency) || force) {
|
||||||
|
reverseAPIKeys.append("transverterDeltaFrequency");
|
||||||
|
}
|
||||||
|
|
||||||
if ((m_settings.m_centerFrequency != settings.m_centerFrequency) ||
|
if ((m_settings.m_centerFrequency != settings.m_centerFrequency) ||
|
||||||
(m_settings.m_devSampleRate != settings.m_devSampleRate) ||
|
(m_settings.m_devSampleRate != settings.m_devSampleRate) ||
|
||||||
(m_settings.m_LOppmTenths != settings.m_LOppmTenths) ||
|
(m_settings.m_LOppmTenths != settings.m_LOppmTenths) ||
|
||||||
(m_settings.m_log2Interp != settings.m_log2Interp) ||
|
(m_settings.m_log2Interp != settings.m_log2Interp) ||
|
||||||
(m_settings.m_fcPos != settings.m_fcPos) || force)
|
(m_settings.m_fcPos != settings.m_fcPos) ||
|
||||||
|
(m_settings.m_transverterMode != settings.m_transverterMode) ||
|
||||||
|
(m_settings.m_transverterDeltaFrequency != settings.m_transverterDeltaFrequency) || force)
|
||||||
{
|
{
|
||||||
qint64 deviceCenterFrequency = DeviceSampleSink::calculateDeviceCenterFrequency(
|
qint64 deviceCenterFrequency = DeviceSampleSink::calculateDeviceCenterFrequency(
|
||||||
settings.m_centerFrequency,
|
settings.m_centerFrequency,
|
||||||
0,
|
settings.m_transverterDeltaFrequency,
|
||||||
settings.m_log2Interp,
|
settings.m_log2Interp,
|
||||||
(DeviceSampleSink::fcPos_t) settings.m_fcPos,
|
(DeviceSampleSink::fcPos_t) settings.m_fcPos,
|
||||||
settings.m_devSampleRate);
|
settings.m_devSampleRate,
|
||||||
|
m_settings.m_transverterMode);
|
||||||
setDeviceCenterFrequency(deviceCenterFrequency, settings.m_LOppmTenths);
|
setDeviceCenterFrequency(deviceCenterFrequency, settings.m_LOppmTenths);
|
||||||
|
|
||||||
if (m_deviceAPI->getSourceBuddies().size() > 0)
|
if (m_deviceAPI->getSourceBuddies().size() > 0)
|
||||||
@ -611,6 +620,12 @@ void HackRFOutput::webapiUpdateDeviceSettings(
|
|||||||
if (deviceSettingsKeys.contains("lnaExt")) {
|
if (deviceSettingsKeys.contains("lnaExt")) {
|
||||||
settings.m_lnaExt = response.getHackRfOutputSettings()->getLnaExt() != 0;
|
settings.m_lnaExt = response.getHackRfOutputSettings()->getLnaExt() != 0;
|
||||||
}
|
}
|
||||||
|
if (deviceSettingsKeys.contains("transverterDeltaFrequency")) {
|
||||||
|
settings.m_transverterDeltaFrequency = response.getHackRfInputSettings()->getTransverterDeltaFrequency();
|
||||||
|
}
|
||||||
|
if (deviceSettingsKeys.contains("transverterMode")) {
|
||||||
|
settings.m_transverterMode = response.getHackRfInputSettings()->getTransverterMode() != 0;
|
||||||
|
}
|
||||||
if (deviceSettingsKeys.contains("useReverseAPI")) {
|
if (deviceSettingsKeys.contains("useReverseAPI")) {
|
||||||
settings.m_useReverseAPI = response.getHackRfOutputSettings()->getUseReverseApi() != 0;
|
settings.m_useReverseAPI = response.getHackRfOutputSettings()->getUseReverseApi() != 0;
|
||||||
}
|
}
|
||||||
@ -636,6 +651,8 @@ void HackRFOutput::webapiFormatDeviceSettings(SWGSDRangel::SWGDeviceSettings& re
|
|||||||
response.getHackRfOutputSettings()->setDevSampleRate(settings.m_devSampleRate);
|
response.getHackRfOutputSettings()->setDevSampleRate(settings.m_devSampleRate);
|
||||||
response.getHackRfOutputSettings()->setBiasT(settings.m_biasT ? 1 : 0);
|
response.getHackRfOutputSettings()->setBiasT(settings.m_biasT ? 1 : 0);
|
||||||
response.getHackRfOutputSettings()->setLnaExt(settings.m_lnaExt ? 1 : 0);
|
response.getHackRfOutputSettings()->setLnaExt(settings.m_lnaExt ? 1 : 0);
|
||||||
|
response.getHackRfOutputSettings()->setTransverterDeltaFrequency(settings.m_transverterDeltaFrequency);
|
||||||
|
response.getHackRfOutputSettings()->setTransverterMode(settings.m_transverterMode ? 1 : 0);
|
||||||
|
|
||||||
response.getHackRfOutputSettings()->setUseReverseApi(settings.m_useReverseAPI ? 1 : 0);
|
response.getHackRfOutputSettings()->setUseReverseApi(settings.m_useReverseAPI ? 1 : 0);
|
||||||
|
|
||||||
@ -715,6 +732,12 @@ void HackRFOutput::webapiReverseSendSettings(QList<QString>& deviceSettingsKeys,
|
|||||||
if (deviceSettingsKeys.contains("lnaExt") || force) {
|
if (deviceSettingsKeys.contains("lnaExt") || force) {
|
||||||
swgHackRFOutputSettings->setLnaExt(settings.m_lnaExt ? 1 : 0);
|
swgHackRFOutputSettings->setLnaExt(settings.m_lnaExt ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
if (deviceSettingsKeys.contains("transverterDeltaFrequency") || force) {
|
||||||
|
swgHackRFOutputSettings->setTransverterDeltaFrequency(settings.m_transverterDeltaFrequency);
|
||||||
|
}
|
||||||
|
if (deviceSettingsKeys.contains("transverterMode") || force) {
|
||||||
|
swgHackRFOutputSettings->setTransverterMode(settings.m_transverterMode ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
QString deviceSettingsURL = QString("http://%1:%2/sdrangel/deviceset/%3/device/settings")
|
QString deviceSettingsURL = QString("http://%1:%2/sdrangel/deviceset/%3/device/settings")
|
||||||
.arg(settings.m_reverseAPIAddress)
|
.arg(settings.m_reverseAPIAddress)
|
||||||
|
@ -229,6 +229,21 @@ void HackRFOutputGui::displaySampleRate()
|
|||||||
ui->sampleRate->blockSignals(false);
|
ui->sampleRate->blockSignals(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HackRFOutputGui::updateFrequencyLimits()
|
||||||
|
{
|
||||||
|
// values in kHz
|
||||||
|
qint64 deltaFrequency = m_settings.m_transverterMode ? m_settings.m_transverterDeltaFrequency/1000 : 0;
|
||||||
|
qint64 minLimit = (0U) + deltaFrequency;
|
||||||
|
qint64 maxLimit = (7250000U) + deltaFrequency;
|
||||||
|
|
||||||
|
minLimit = minLimit < 0 ? 0 : minLimit > 9999999 ? 9999999 : minLimit;
|
||||||
|
maxLimit = maxLimit < 0 ? 0 : maxLimit > 9999999 ? 9999999 : maxLimit;
|
||||||
|
|
||||||
|
qDebug("HackRFOutputGui::updateFrequencyLimits: delta: %lld min: %lld max: %lld", deltaFrequency, minLimit, maxLimit);
|
||||||
|
|
||||||
|
ui->centerFrequency->setValueRange(7, minLimit, maxLimit);
|
||||||
|
}
|
||||||
|
|
||||||
void HackRFOutputGui::displayFcTooltip()
|
void HackRFOutputGui::displayFcTooltip()
|
||||||
{
|
{
|
||||||
int32_t fShift = DeviceSampleSink::calculateFrequencyShift(
|
int32_t fShift = DeviceSampleSink::calculateFrequencyShift(
|
||||||
@ -386,6 +401,16 @@ void HackRFOutputGui::on_sampleRateMode_toggled(bool checked)
|
|||||||
displaySampleRate();
|
displaySampleRate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HackRFOutputGui::on_transverter_clicked()
|
||||||
|
{
|
||||||
|
m_settings.m_transverterMode = ui->transverter->getDeltaFrequencyAcive();
|
||||||
|
m_settings.m_transverterDeltaFrequency = ui->transverter->getDeltaFrequency();
|
||||||
|
qDebug("HackRFOutputGui::on_transverter_clicked: %lld Hz %s", m_settings.m_transverterDeltaFrequency, m_settings.m_transverterMode ? "on" : "off");
|
||||||
|
updateFrequencyLimits();
|
||||||
|
m_settings.m_centerFrequency = ui->centerFrequency->getValueNew()*1000;
|
||||||
|
sendSettings();
|
||||||
|
}
|
||||||
|
|
||||||
void HackRFOutputGui::updateHardware()
|
void HackRFOutputGui::updateHardware()
|
||||||
{
|
{
|
||||||
if (m_doApplySettings)
|
if (m_doApplySettings)
|
||||||
|
@ -84,6 +84,7 @@ private:
|
|||||||
void displayBandwidths();
|
void displayBandwidths();
|
||||||
void sendSettings();
|
void sendSettings();
|
||||||
void updateSampleRateAndFrequency();
|
void updateSampleRateAndFrequency();
|
||||||
|
void updateFrequencyLimits();
|
||||||
void blockApplySettings(bool block);
|
void blockApplySettings(bool block);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
@ -99,6 +100,7 @@ private slots:
|
|||||||
void on_txvga_valueChanged(int value);
|
void on_txvga_valueChanged(int value);
|
||||||
void on_startStop_toggled(bool checked);
|
void on_startStop_toggled(bool checked);
|
||||||
void on_sampleRateMode_toggled(bool checked);
|
void on_sampleRateMode_toggled(bool checked);
|
||||||
|
void on_transverter_clicked();
|
||||||
void updateHardware();
|
void updateHardware();
|
||||||
void updateStatus();
|
void updateStatus();
|
||||||
void openDeviceSettingsDialog(const QPoint& p);
|
void openDeviceSettingsDialog(const QPoint& p);
|
||||||
|
@ -277,6 +277,22 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="1" column="5">
|
||||||
|
<widget class="TransverterButton" name="transverter">
|
||||||
|
<property name="maximumSize">
|
||||||
|
<size>
|
||||||
|
<width>24</width>
|
||||||
|
<height>24</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Transverter frequency translation dialog</string>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>X</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
@ -552,6 +568,11 @@
|
|||||||
<extends>QToolButton</extends>
|
<extends>QToolButton</extends>
|
||||||
<header>gui/buttonswitch.h</header>
|
<header>gui/buttonswitch.h</header>
|
||||||
</customwidget>
|
</customwidget>
|
||||||
|
<customwidget>
|
||||||
|
<class>TransverterButton</class>
|
||||||
|
<extends>QPushButton</extends>
|
||||||
|
<header>gui/transverterbutton.h</header>
|
||||||
|
</customwidget>
|
||||||
</customwidgets>
|
</customwidgets>
|
||||||
<resources>
|
<resources>
|
||||||
<include location="../../../sdrgui/resources/res.qrc"/>
|
<include location="../../../sdrgui/resources/res.qrc"/>
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
const PluginDescriptor HackRFOutputPlugin::m_pluginDescriptor = {
|
const PluginDescriptor HackRFOutputPlugin::m_pluginDescriptor = {
|
||||||
QString("HackRF Output"),
|
QString("HackRF Output"),
|
||||||
QString("4.11.6"),
|
QString("4.11.8"),
|
||||||
QString("(c) Edouard Griffiths, F4EXB"),
|
QString("(c) Edouard Griffiths, F4EXB"),
|
||||||
QString("https://github.com/f4exb/sdrangel"),
|
QString("https://github.com/f4exb/sdrangel"),
|
||||||
true,
|
true,
|
||||||
|
@ -37,6 +37,8 @@ void HackRFOutputSettings::resetToDefaults()
|
|||||||
m_vgaGain = 22;
|
m_vgaGain = 22;
|
||||||
m_bandwidth = 1750000;
|
m_bandwidth = 1750000;
|
||||||
m_devSampleRate = 2400000;
|
m_devSampleRate = 2400000;
|
||||||
|
m_transverterMode = false;
|
||||||
|
m_transverterDeltaFrequency = 0;
|
||||||
m_useReverseAPI = false;
|
m_useReverseAPI = false;
|
||||||
m_reverseAPIAddress = "127.0.0.1";
|
m_reverseAPIAddress = "127.0.0.1";
|
||||||
m_reverseAPIPort = 8888;
|
m_reverseAPIPort = 8888;
|
||||||
@ -59,6 +61,8 @@ QByteArray HackRFOutputSettings::serialize() const
|
|||||||
s.writeString(10, m_reverseAPIAddress);
|
s.writeString(10, m_reverseAPIAddress);
|
||||||
s.writeU32(11, m_reverseAPIPort);
|
s.writeU32(11, m_reverseAPIPort);
|
||||||
s.writeU32(12, m_reverseAPIDeviceIndex);
|
s.writeU32(12, m_reverseAPIDeviceIndex);
|
||||||
|
s.writeBool(13, m_transverterMode);
|
||||||
|
s.writeS64(14, m_transverterDeltaFrequency);
|
||||||
|
|
||||||
return s.final();
|
return s.final();
|
||||||
}
|
}
|
||||||
@ -99,6 +103,8 @@ bool HackRFOutputSettings::deserialize(const QByteArray& data)
|
|||||||
|
|
||||||
d.readU32(12, &uintval, 0);
|
d.readU32(12, &uintval, 0);
|
||||||
m_reverseAPIDeviceIndex = uintval > 99 ? 99 : uintval;
|
m_reverseAPIDeviceIndex = uintval > 99 ? 99 : uintval;
|
||||||
|
d.readBool(13, &m_transverterMode, false);
|
||||||
|
d.readS64(14, &m_transverterDeltaFrequency, 0);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,8 @@ struct HackRFOutputSettings {
|
|||||||
quint64 m_devSampleRate;
|
quint64 m_devSampleRate;
|
||||||
bool m_biasT;
|
bool m_biasT;
|
||||||
bool m_lnaExt;
|
bool m_lnaExt;
|
||||||
|
bool m_transverterMode;
|
||||||
|
qint64 m_transverterDeltaFrequency;
|
||||||
bool m_useReverseAPI;
|
bool m_useReverseAPI;
|
||||||
QString m_reverseAPIAddress;
|
QString m_reverseAPIAddress;
|
||||||
uint16_t m_reverseAPIPort;
|
uint16_t m_reverseAPIPort;
|
||||||
|
@ -31,6 +31,9 @@
|
|||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string>HackRF</string>
|
<string>HackRF</string>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Transverter frequency translation dialog</string>
|
||||||
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
<property name="spacing">
|
<property name="spacing">
|
||||||
<number>3</number>
|
<number>3</number>
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
|
|
||||||
const PluginDescriptor HackRFInputPlugin::m_pluginDescriptor = {
|
const PluginDescriptor HackRFInputPlugin::m_pluginDescriptor = {
|
||||||
QString("HackRF Input"),
|
QString("HackRF Input"),
|
||||||
QString("4.11.6"),
|
QString("4.11.8"),
|
||||||
QString("(c) Edouard Griffiths, F4EXB"),
|
QString("(c) Edouard Griffiths, F4EXB"),
|
||||||
QString("https://github.com/f4exb/sdrangel"),
|
QString("https://github.com/f4exb/sdrangel"),
|
||||||
true,
|
true,
|
||||||
|
@ -3599,6 +3599,13 @@ margin-bottom: 20px;
|
|||||||
"lnaExt" : {
|
"lnaExt" : {
|
||||||
"type" : "integer"
|
"type" : "integer"
|
||||||
},
|
},
|
||||||
|
"transverterMode" : {
|
||||||
|
"type" : "integer"
|
||||||
|
},
|
||||||
|
"transverterDeltaFrequency" : {
|
||||||
|
"type" : "integer",
|
||||||
|
"format" : "int64"
|
||||||
|
},
|
||||||
"useReverseAPI" : {
|
"useReverseAPI" : {
|
||||||
"type" : "integer",
|
"type" : "integer",
|
||||||
"description" : "Synchronize with reverse API (1 for yes, 0 for no)"
|
"description" : "Synchronize with reverse API (1 for yes, 0 for no)"
|
||||||
@ -28221,7 +28228,7 @@ except ApiException as e:
|
|||||||
</div>
|
</div>
|
||||||
<div id="generator">
|
<div id="generator">
|
||||||
<div class="content">
|
<div class="content">
|
||||||
Generated 2019-08-27T08:26:32.301+02:00
|
Generated 2019-08-28T08:25:28.542+02:00
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -67,6 +67,11 @@ HackRFOutputSettings:
|
|||||||
type: integer
|
type: integer
|
||||||
lnaExt:
|
lnaExt:
|
||||||
type: integer
|
type: integer
|
||||||
|
transverterMode:
|
||||||
|
type: integer
|
||||||
|
transverterDeltaFrequency:
|
||||||
|
type: integer
|
||||||
|
format: int64
|
||||||
useReverseAPI:
|
useReverseAPI:
|
||||||
description: Synchronize with reverse API (1 for yes, 0 for no)
|
description: Synchronize with reverse API (1 for yes, 0 for no)
|
||||||
type: integer
|
type: integer
|
||||||
|
@ -67,6 +67,11 @@ HackRFOutputSettings:
|
|||||||
type: integer
|
type: integer
|
||||||
lnaExt:
|
lnaExt:
|
||||||
type: integer
|
type: integer
|
||||||
|
transverterMode:
|
||||||
|
type: integer
|
||||||
|
transverterDeltaFrequency:
|
||||||
|
type: integer
|
||||||
|
format: int64
|
||||||
useReverseAPI:
|
useReverseAPI:
|
||||||
description: Synchronize with reverse API (1 for yes, 0 for no)
|
description: Synchronize with reverse API (1 for yes, 0 for no)
|
||||||
type: integer
|
type: integer
|
||||||
|
@ -3599,6 +3599,13 @@ margin-bottom: 20px;
|
|||||||
"lnaExt" : {
|
"lnaExt" : {
|
||||||
"type" : "integer"
|
"type" : "integer"
|
||||||
},
|
},
|
||||||
|
"transverterMode" : {
|
||||||
|
"type" : "integer"
|
||||||
|
},
|
||||||
|
"transverterDeltaFrequency" : {
|
||||||
|
"type" : "integer",
|
||||||
|
"format" : "int64"
|
||||||
|
},
|
||||||
"useReverseAPI" : {
|
"useReverseAPI" : {
|
||||||
"type" : "integer",
|
"type" : "integer",
|
||||||
"description" : "Synchronize with reverse API (1 for yes, 0 for no)"
|
"description" : "Synchronize with reverse API (1 for yes, 0 for no)"
|
||||||
@ -28221,7 +28228,7 @@ except ApiException as e:
|
|||||||
</div>
|
</div>
|
||||||
<div id="generator">
|
<div id="generator">
|
||||||
<div class="content">
|
<div class="content">
|
||||||
Generated 2019-08-27T08:26:32.301+02:00
|
Generated 2019-08-28T08:25:28.542+02:00
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -46,6 +46,10 @@ SWGHackRFOutputSettings::SWGHackRFOutputSettings() {
|
|||||||
m_bias_t_isSet = false;
|
m_bias_t_isSet = false;
|
||||||
lna_ext = 0;
|
lna_ext = 0;
|
||||||
m_lna_ext_isSet = false;
|
m_lna_ext_isSet = false;
|
||||||
|
transverter_mode = 0;
|
||||||
|
m_transverter_mode_isSet = false;
|
||||||
|
transverter_delta_frequency = 0L;
|
||||||
|
m_transverter_delta_frequency_isSet = false;
|
||||||
use_reverse_api = 0;
|
use_reverse_api = 0;
|
||||||
m_use_reverse_api_isSet = false;
|
m_use_reverse_api_isSet = false;
|
||||||
reverse_api_address = nullptr;
|
reverse_api_address = nullptr;
|
||||||
@ -80,6 +84,10 @@ SWGHackRFOutputSettings::init() {
|
|||||||
m_bias_t_isSet = false;
|
m_bias_t_isSet = false;
|
||||||
lna_ext = 0;
|
lna_ext = 0;
|
||||||
m_lna_ext_isSet = false;
|
m_lna_ext_isSet = false;
|
||||||
|
transverter_mode = 0;
|
||||||
|
m_transverter_mode_isSet = false;
|
||||||
|
transverter_delta_frequency = 0L;
|
||||||
|
m_transverter_delta_frequency_isSet = false;
|
||||||
use_reverse_api = 0;
|
use_reverse_api = 0;
|
||||||
m_use_reverse_api_isSet = false;
|
m_use_reverse_api_isSet = false;
|
||||||
reverse_api_address = new QString("");
|
reverse_api_address = new QString("");
|
||||||
@ -102,6 +110,8 @@ SWGHackRFOutputSettings::cleanup() {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if(reverse_api_address != nullptr) {
|
if(reverse_api_address != nullptr) {
|
||||||
delete reverse_api_address;
|
delete reverse_api_address;
|
||||||
}
|
}
|
||||||
@ -138,6 +148,10 @@ SWGHackRFOutputSettings::fromJsonObject(QJsonObject &pJson) {
|
|||||||
|
|
||||||
::SWGSDRangel::setValue(&lna_ext, pJson["lnaExt"], "qint32", "");
|
::SWGSDRangel::setValue(&lna_ext, pJson["lnaExt"], "qint32", "");
|
||||||
|
|
||||||
|
::SWGSDRangel::setValue(&transverter_mode, pJson["transverterMode"], "qint32", "");
|
||||||
|
|
||||||
|
::SWGSDRangel::setValue(&transverter_delta_frequency, pJson["transverterDeltaFrequency"], "qint64", "");
|
||||||
|
|
||||||
::SWGSDRangel::setValue(&use_reverse_api, pJson["useReverseAPI"], "qint32", "");
|
::SWGSDRangel::setValue(&use_reverse_api, pJson["useReverseAPI"], "qint32", "");
|
||||||
|
|
||||||
::SWGSDRangel::setValue(&reverse_api_address, pJson["reverseAPIAddress"], "QString", "QString");
|
::SWGSDRangel::setValue(&reverse_api_address, pJson["reverseAPIAddress"], "QString", "QString");
|
||||||
@ -189,6 +203,12 @@ SWGHackRFOutputSettings::asJsonObject() {
|
|||||||
if(m_lna_ext_isSet){
|
if(m_lna_ext_isSet){
|
||||||
obj->insert("lnaExt", QJsonValue(lna_ext));
|
obj->insert("lnaExt", QJsonValue(lna_ext));
|
||||||
}
|
}
|
||||||
|
if(m_transverter_mode_isSet){
|
||||||
|
obj->insert("transverterMode", QJsonValue(transverter_mode));
|
||||||
|
}
|
||||||
|
if(m_transverter_delta_frequency_isSet){
|
||||||
|
obj->insert("transverterDeltaFrequency", QJsonValue(transverter_delta_frequency));
|
||||||
|
}
|
||||||
if(m_use_reverse_api_isSet){
|
if(m_use_reverse_api_isSet){
|
||||||
obj->insert("useReverseAPI", QJsonValue(use_reverse_api));
|
obj->insert("useReverseAPI", QJsonValue(use_reverse_api));
|
||||||
}
|
}
|
||||||
@ -295,6 +315,26 @@ SWGHackRFOutputSettings::setLnaExt(qint32 lna_ext) {
|
|||||||
this->m_lna_ext_isSet = true;
|
this->m_lna_ext_isSet = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
qint32
|
||||||
|
SWGHackRFOutputSettings::getTransverterMode() {
|
||||||
|
return transverter_mode;
|
||||||
|
}
|
||||||
|
void
|
||||||
|
SWGHackRFOutputSettings::setTransverterMode(qint32 transverter_mode) {
|
||||||
|
this->transverter_mode = transverter_mode;
|
||||||
|
this->m_transverter_mode_isSet = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
qint64
|
||||||
|
SWGHackRFOutputSettings::getTransverterDeltaFrequency() {
|
||||||
|
return transverter_delta_frequency;
|
||||||
|
}
|
||||||
|
void
|
||||||
|
SWGHackRFOutputSettings::setTransverterDeltaFrequency(qint64 transverter_delta_frequency) {
|
||||||
|
this->transverter_delta_frequency = transverter_delta_frequency;
|
||||||
|
this->m_transverter_delta_frequency_isSet = true;
|
||||||
|
}
|
||||||
|
|
||||||
qint32
|
qint32
|
||||||
SWGHackRFOutputSettings::getUseReverseApi() {
|
SWGHackRFOutputSettings::getUseReverseApi() {
|
||||||
return use_reverse_api;
|
return use_reverse_api;
|
||||||
@ -367,6 +407,12 @@ SWGHackRFOutputSettings::isSet(){
|
|||||||
if(m_lna_ext_isSet){
|
if(m_lna_ext_isSet){
|
||||||
isObjectUpdated = true; break;
|
isObjectUpdated = true; break;
|
||||||
}
|
}
|
||||||
|
if(m_transverter_mode_isSet){
|
||||||
|
isObjectUpdated = true; break;
|
||||||
|
}
|
||||||
|
if(m_transverter_delta_frequency_isSet){
|
||||||
|
isObjectUpdated = true; break;
|
||||||
|
}
|
||||||
if(m_use_reverse_api_isSet){
|
if(m_use_reverse_api_isSet){
|
||||||
isObjectUpdated = true; break;
|
isObjectUpdated = true; break;
|
||||||
}
|
}
|
||||||
|
@ -69,6 +69,12 @@ public:
|
|||||||
qint32 getLnaExt();
|
qint32 getLnaExt();
|
||||||
void setLnaExt(qint32 lna_ext);
|
void setLnaExt(qint32 lna_ext);
|
||||||
|
|
||||||
|
qint32 getTransverterMode();
|
||||||
|
void setTransverterMode(qint32 transverter_mode);
|
||||||
|
|
||||||
|
qint64 getTransverterDeltaFrequency();
|
||||||
|
void setTransverterDeltaFrequency(qint64 transverter_delta_frequency);
|
||||||
|
|
||||||
qint32 getUseReverseApi();
|
qint32 getUseReverseApi();
|
||||||
void setUseReverseApi(qint32 use_reverse_api);
|
void setUseReverseApi(qint32 use_reverse_api);
|
||||||
|
|
||||||
@ -112,6 +118,12 @@ private:
|
|||||||
qint32 lna_ext;
|
qint32 lna_ext;
|
||||||
bool m_lna_ext_isSet;
|
bool m_lna_ext_isSet;
|
||||||
|
|
||||||
|
qint32 transverter_mode;
|
||||||
|
bool m_transverter_mode_isSet;
|
||||||
|
|
||||||
|
qint64 transverter_delta_frequency;
|
||||||
|
bool m_transverter_delta_frequency_isSet;
|
||||||
|
|
||||||
qint32 use_reverse_api;
|
qint32 use_reverse_api;
|
||||||
bool m_use_reverse_api_isSet;
|
bool m_use_reverse_api_isSet;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user