Skip to content

Commit

Permalink
Following PR #1305: set device center frequency from the MainWindow r…
Browse files Browse the repository at this point in the history
…ather than in MainSpectrumGUI
  • Loading branch information
f4exb committed Jun 24, 2022
1 parent 1638814 commit f95d0e4
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 3 deletions.
4 changes: 1 addition & 3 deletions sdrgui/mainspectrum/mainspectrumgui.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@
#include "gui/glspectrumgui.h"
#include "gui/workspaceselectiondialog.h"
#include "dsp/spectrumvis.h"
#include "channel/channelwebapiutils.h"
#include "mainspectrumgui.h"

MainSpectrumGUI::MainSpectrumGUI(GLSpectrum *spectrum, GLSpectrumGUI *spectrumGUI, QWidget *parent) :
Expand Down Expand Up @@ -324,6 +323,5 @@ QString MainSpectrumGUI::getDeviceTypeTag()
// Handle request from GLSpectrum to adjust center frequency
void MainSpectrumGUI::onRequestCenterFrequency(qint64 frequency)
{
double frequencyInHz = (double)frequency;
ChannelWebAPIUtils::setCenterFrequency(m_deviceSetIndex, frequencyInHz);
emit requestCenterFrequency(m_deviceSetIndex, frequency);
}
1 change: 1 addition & 0 deletions sdrgui/mainspectrum/mainspectrumgui.h
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,7 @@ private slots:
void closing();
void moveToWorkspace(int workspaceIndex);
void forceShrink();
void requestCenterFrequency(int deviceSetIndex, qint64 frequency); // an action from the user to move device center frequency
};


Expand Down
27 changes: 27 additions & 0 deletions sdrgui/mainwindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -319,6 +319,13 @@ void MainWindow::sampleSourceAdd(Workspace *deviceWorkspace, Workspace *spectrum
[=](int channelPluginIndex){ this->channelAddClicked(deviceWorkspace, deviceSetIndex, channelPluginIndex); }
);

QObject::connect(
mainSpectrumGUI,
&MainSpectrumGUI::requestCenterFrequency,
this,
&MainWindow::mainSpectrumRequestDeviceCenterFrequency
);

deviceWorkspace->addToMdiArea(m_deviceUIs.back()->m_deviceGUI);
spectrumWorkspace->addToMdiArea(m_deviceUIs.back()->m_mainSpectrumGUI);
emit m_mainCore->deviceSetAdded(deviceSetIndex, deviceAPI);
Expand Down Expand Up @@ -535,6 +542,13 @@ void MainWindow::sampleSinkAdd(Workspace *deviceWorkspace, Workspace *spectrumWo
[=](int channelPluginIndex){ this->channelAddClicked(deviceWorkspace, deviceSetIndex, channelPluginIndex); }
);

QObject::connect(
mainSpectrumGUI,
&MainSpectrumGUI::requestCenterFrequency,
this,
&MainWindow::mainSpectrumRequestDeviceCenterFrequency
);

deviceWorkspace->addToMdiArea(m_deviceUIs.back()->m_deviceGUI);
spectrumWorkspace->addToMdiArea(m_deviceUIs.back()->m_mainSpectrumGUI);
emit m_mainCore->deviceSetAdded(deviceSetIndex, deviceAPI);
Expand Down Expand Up @@ -2666,6 +2680,19 @@ void MainWindow::mainSpectrumShow(int deviceSetIndex)
deviceUISet->m_mainSpectrumGUI->raise();
}

void MainWindow::mainSpectrumRequestDeviceCenterFrequency(int deviceSetIndex, qint64 deviceCenterFrequency)
{
DeviceUISet *deviceUISet = m_deviceUIs[deviceSetIndex];
DeviceAPI *deviceAPI = deviceUISet->m_deviceAPI;

if (deviceAPI->getSampleSource()) {
deviceAPI->getSampleSource()->setCenterFrequency(deviceCenterFrequency);
} else if (deviceAPI->getSampleSink()) {
deviceAPI->getSampleSink()->setCenterFrequency(deviceCenterFrequency);
}
// Not implemented for MIMO
}

void MainWindow::showAllChannels(int deviceSetIndex)
{
DeviceUISet *deviceUISet = m_deviceUIs[deviceSetIndex];
Expand Down
1 change: 1 addition & 0 deletions sdrgui/mainwindow.h
Original file line number Diff line number Diff line change
Expand Up @@ -207,6 +207,7 @@ private slots:
void deviceMove(DeviceGUI *gui, int wsIndexDestnation);
void mainSpectrumMove(MainSpectrumGUI *gui, int wsIndexDestnation);
void mainSpectrumShow(int deviceSetIndex);
void mainSpectrumRequestDeviceCenterFrequency(int deviceSetIndex, qint64 deviceCenterFrequency);
void showAllChannels(int deviceSetIndex);
void openDeviceSetPresetsDialog(QPoint p, DeviceGUI *deviceGUI);
void commandKeyPressed(Qt::Key key, Qt::KeyboardModifiers keyModifiers, bool release);
Expand Down

0 comments on commit f95d0e4

Please sign in to comment.