Moved auto sync experiment into the timing tab
This commit is contained in:
		
							parent
							
								
									1b6a4dd301
								
							
						
					
					
						commit
						9728fe52c2
					
				| @ -1022,11 +1022,6 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | |||||||
|   if(!JS8_ENABLE_JS8I){ |   if(!JS8_ENABLE_JS8I){ | ||||||
|       ui->actionModeJS8Ultra->setVisible(false); |       ui->actionModeJS8Ultra->setVisible(false); | ||||||
|   } |   } | ||||||
|   if(!JS8_AUTO_SYNC){ |  | ||||||
|       ui->actionModeAutoSync->setVisible(false); |  | ||||||
|       ui->actionModeAutoSync->setEnabled(false); |  | ||||||
|       ui->actionModeAutoSync->setChecked(false); |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   // prep
 |   // prep
 | ||||||
|   prepareMonitorControls(); |   prepareMonitorControls(); | ||||||
| @ -2275,7 +2270,6 @@ void MainWindow::writeSettings() | |||||||
|   m_settings->setValue("SubModeHB", ui->actionModeJS8HB->isChecked()); |   m_settings->setValue("SubModeHB", ui->actionModeJS8HB->isChecked()); | ||||||
|   m_settings->setValue("SubModeHBAck", ui->actionHeartbeatAcknowledgements->isChecked()); |   m_settings->setValue("SubModeHBAck", ui->actionHeartbeatAcknowledgements->isChecked()); | ||||||
|   m_settings->setValue("SubModeMultiDecode", ui->actionModeMultiDecoder->isChecked()); |   m_settings->setValue("SubModeMultiDecode", ui->actionModeMultiDecoder->isChecked()); | ||||||
|   m_settings->setValue("SubModeAutoSync", ui->actionModeAutoSync->isChecked()); |  | ||||||
|   m_settings->setValue("DTtol",m_DTtol); |   m_settings->setValue("DTtol",m_DTtol); | ||||||
|   m_settings->setValue("Ftol", ui->sbFtol->value ()); |   m_settings->setValue("Ftol", ui->sbFtol->value ()); | ||||||
|   m_settings->setValue("MinSync",m_minSync); |   m_settings->setValue("MinSync",m_minSync); | ||||||
| @ -2432,7 +2426,6 @@ void MainWindow::readSettings() | |||||||
|   ui->actionModeJS8HB->setChecked(m_settings->value("SubModeHB", false).toBool()); |   ui->actionModeJS8HB->setChecked(m_settings->value("SubModeHB", false).toBool()); | ||||||
|   ui->actionHeartbeatAcknowledgements->setChecked(m_settings->value("SubModeHBAck", false).toBool()); |   ui->actionHeartbeatAcknowledgements->setChecked(m_settings->value("SubModeHBAck", false).toBool()); | ||||||
|   ui->actionModeMultiDecoder->setChecked(m_settings->value("SubModeMultiDecode", true).toBool()); |   ui->actionModeMultiDecoder->setChecked(m_settings->value("SubModeMultiDecode", true).toBool()); | ||||||
|   ui->actionModeAutoSync->setChecked(m_settings->value("SubModeAutoSync", false).toBool()); |  | ||||||
| 
 | 
 | ||||||
|   ui->sbFtol->setValue (m_settings->value("Ftol", 20).toInt()); |   ui->sbFtol->setValue (m_settings->value("Ftol", 20).toInt()); | ||||||
|   m_minSync=m_settings->value("MinSync",0).toInt(); |   m_minSync=m_settings->value("MinSync",0).toInt(); | ||||||
| @ -4498,7 +4491,7 @@ bool MainWindow::decodeEnqueueReadyExperiment(qint32 k, qint32 /*k0*/){ | |||||||
|     bool multi = ui->actionModeMultiDecoder->isChecked(); |     bool multi = ui->actionModeMultiDecoder->isChecked(); | ||||||
| 
 | 
 | ||||||
|     // do we have a better way to check this?
 |     // do we have a better way to check this?
 | ||||||
|     bool everySecond = ui->actionModeAutoSync->isChecked(); |     bool everySecond = m_wideGraph->shouldAutoSync(); | ||||||
| 
 | 
 | ||||||
|     // do we need to process alternate positions?
 |     // do we need to process alternate positions?
 | ||||||
|     bool skipAlt = false; |     bool skipAlt = false; | ||||||
| @ -4870,7 +4863,7 @@ bool MainWindow::decodeProcessQueue(qint32 *pSubmode){ | |||||||
| 
 | 
 | ||||||
|     int period = computePeriodForSubmode(submode); |     int period = computePeriodForSubmode(submode); | ||||||
| 
 | 
 | ||||||
|     dec_data.params.syncStats = (m_wideGraph->shouldDisplayDecodeAttempts() || ui->actionModeAutoSync->isChecked()); |     dec_data.params.syncStats = (m_wideGraph->shouldDisplayDecodeAttempts() || m_wideGraph->shouldAutoSync()); | ||||||
|     dec_data.params.npts8=(m_ihsym*m_nsps)/16; |     dec_data.params.npts8=(m_ihsym*m_nsps)/16; | ||||||
|     dec_data.params.newdat=1; |     dec_data.params.newdat=1; | ||||||
|     dec_data.params.nagain=0; |     dec_data.params.nagain=0; | ||||||
| @ -5248,7 +5241,7 @@ void MainWindow::processDecodedLine(QByteArray t){ | |||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       // only continue if we should either display decode attempts or if we should try to auto sync
 |       // only continue if we should either display decode attempts or if we should try to auto sync
 | ||||||
|       if(!m_wideGraph->shouldDisplayDecodeAttempts() && !ui->actionModeAutoSync->isChecked()){ |       if(!m_wideGraph->shouldDisplayDecodeAttempts() && !m_wideGraph->shouldAutoSync()){ | ||||||
|           return; |           return; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -5284,7 +5277,7 @@ void MainWindow::processDecodedLine(QByteArray t){ | |||||||
|       m_wideGraph->drawDecodeLine(QColor(Qt::red), f, f + computeBandwidthForSubmode(m)); |       m_wideGraph->drawDecodeLine(QColor(Qt::red), f, f + computeBandwidthForSubmode(m)); | ||||||
| 
 | 
 | ||||||
|       // compute time drift if needed
 |       // compute time drift if needed
 | ||||||
|       if(!ui->actionModeAutoSync->isChecked()){ |       if(!m_wideGraph->shouldAutoSync()){ | ||||||
|           return; |           return; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -5511,7 +5504,7 @@ void MainWindow::processDecodedLine(QByteArray t){ | |||||||
|     d.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); |     d.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); | ||||||
|     d.snr = decodedtext.snr(); |     d.snr = decodedtext.snr(); | ||||||
|     d.isBuffered = false; |     d.isBuffered = false; | ||||||
|     d.tdrift = ui->actionModeAutoSync->isChecked() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); |     d.tdrift = m_wideGraph->shouldAutoSync() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); | ||||||
|     d.submode = decodedtext.submode(); |     d.submode = decodedtext.submode(); | ||||||
| 
 | 
 | ||||||
|     // if we have any "first" frame, and a buffer is already established, clear it...
 |     // if we have any "first" frame, and a buffer is already established, clear it...
 | ||||||
| @ -5549,7 +5542,7 @@ void MainWindow::processDecodedLine(QByteArray t){ | |||||||
|     cd.offset = decodedtext.frequencyOffset(); |     cd.offset = decodedtext.frequencyOffset(); | ||||||
|     cd.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); |     cd.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); | ||||||
|     cd.bits = decodedtext.bits(); |     cd.bits = decodedtext.bits(); | ||||||
|     cd.tdrift = ui->actionModeAutoSync->isChecked() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); |     cd.tdrift = m_wideGraph->shouldAutoSync() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); | ||||||
|     cd.submode = decodedtext.submode(); |     cd.submode = decodedtext.submode(); | ||||||
| 
 | 
 | ||||||
|     // Only respond to HEARTBEATS...remember that CQ messages are "Alt" pings
 |     // Only respond to HEARTBEATS...remember that CQ messages are "Alt" pings
 | ||||||
| @ -5628,7 +5621,7 @@ void MainWindow::processDecodedLine(QByteArray t){ | |||||||
|       cmd.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); |       cmd.utcTimestamp = DriftingDateTime::currentDateTimeUtc(); | ||||||
|       cmd.bits = decodedtext.bits(); |       cmd.bits = decodedtext.bits(); | ||||||
|       cmd.extra = parts.length() > 2 ? parts.mid(3).join(" ") : ""; |       cmd.extra = parts.length() > 2 ? parts.mid(3).join(" ") : ""; | ||||||
|       cmd.tdrift = ui->actionModeAutoSync->isChecked() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); |       cmd.tdrift = m_wideGraph->shouldAutoSync() ? DriftingDateTime::drift()/1000.0 : decodedtext.dt(); | ||||||
|       cmd.submode = decodedtext.submode(); |       cmd.submode = decodedtext.submode(); | ||||||
| 
 | 
 | ||||||
|       // if the command is a buffered command and its not the last frame OR we have from or to in a separate message (compound call)
 |       // if the command is a buffered command and its not the last frame OR we have from or to in a separate message (compound call)
 | ||||||
| @ -6457,7 +6450,7 @@ void MainWindow::guiUpdate() | |||||||
|     auto drift = DriftingDateTime::drift(); |     auto drift = DriftingDateTime::drift(); | ||||||
|     QDateTime t = DriftingDateTime::currentDateTimeUtc(); |     QDateTime t = DriftingDateTime::currentDateTimeUtc(); | ||||||
|     QStringList parts; |     QStringList parts; | ||||||
|     parts << (t.time().toString() + (!drift ? " " : QString(" (%1%2ms)").arg(drift > 0 ? "+" : "").arg(drift))); |     parts << (t.time().toString() + (!drift ? " " : QString(" (%1%2ms%3)").arg(drift > 0 ? "+" : "").arg(drift).arg(m_wideGraph->shouldAutoSync() ? " auto" : ""))); | ||||||
|     parts << t.date().toString("yyyy MMM dd"); |     parts << t.date().toString("yyyy MMM dd"); | ||||||
|     ui->labUTC->setText(parts.join("\n")); |     ui->labUTC->setText(parts.join("\n")); | ||||||
| 
 | 
 | ||||||
| @ -10668,7 +10661,6 @@ void MainWindow::updateModeButtonText(){ | |||||||
|     auto selectedCallsign = callsignSelected(); |     auto selectedCallsign = callsignSelected(); | ||||||
| 
 | 
 | ||||||
|     auto multi = ui->actionModeMultiDecoder->isChecked(); |     auto multi = ui->actionModeMultiDecoder->isChecked(); | ||||||
|     auto autosync = ui->actionModeAutoSync->isChecked(); |  | ||||||
|     auto autoreply = ui->actionModeAutoreply->isChecked(); |     auto autoreply = ui->actionModeAutoreply->isChecked(); | ||||||
|     auto heartbeat = ui->actionModeJS8HB->isEnabled() && ui->actionModeJS8HB->isChecked(); |     auto heartbeat = ui->actionModeJS8HB->isEnabled() && ui->actionModeJS8HB->isChecked(); | ||||||
|     auto ack = autoreply && ui->actionHeartbeatAcknowledgements->isChecked() && (!m_config.heartbeat_qso_pause() || selectedCallsign.isEmpty()); |     auto ack = autoreply && ui->actionHeartbeatAcknowledgements->isChecked() && (!m_config.heartbeat_qso_pause() || selectedCallsign.isEmpty()); | ||||||
| @ -10678,10 +10670,6 @@ void MainWindow::updateModeButtonText(){ | |||||||
|         modeText += QString("+MULTI"); |         modeText += QString("+MULTI"); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if(autosync){ |  | ||||||
|         modeText += QString("+SYNC"); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if(autoreply){ |     if(autoreply){ | ||||||
|         if(m_config.autoreply_confirmation()){ |         if(m_config.autoreply_confirmation()){ | ||||||
|             modeText += QString("+AUTO+CONF"); |             modeText += QString("+AUTO+CONF"); | ||||||
|  | |||||||
| @ -4749,7 +4749,6 @@ list. The list can be maintained in Settings (F2).</string> | |||||||
|     <addaction name="separator"/> |     <addaction name="separator"/> | ||||||
|     <addaction name="menu_Decode_Passes"/> |     <addaction name="menu_Decode_Passes"/> | ||||||
|     <addaction name="actionModeMultiDecoder"/> |     <addaction name="actionModeMultiDecoder"/> | ||||||
|     <addaction name="actionModeAutoSync"/> |  | ||||||
|     <addaction name="separator"/> |     <addaction name="separator"/> | ||||||
|     <addaction name="actionModeAutoreply"/> |     <addaction name="actionModeAutoreply"/> | ||||||
|     <addaction name="actionModeJS8HB"/> |     <addaction name="actionModeJS8HB"/> | ||||||
|  | |||||||
| @ -250,6 +250,19 @@ bool WideGraph::shouldDisplayDecodeAttempts(){ | |||||||
|     return ui->decodeAttemptCheckBox->isChecked(); |     return ui->decodeAttemptCheckBox->isChecked(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool WideGraph::shouldAutoSync(){ | ||||||
|  |     return ui->autoDriftButton->isChecked(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void WideGraph::on_autoDriftButton_checked(bool checked){ | ||||||
|  |     auto text = ui->autoDriftButton->text(); | ||||||
|  |     if(checked){ | ||||||
|  |         ui->autoDriftButton->setText(text.replace("Start", "Stop")); | ||||||
|  |     } else { | ||||||
|  |         ui->autoDriftButton->setText(text.replace("Stop", "Start")); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void WideGraph::drawDecodeLine(const QColor &color, int ia, int ib) | void WideGraph::drawDecodeLine(const QColor &color, int ia, int ib) | ||||||
| { | { | ||||||
|   ui->widePlot->drawDecodeLine(color, ia, ib); |   ui->widePlot->drawDecodeLine(color, ia, ib); | ||||||
|  | |||||||
| @ -69,6 +69,7 @@ public: | |||||||
|   void   setRedFile(QString fRed); |   void   setRedFile(QString fRed); | ||||||
|   void   setTurbo(bool turbo); |   void   setTurbo(bool turbo); | ||||||
|   bool   shouldDisplayDecodeAttempts(); |   bool   shouldDisplayDecodeAttempts(); | ||||||
|  |   bool   shouldAutoSync(); | ||||||
|   QVector<QColor> const& colors(); |   QVector<QColor> const& colors(); | ||||||
| 
 | 
 | ||||||
| signals: | signals: | ||||||
| @ -122,6 +123,7 @@ private slots: | |||||||
|   void on_filterCheckBox_toggled(bool b); |   void on_filterCheckBox_toggled(bool b); | ||||||
|   void on_filterOpacitySpinBox_valueChanged(int n); |   void on_filterOpacitySpinBox_valueChanged(int n); | ||||||
| 
 | 
 | ||||||
|  |   void on_autoDriftButton_checked(bool checked); | ||||||
|   void on_driftSpinBox_valueChanged(int n); |   void on_driftSpinBox_valueChanged(int n); | ||||||
|   void on_driftSyncButton_clicked(); |   void on_driftSyncButton_clicked(); | ||||||
|   void on_driftSyncEndButton_clicked(); |   void on_driftSyncEndButton_clicked(); | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								widegraph.ui
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								widegraph.ui
									
									
									
									
									
								
							| @ -427,8 +427,8 @@ | |||||||
|               <property name="geometry"> |               <property name="geometry"> | ||||||
|                <rect> |                <rect> | ||||||
|                 <x>0</x> |                 <x>0</x> | ||||||
|                 <y>-371</y> |                 <y>0</y> | ||||||
|                 <width>267</width> |                 <width>240</width> | ||||||
|                 <height>742</height> |                 <height>742</height> | ||||||
|                </rect> |                </rect> | ||||||
|               </property> |               </property> | ||||||
| @ -976,7 +976,7 @@ | |||||||
|                 <x>0</x> |                 <x>0</x> | ||||||
|                 <y>0</y> |                 <y>0</y> | ||||||
|                 <width>281</width> |                 <width>281</width> | ||||||
|                 <height>198</height> |                 <height>234</height> | ||||||
|                </rect> |                </rect> | ||||||
|               </property> |               </property> | ||||||
|               <layout class="QVBoxLayout" name="verticalLayout"> |               <layout class="QVBoxLayout" name="verticalLayout"> | ||||||
| @ -1020,6 +1020,22 @@ | |||||||
|                  </property> |                  </property> | ||||||
|                 </widget> |                 </widget> | ||||||
|                </item> |                </item> | ||||||
|  |                <item> | ||||||
|  |                 <widget class="QPushButton" name="autoDriftButton"> | ||||||
|  |                  <property name="minimumSize"> | ||||||
|  |                   <size> | ||||||
|  |                    <width>0</width> | ||||||
|  |                    <height>30</height> | ||||||
|  |                   </size> | ||||||
|  |                  </property> | ||||||
|  |                  <property name="text"> | ||||||
|  |                   <string>Start Automatic Drift Sync</string> | ||||||
|  |                  </property> | ||||||
|  |                  <property name="checkable"> | ||||||
|  |                   <bool>true</bool> | ||||||
|  |                  </property> | ||||||
|  |                 </widget> | ||||||
|  |                </item> | ||||||
|                <item> |                <item> | ||||||
|                 <widget class="QPushButton" name="driftSyncMinuteButton"> |                 <widget class="QPushButton" name="driftSyncMinuteButton"> | ||||||
|                  <property name="minimumSize"> |                  <property name="minimumSize"> | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jordan Sherer
						Jordan Sherer