diff --git a/Desktop_Interface/functiongencontrol.cpp b/Desktop_Interface/functiongencontrol.cpp index 021c1eb5..def19d37 100644 --- a/Desktop_Interface/functiongencontrol.cpp +++ b/Desktop_Interface/functiongencontrol.cpp @@ -10,6 +10,7 @@ ChannelData const& SingleChannelController::getData() const { void SingleChannelController::waveformName(QString newName) { qDebug() << "newName = " << newName; + m_data.waveform = newName; newName.append(".tlw"); int length; @@ -139,12 +140,22 @@ void SingleChannelController::txuartUpdate(int baudRate, std::vector sa m_data.samples.resize(length); m_data.samples = samples; m_data.freq = baudRate/length; - m_data.divisibility = 1; m_data.repeat_forever = false; notifyUpdate(this); } +void SingleChannelController::backup_waveform() +{ + m_data.freq2 = m_data.freq; +} + +void SingleChannelController::restore_waveform() +{ + m_data.freq = m_data.freq2; + waveformName(m_data.waveform); +} + DualChannelController::DualChannelController(QWidget *parent) : QLabel(parent) { @@ -208,6 +219,16 @@ void DualChannelController::txuartUpdate(ChannelID channelID, int baudRate, std: getChannelController(channelID)->txuartUpdate(baudRate, samples); } +void DualChannelController::backup_waveform(ChannelID channelID) +{ + getChannelController(channelID)->backup_waveform(); +} + +void DualChannelController::restore_waveform(ChannelID channelID) +{ + getChannelController(channelID)->restore_waveform(); +} + void DualChannelController::waveformName_CH1(QString newName) { diff --git a/Desktop_Interface/functiongencontrol.h b/Desktop_Interface/functiongencontrol.h index 9ceede6e..bb165020 100644 --- a/Desktop_Interface/functiongencontrol.h +++ b/Desktop_Interface/functiongencontrol.h @@ -24,9 +24,10 @@ enum class ChannelID struct ChannelData { std::vector samples; + QString waveform; bool repeat_forever; int divisibility; - double freq = 1000.0; + double freq = 1000.0, freq2 = 1000.0; double amplitude = 0.0; double offset = 0.0; }; @@ -49,6 +50,8 @@ public slots: void amplitudeUpdate(double newAmplitude); void offsetUpdate(double newOffset); void txuartUpdate(int baudRate, std::vector samples); + void backup_waveform(); + void restore_waveform(); private: ChannelData m_data; @@ -63,6 +66,8 @@ class DualChannelController : public QLabel public: SingleChannelController* getChannelController(ChannelID channelID); void txuartUpdate(ChannelID channelID, int baudRate, std::vector samples); + void backup_waveform(ChannelID channelID); + void restore_waveform(ChannelID channelID); signals: void functionGenToUpdate(ChannelID channel, SingleChannelController* fGenControl); diff --git a/Desktop_Interface/mainwindow.cpp b/Desktop_Interface/mainwindow.cpp index 7cb35dcb..270a6bb6 100644 --- a/Desktop_Interface/mainwindow.cpp +++ b/Desktop_Interface/mainwindow.cpp @@ -2639,8 +2639,12 @@ void MainWindow::on_serialEncodingCheck_CH1_toggled(bool checked) std::vector data; // If uart encoding is enabled + using functionGen::ChannelID; if(checked) { + // Backup waveform on CH1 + ui->controller_fg->backup_waveform(ChannelID::CH1); + // Enable uart decoding ui->serialDecodingCheck_CH1->setChecked(true); @@ -2653,9 +2657,13 @@ void MainWindow::on_serialEncodingCheck_CH1_toggled(bool checked) data = uartEncode("\r\n", parity_CH1); // Transmit txuart data - using functionGen::ChannelID; ui->controller_fg->txuartUpdate(ChannelID::CH1, baudRate_CH1, data); } + else + { + // Restore waveform on CH1 + ui->controller_fg->restore_waveform(ChannelID::CH1); + } } void MainWindow::on_txuart_textChanged()