mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-24 17:40:26 -04:00 
			
		
		
		
	Attempt to fix a few TX sequencing issues.
Simplified some of the TX logic and removed some redundant code. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@4014 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									22008672f1
								
							
						
					
					
						commit
						0cd70bb808
					
				
							
								
								
									
										143
									
								
								mainwindow.cpp
									
									
									
									
									
								
							
							
						
						
									
										143
									
								
								mainwindow.cpp
									
									
									
									
									
								
							| @ -37,7 +37,6 @@ int volatile icw[NUM_CW_SYMBOLS];	//Dits for CW ID | |||||||
| int outBufSize; | int outBufSize; | ||||||
| int rc; | int rc; | ||||||
| qint32  g_iptt; | qint32  g_iptt; | ||||||
| static int nc1=1; |  | ||||||
| wchar_t buffer[256]; | wchar_t buffer[256]; | ||||||
| 
 | 
 | ||||||
| QTextEdit* pShortcuts; | QTextEdit* pShortcuts; | ||||||
| @ -93,6 +92,7 @@ MainWindow::MainWindow(bool multiple, QSettings * settings, QSharedMemory *shdme | |||||||
|   m_detector (RX_SAMPLE_RATE, NTMAX / 2, 6912 / 2, downSampleFactor), |   m_detector (RX_SAMPLE_RATE, NTMAX / 2, 6912 / 2, downSampleFactor), | ||||||
|   m_modulator (TX_SAMPLE_RATE, NTMAX / 2), |   m_modulator (TX_SAMPLE_RATE, NTMAX / 2), | ||||||
|   m_audioThread {new QThread}, |   m_audioThread {new QThread}, | ||||||
|  |   m_diskData {false}, | ||||||
|   m_appDir {QApplication::applicationDirPath ()}, |   m_appDir {QApplication::applicationDirPath ()}, | ||||||
|   mem_jt9 {shdmem}, |   mem_jt9 {shdmem}, | ||||||
|   mykey_jt9 {thekey}, |   mykey_jt9 {thekey}, | ||||||
| @ -292,7 +292,6 @@ MainWindow::MainWindow(bool multiple, QSettings * settings, QSharedMemory *shdme | |||||||
|   m_auto=false; |   m_auto=false; | ||||||
|   m_waterfallAvg = 1; |   m_waterfallAvg = 1; | ||||||
|   m_txFirst=false; |   m_txFirst=false; | ||||||
|   m_btxMute=false; |  | ||||||
|   m_btxok=false; |   m_btxok=false; | ||||||
|   m_restart=false; |   m_restart=false; | ||||||
|   m_killAll=false; |   m_killAll=false; | ||||||
| @ -533,8 +532,6 @@ void MainWindow::readSettings() | |||||||
|   ui->cbTxLock->setChecked(m_lockTxFreq); |   ui->cbTxLock->setChecked(m_lockTxFreq); | ||||||
|   m_plus2kHz=m_settings->value("Plus2kHz",false).toBool(); |   m_plus2kHz=m_settings->value("Plus2kHz",false).toBool(); | ||||||
|   ui->cbPlus2kHz->setChecked(m_plus2kHz); |   ui->cbPlus2kHz->setChecked(m_plus2kHz); | ||||||
|   m_EMEbandIndex=m_settings->value("EMEbandIndex",0).toInt(); |  | ||||||
|   m_toneMultIndex=m_settings->value("ToneMultIndex",0).toInt(); |  | ||||||
|   m_settings->endGroup(); |   m_settings->endGroup(); | ||||||
| 
 | 
 | ||||||
|   // use these initialisation settings to tune the audio o/p buffer
 |   // use these initialisation settings to tune the audio o/p buffer
 | ||||||
| @ -664,41 +661,47 @@ void MainWindow::on_actionSettings_triggered()               //Setup Dialog | |||||||
| 
 | 
 | ||||||
| void MainWindow::on_monitorButton_clicked (bool checked) | void MainWindow::on_monitorButton_clicked (bool checked) | ||||||
| { | { | ||||||
|   // make sure we have the current rig state
 |  | ||||||
|   //  Q_EMIT m_config.sync_transceiver (true);
 |  | ||||||
| 
 |  | ||||||
|   qDebug () <<  "MainWindow::on_monitorButton_clicked: checked:" << checked; |  | ||||||
|   qDebug () <<  "MainWindow::on_monitorButton_clicked: m_monitoring:" << m_monitoring << "m_transmitting:" << m_transmitting; |  | ||||||
| 
 |  | ||||||
|   if (!m_transmitting) |   if (!m_transmitting) | ||||||
|     { |     { | ||||||
|  |       auto prior = m_monitoring; | ||||||
|       m_monitoring = checked; |       m_monitoring = checked; | ||||||
|       if (m_monitoring) |       if (!prior) | ||||||
|         { |         { | ||||||
|           m_diskData = false;	// no longer reading WAV files
 |           m_diskData = false;	// no longer reading WAV files
 | ||||||
| 
 | 
 | ||||||
|           // put rig back where it was when last in control
 |           // put rig back where it was when last in control
 | ||||||
|           Q_EMIT m_config.transceiver_frequency (m_lastMonitoredFrequency); |           Q_EMIT m_config.transceiver_frequency (m_lastMonitoredFrequency); | ||||||
|           setXIT (m_txFreq); |           setXIT (m_txFreq); | ||||||
|           Q_EMIT resumeAudioInputStream (); |  | ||||||
|         } |  | ||||||
|       else |  | ||||||
|         { |  | ||||||
|           Q_EMIT suspendAudioInputStream (); |  | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |       Q_EMIT m_config.sync_transceiver (true, checked); // gets
 | ||||||
|  |                                                         // Configuration
 | ||||||
|  |                                                         // in/out of
 | ||||||
|  |                                                         // strict
 | ||||||
|  |                                                         // split and
 | ||||||
|  |                                                         // mode
 | ||||||
|  |                                                         // checking
 | ||||||
|  | 
 | ||||||
|  |       monitor (checked); | ||||||
|     } |     } | ||||||
|   else |   else | ||||||
|     { |     { | ||||||
|       ui->monitorButton->setChecked (false); // disallow
 |       ui->monitorButton->setChecked (false); // disallow
 | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|   Q_EMIT m_config.sync_transceiver (true, checked); // gets Configuration in/out of strict split and mode checking
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::monitor (bool state) | void MainWindow::monitor (bool state) | ||||||
| { | { | ||||||
|   ui->monitorButton->setChecked (state); |   ui->monitorButton->setChecked (state); | ||||||
|   on_monitorButton_clicked (state); |   m_monitoring = state; | ||||||
|  |   if (state) | ||||||
|  |     { | ||||||
|  |       Q_EMIT resumeAudioInputStream (); | ||||||
|  |     } | ||||||
|  |   else | ||||||
|  |     { | ||||||
|  |       Q_EMIT suspendAudioInputStream (); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::on_actionAbout_triggered()                  //Display "About"
 | void MainWindow::on_actionAbout_triggered()                  //Display "About"
 | ||||||
| @ -1401,7 +1404,6 @@ void MainWindow::guiUpdate() | |||||||
|   static char message[29]; |   static char message[29]; | ||||||
|   static char msgsent[29]; |   static char msgsent[29]; | ||||||
|   static int nsendingsh=0; |   static int nsendingsh=0; | ||||||
|   static int giptt00=-1; |  | ||||||
|   static double onAirFreq0=0.0; |   static double onAirFreq0=0.0; | ||||||
|   QString rt; |   QString rt; | ||||||
| 
 | 
 | ||||||
| @ -1431,7 +1433,7 @@ void MainWindow::guiUpdate() | |||||||
|         bTxTime=false; |         bTxTime=false; | ||||||
|         if (m_tune) |         if (m_tune) | ||||||
|           { |           { | ||||||
|             tuning (false); |             stop_tuning (); | ||||||
|           } |           } | ||||||
| 	 | 	 | ||||||
|         if (m_auto) |         if (m_auto) | ||||||
| @ -1451,13 +1453,13 @@ void MainWindow::guiUpdate() | |||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|     float fTR=float((nsec%m_TRperiod))/m_TRperiod; |     float fTR=float((nsec%m_TRperiod))/m_TRperiod; | ||||||
|     if(g_iptt==0 and ((bTxTime and !m_btxMute and fTR<0.4) or m_tune )) { |     if(g_iptt==0 and ((bTxTime and fTR<0.4) or m_tune )) { | ||||||
|       icw[0]=m_ncw; |       icw[0]=m_ncw; | ||||||
|       g_iptt = 1; |       g_iptt = 1; | ||||||
|       Q_EMIT m_config.transceiver_ptt (true); |       Q_EMIT m_config.transceiver_ptt (true); | ||||||
|       ptt1Timer->start(200);                       //Sequencer delay
 |       ptt1Timer->start(200);                       //Sequencer delay
 | ||||||
|     } |     } | ||||||
|     if(!bTxTime || m_btxMute) { |     if(!bTxTime) { | ||||||
|       m_btxok=false; |       m_btxok=false; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @ -1550,48 +1552,40 @@ void MainWindow::guiUpdate() | |||||||
|     m_restart=false; |     m_restart=false; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |   if (g_iptt == 1 && iptt0 == 0) | ||||||
|   // If PTT was just raised, start a countdown for raising TxOK:
 |     { | ||||||
|   // NB: could be better implemented with a timer
 |       QString t=QString::fromLatin1(msgsent); | ||||||
|   if(g_iptt == 1 && iptt0 == 0) { |       if(t==m_msgSent0) { | ||||||
|     nc1=-9;    // TxDelay = 0.8 s
 |         m_repeatMsg++; | ||||||
|   } |       } else { | ||||||
|   if(nc1 <= 0) { |         m_repeatMsg=0; | ||||||
|     nc1++; |         m_msgSent0=t; | ||||||
|   } |  | ||||||
|   if(nc1 == 0) { |  | ||||||
|     QString t=QString::fromLatin1(msgsent); |  | ||||||
|     if(t==m_msgSent0) { |  | ||||||
|       m_repeatMsg++; |  | ||||||
|     } else { |  | ||||||
|       m_repeatMsg=0; |  | ||||||
|       m_msgSent0=t; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     signalMeter->setValue(0); |  | ||||||
| 
 |  | ||||||
|     if (m_monitoring) |  | ||||||
|       { |  | ||||||
|         monitor (false); |  | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|     m_btxok=true; |       signalMeter->setValue(0); | ||||||
|     m_transmitting=true; | 
 | ||||||
|     ui->pbTxMode->setEnabled(false); |       if (m_monitoring) | ||||||
|     if(!m_tune) { |         { | ||||||
|       QFile f(m_config.data_path ().absoluteFilePath ("ALL.TXT")); |           monitor (false); | ||||||
|       f.open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Append); |         } | ||||||
|       QTextStream out(&f); | 
 | ||||||
|       out << QDateTime::currentDateTimeUtc().toString("hhmm") |       m_btxok=true; | ||||||
|           << "  Transmitting " << (m_dialFreq / 1.e6) << " MHz  " << m_modeTx |       m_transmitting=true; | ||||||
|           << ":  " << t << endl; |       ui->pbTxMode->setEnabled(false); | ||||||
|       f.close(); |       if(!m_tune) { | ||||||
|     } |         QFile f(m_config.data_path ().absoluteFilePath ("ALL.TXT")); | ||||||
|     if (m_config.TX_messages () && !m_tune) |         f.open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Append); | ||||||
|       { |         QTextStream out(&f); | ||||||
|         ui->decodedTextBrowser2->displayTransmittedText(t,m_modeTx,m_txFreq); |         out << QDateTime::currentDateTimeUtc().toString("hhmm") | ||||||
|  |             << "  Transmitting " << (m_dialFreq / 1.e6) << " MHz  " << m_modeTx | ||||||
|  |             << ":  " << t << endl; | ||||||
|  |         f.close(); | ||||||
|       } |       } | ||||||
|   } |       if (m_config.TX_messages () && !m_tune) | ||||||
|  |         { | ||||||
|  |           ui->decodedTextBrowser2->displayTransmittedText(t,m_modeTx,m_txFreq); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|   if(!m_btxok && btxok0 && g_iptt==1) stopTx(); |   if(!m_btxok && btxok0 && g_iptt==1) stopTx(); | ||||||
| 
 | 
 | ||||||
| @ -1648,10 +1642,6 @@ void MainWindow::guiUpdate() | |||||||
|     m_sec0=nsec; |     m_sec0=nsec; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if(g_iptt!=giptt00) { |  | ||||||
|     giptt00=g_iptt; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   iptt0=g_iptt; |   iptt0=g_iptt; | ||||||
|   btxok0=m_btxok; |   btxok0=m_btxok; | ||||||
| }               //End of GUIupdate
 | }               //End of GUIupdate
 | ||||||
| @ -1671,10 +1661,10 @@ void MainWindow::startTx2() | |||||||
|     transmit (snr); |     transmit (snr); | ||||||
|     signalMeter->setValue(0); |     signalMeter->setValue(0); | ||||||
| 
 | 
 | ||||||
|     monitor (false); |     //monitor (false);
 | ||||||
| 
 | 
 | ||||||
|     m_btxok=true; |     //m_btxok=true;
 | ||||||
|     m_transmitting=true; |     //m_transmitting=true;
 | ||||||
|     ui->pbTxMode->setEnabled(false); |     ui->pbTxMode->setEnabled(false); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -1683,6 +1673,7 @@ void MainWindow::stopTx() | |||||||
| { | { | ||||||
|   Q_EMIT endTransmitMessage (); |   Q_EMIT endTransmitMessage (); | ||||||
|   m_transmitting=false; |   m_transmitting=false; | ||||||
|  |   m_btxok = false; | ||||||
|   if ("JT9+JT65" == m_mode) ui->pbTxMode->setEnabled(true); |   if ("JT9+JT65" == m_mode) ui->pbTxMode->setEnabled(true); | ||||||
|   g_iptt=0; |   g_iptt=0; | ||||||
|   tx_status_label->setStyleSheet(""); |   tx_status_label->setStyleSheet(""); | ||||||
| @ -2643,7 +2634,6 @@ void MainWindow::on_tuneButton_clicked (bool checked) | |||||||
| { | { | ||||||
|   if (m_tune) |   if (m_tune) | ||||||
|     { |     { | ||||||
|       nc1=1;                                 //disable the countdown timer
 |  | ||||||
|       tuneButtonTimer->start(250); |       tuneButtonTimer->start(250); | ||||||
|     }  |     }  | ||||||
|   else |   else | ||||||
| @ -2655,21 +2645,17 @@ void MainWindow::on_tuneButton_clicked (bool checked) | |||||||
|   Q_EMIT tune (checked); |   Q_EMIT tune (checked); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::tuning (bool state) | void MainWindow::stop_tuning () | ||||||
| { | { | ||||||
|   ui->tuneButton->setChecked (state); |   ui->tuneButton->setChecked (false); | ||||||
|   on_tuneButton_clicked (state); |   on_tuneButton_clicked (false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::on_stopTxButton_clicked()                    //Stop Tx
 | void MainWindow::on_stopTxButton_clicked()                    //Stop Tx
 | ||||||
| { | { | ||||||
|   // if(m_tune) {
 |  | ||||||
|   //   m_tune=false;
 |  | ||||||
|   //   Q_EMIT tune (m_tune);
 |  | ||||||
|   // }
 |  | ||||||
|   if (m_tune) |   if (m_tune) | ||||||
|     { |     { | ||||||
|       tuning (false); |       stop_tuning (); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|   if (m_auto) |   if (m_auto) | ||||||
| @ -2677,6 +2663,7 @@ void MainWindow::on_stopTxButton_clicked()                    //Stop Tx | |||||||
|       auto_tx_mode (false); |       auto_tx_mode (false); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |   m_transmitting = false; | ||||||
|   m_btxok=false; |   m_btxok=false; | ||||||
|   m_repeatMsg=0; |   m_repeatMsg=0; | ||||||
| } | } | ||||||
|  | |||||||
| @ -171,7 +171,7 @@ private slots: | |||||||
| 
 | 
 | ||||||
|   void band_changed (Frequency); |   void band_changed (Frequency); | ||||||
|   void monitor (bool); |   void monitor (bool); | ||||||
|   void tuning (bool); |   void stop_tuning (); | ||||||
|   void auto_tx_mode (bool); |   void auto_tx_mode (bool); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
| @ -248,13 +248,9 @@ private: | |||||||
|   QString  m_band; |   QString  m_band; | ||||||
|   qint32  m_repeatMsg; |   qint32  m_repeatMsg; | ||||||
|   qint32  m_watchdogLimit; |   qint32  m_watchdogLimit; | ||||||
|   qint32  m_fMax; |  | ||||||
|   qint32  m_EMEbandIndex; |  | ||||||
|   qint32  m_toneMultIndex; |  | ||||||
|   qint32  m_astroFont; |   qint32  m_astroFont; | ||||||
| 
 | 
 | ||||||
|   bool    m_btxok;		//True if OK to transmit
 |   bool    m_btxok;		//True if OK to transmit
 | ||||||
|   bool    m_btxMute;		//True if transmit should be muted
 |  | ||||||
|   bool    m_diskData; |   bool    m_diskData; | ||||||
|   bool    m_loopall; |   bool    m_loopall; | ||||||
|   bool    m_decoderBusy; |   bool    m_decoderBusy; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user