Skip to content

Commit

Permalink
IQ tool: disable unused controls when recording/playback is in progress.
Browse files Browse the repository at this point in the history
Changing IO devices and loading/saving settings does not look like good thing
to do while recording/playing an IQ file.
Disable seek slider during recording as it has no function in this
state.
Disable file list and directory selector during recording/playback.
  • Loading branch information
vladisslav2011 committed Nov 17, 2022
1 parent 53bd3c5 commit 8ebe190
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 11 deletions.
10 changes: 10 additions & 0 deletions src/applications/gqrx/mainwindow.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1552,6 +1552,8 @@ void MainWindow::startIqRecording(const QString& recdir)
toString("%1/gqrx_yyyyMMdd_hhmmss_%2_%3_fc.'raw'")
.arg(recdir).arg(freq).arg(sr/dec);

ui->actionIoConfig->setDisabled(true);
ui->actionLoadSettings->setDisabled(true);
// start recorder; fails if recording already in progress
if (rx->start_iq_recording(lastRec.toStdString()))
{
Expand Down Expand Up @@ -1582,6 +1584,8 @@ void MainWindow::stopIqRecording()
ui->statusBar->showMessage(tr("Error stopping I/Q recoder"));
else
ui->statusBar->showMessage(tr("I/Q data recoding stopped"), 5000);
ui->actionIoConfig->setDisabled(false);
ui->actionLoadSettings->setDisabled(false);
}

void MainWindow::startIqPlayback(const QString& filename, float samprate, qint64 center_freq)
Expand Down Expand Up @@ -1624,6 +1628,9 @@ void MainWindow::startIqPlayback(const QString& filename, float samprate, qint64

// FIXME: would be nice with good/bad status
ui->statusBar->showMessage(tr("Playing %1").arg(filename));
ui->actionIoConfig->setDisabled(true);
ui->actionLoadSettings->setDisabled(true);
ui->actionSaveSettings->setDisabled(true);

on_actionDSP_triggered(true);
}
Expand All @@ -1637,6 +1644,9 @@ void MainWindow::stopIqPlayback()
}

ui->statusBar->showMessage(tr("I/Q playback stopped"), 5000);
ui->actionIoConfig->setDisabled(false);
ui->actionLoadSettings->setDisabled(false);
ui->actionSaveSettings->setDisabled(false);

// restore original input device
auto indev = m_settings->value("input/device", "").toString();
Expand Down
31 changes: 20 additions & 11 deletions src/qtgui/iq_tool.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,20 @@ void CIqTool::on_listWidget_currentTextChanged(const QString &currentText)

}

/*! \brief Show/hide/enable/disable GUI controls */

void CIqTool::switchControlsState(enum IqToolState state)
{
ui->recButton->setEnabled(state != playing);

ui->playButton->setEnabled(state != recording);
ui->slider->setEnabled(state != recording);

ui->listWidget->setEnabled(state == idle);
ui->recDirEdit->setEnabled(state == idle);
ui->recDirButton->setEnabled(state == idle);
}

/*! \brief Start/stop playback */
void CIqTool::on_playButton_clicked(bool checked)
{
Expand All @@ -126,17 +140,15 @@ void CIqTool::on_playButton_clicked(bool checked)
}
else
{
ui->listWidget->setEnabled(false);
ui->recButton->setEnabled(false);
switchControlsState(playing);
emit startPlayback(recdir->absoluteFilePath(current_file),
(float)sample_rate, center_freq);
}
}
else
{
emit stopPlayback();
ui->listWidget->setEnabled(true);
ui->recButton->setEnabled(true);
switchControlsState(idle);
ui->slider->setValue(0);
}
}
Expand All @@ -149,9 +161,7 @@ void CIqTool::on_playButton_clicked(bool checked)
*/
void CIqTool::cancelPlayback()
{
ui->playButton->setChecked(false);
ui->listWidget->setEnabled(true);
ui->recButton->setEnabled(true);
switchControlsState(idle);
is_playing = false;
}

Expand All @@ -173,15 +183,15 @@ void CIqTool::on_recButton_clicked(bool checked)

if (checked)
{
ui->playButton->setEnabled(false);
switchControlsState(recording);
emit startRecording(recdir->path());

refreshDir();
ui->listWidget->setCurrentRow(ui->listWidget->count()-1);
}
else
{
ui->playButton->setEnabled(true);
switchControlsState(idle);
emit stopRecording();
}
}
Expand All @@ -196,8 +206,7 @@ void CIqTool::on_recButton_clicked(bool checked)
*/
void CIqTool::cancelRecording()
{
ui->recButton->setChecked(false);
ui->playButton->setEnabled(true);
switchControlsState(idle);
is_recording = false;
}

Expand Down
7 changes: 7 additions & 0 deletions src/qtgui/iq_tool.h
Original file line number Diff line number Diff line change
Expand Up @@ -82,9 +82,16 @@ private slots:
void timeoutFunction(void);

private:
enum IqToolState
{
idle = 0,
playing,
recording
};
void refreshDir(void);
void refreshTimeWidgets(void);
void parseFileName(const QString &filename);
void switchControlsState(enum IqToolState state);

private:
Ui::CIqTool *ui;
Expand Down

0 comments on commit 8ebe190

Please sign in to comment.