mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 10:30:22 -04:00 
			
		
		
		
	Fix an issue with VFO tuning while running Doppler correction
Holding down the SHIFT key while tuning the rig should update the nominal sked frequency, not holding done the SHIFT key should not update the sked frequency. This is not yet perfect and sometimes a change to the nominal sked frequency can get through but it is a rare as yet unfound race condition. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@7992 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									cabb7cc453
								
							
						
					
					
						commit
						f70a3c5414
					
				| @ -5578,7 +5578,12 @@ void MainWindow::handle_transceiver_update (Transceiver::TransceiverState const& | |||||||
|     } |     } | ||||||
|   m_rigState = s; |   m_rigState = s; | ||||||
|   auto old_freqNominal = m_freqNominal; |   auto old_freqNominal = m_freqNominal; | ||||||
|   m_freqNominal = s.frequency () - m_astroCorrection.rx; |   if (!old_freqNominal) | ||||||
|  |     { | ||||||
|  |       // always take initial rig frequency to avoid start up problems
 | ||||||
|  |       // with bogus Tx frequencies
 | ||||||
|  |       m_freqNominal = s.frequency (); | ||||||
|  |     } | ||||||
|   if (old_state.online () == false && s.online () == true) |   if (old_state.online () == false && s.online () == true) | ||||||
|     { |     { | ||||||
|       // initializing
 |       // initializing
 | ||||||
| @ -5587,8 +5592,9 @@ void MainWindow::handle_transceiver_update (Transceiver::TransceiverState const& | |||||||
|   if (s.frequency () != old_state.frequency () || s.split () != m_splitMode) |   if (s.frequency () != old_state.frequency () || s.split () != m_splitMode) | ||||||
|     { |     { | ||||||
|       m_splitMode = s.split (); |       m_splitMode = s.split (); | ||||||
|       if (!s.ptt ()) //!m_transmitting)
 |       if (!s.ptt ()) | ||||||
|         { |         { | ||||||
|  |           m_freqNominal = s.frequency () - m_astroCorrection.rx; | ||||||
|           if (old_freqNominal != m_freqNominal) |           if (old_freqNominal != m_freqNominal) | ||||||
|             { |             { | ||||||
|               m_freqTxNominal = m_freqNominal; |               m_freqTxNominal = m_freqNominal; | ||||||
| @ -6461,14 +6467,14 @@ void MainWindow::astroUpdate () | |||||||
| { | { | ||||||
|   if (m_astroWidget) |   if (m_astroWidget) | ||||||
|     { |     { | ||||||
|  |       // no Doppler correction while CTRL pressed allows manual tuning
 | ||||||
|  |       if (Qt::ControlModifier & QApplication::queryKeyboardModifiers ()) return; | ||||||
|  | 
 | ||||||
|       auto correction = m_astroWidget->astroUpdate(QDateTime::currentDateTimeUtc (), |       auto correction = m_astroWidget->astroUpdate(QDateTime::currentDateTimeUtc (), | ||||||
|                                                    m_config.my_grid(), m_hisGrid, |                                                    m_config.my_grid(), m_hisGrid, | ||||||
|                                                    m_freqNominal, |                                                    m_freqNominal, | ||||||
|                                                    "Echo" == m_mode, m_transmitting, |                                                    "Echo" == m_mode, m_transmitting, | ||||||
|                                                    !m_config.tx_QSY_allowed (), m_TRperiod); |                                                    !m_config.tx_QSY_allowed (), m_TRperiod); | ||||||
|       // no Doppler correction while CTRL pressed allows manual tuning
 |  | ||||||
|       if (Qt::ControlModifier & QApplication::queryKeyboardModifiers ()) return; |  | ||||||
| 
 |  | ||||||
|       // no Doppler correction in Tx if rig can't do it
 |       // no Doppler correction in Tx if rig can't do it
 | ||||||
|       if (m_transmitting && !m_config.tx_QSY_allowed ()) return; |       if (m_transmitting && !m_config.tx_QSY_allowed ()) return; | ||||||
|       if (!m_astroWidget->doppler_tracking ()) return; |       if (!m_astroWidget->doppler_tracking ()) return; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user