mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 10:00:23 -04:00 
			
		
		
		
	Starting to insert FT8 into GUI.
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@7726 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									51925c3e44
								
							
						
					
					
						commit
						bb21ca949c
					
				| @ -22,7 +22,8 @@ namespace | |||||||
|     "ISCAT", |     "ISCAT", | ||||||
|     "MSK144", |     "MSK144", | ||||||
|     "QRA64", |     "QRA64", | ||||||
|     "FreqCal" |     "FreqCal", | ||||||
|  |     "FT8" | ||||||
|   }; |   }; | ||||||
|   std::size_t constexpr mode_names_size = sizeof (mode_names) / sizeof (mode_names[0]); |   std::size_t constexpr mode_names_size = sizeof (mode_names) / sizeof (mode_names[0]); | ||||||
| } | } | ||||||
|  | |||||||
| @ -49,6 +49,7 @@ public: | |||||||
|     MSK144, |     MSK144, | ||||||
|     QRA64, |     QRA64, | ||||||
|     FreqCal, |     FreqCal, | ||||||
|  |     FT8, | ||||||
|     MODES_END_SENTINAL_AND_COUNT // this must be last
 |     MODES_END_SENTINAL_AND_COUNT // this must be last
 | ||||||
|   }; |   }; | ||||||
|   Q_ENUM (Mode) |   Q_ENUM (Mode) | ||||||
|  | |||||||
| @ -486,6 +486,7 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | |||||||
|   on_EraseButton_clicked (); |   on_EraseButton_clicked (); | ||||||
| 
 | 
 | ||||||
|   QActionGroup* modeGroup = new QActionGroup(this); |   QActionGroup* modeGroup = new QActionGroup(this); | ||||||
|  |   ui->actionFT8->setActionGroup(modeGroup); | ||||||
|   ui->actionJT9->setActionGroup(modeGroup); |   ui->actionJT9->setActionGroup(modeGroup); | ||||||
|   ui->actionJT65->setActionGroup(modeGroup); |   ui->actionJT65->setActionGroup(modeGroup); | ||||||
|   ui->actionJT9_JT65->setActionGroup(modeGroup); |   ui->actionJT9_JT65->setActionGroup(modeGroup); | ||||||
| @ -807,6 +808,7 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | |||||||
|   if(m_bFast9) m_bFastMode=true; |   if(m_bFast9) m_bFastMode=true; | ||||||
|   ui->cbFast9->setChecked(m_bFast9 or m_bFastMode); |   ui->cbFast9->setChecked(m_bFast9 or m_bFastMode); | ||||||
| 
 | 
 | ||||||
|  |   if(m_mode=="FT8") on_actionFT8_triggered(); | ||||||
|   if(m_mode=="JT4") on_actionJT4_triggered(); |   if(m_mode=="JT4") on_actionJT4_triggered(); | ||||||
|   if(m_mode=="JT9") on_actionJT9_triggered(); |   if(m_mode=="JT9") on_actionJT9_triggered(); | ||||||
|   if(m_mode=="JT65") on_actionJT65_triggered(); |   if(m_mode=="JT65") on_actionJT65_triggered(); | ||||||
| @ -875,8 +877,10 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | |||||||
|   splashTimer.start (20 * 1000); |   splashTimer.start (20 * 1000); | ||||||
| 
 | 
 | ||||||
|   if(m_config.my_callsign()=="K1JT" or m_config.my_callsign()=="K9AN" or |   if(m_config.my_callsign()=="K1JT" or m_config.my_callsign()=="K9AN" or | ||||||
|      m_config.my_callsign()=="G4WJS" || m_config.my_callsign () == "G3PQA") |      m_config.my_callsign()=="G4WJS" || m_config.my_callsign () == "G3PQA") { | ||||||
|     ui->actionWSPR_LF->setEnabled(true); |       ui->actionFT8->setEnabled(true); | ||||||
|  |       ui->actionWSPR_LF->setEnabled(true); | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   // this must be the last statement of constructor
 |   // this must be the last statement of constructor
 | ||||||
|   if (!m_valid) throw std::runtime_error {"Fatal initialization exception"}; |   if (!m_valid) throw std::runtime_error {"Fatal initialization exception"}; | ||||||
| @ -1115,6 +1119,8 @@ void MainWindow::fixStop() | |||||||
|     if(m_config.decode_at_52s()) m_hsymStop=186; |     if(m_config.decode_at_52s()) m_hsymStop=186; | ||||||
|   } else if (m_mode=="FreqCal"){ |   } else if (m_mode=="FreqCal"){ | ||||||
|     m_hsymStop=((int(m_TRperiod/0.288))/8)*8; |     m_hsymStop=((int(m_TRperiod/0.288))/8)*8; | ||||||
|  |   } else if (m_mode=="FT8") { | ||||||
|  |     m_hsymStop=48; | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1240,9 +1246,18 @@ void MainWindow::dataSink(qint64 frames) | |||||||
|     if(!m_mode.startsWith ("WSPR")) decode(); //Start decoder
 |     if(!m_mode.startsWith ("WSPR")) decode(); //Start decoder
 | ||||||
| 
 | 
 | ||||||
|     if(!m_diskData) {                        //Always save; may delete later
 |     if(!m_diskData) {                        //Always save; may delete later
 | ||||||
|       auto const& period_start = now.addSecs (-(now.time ().minute () % (m_TRperiod / 60)) * 60); | 
 | ||||||
|       m_fnameWE = m_config.save_directory ().absoluteFilePath (period_start.toString ("yyMMdd_hhmm")); |       if(m_mode=="FT8") { | ||||||
|  |         int n=now.time().second() % m_TRperiod; | ||||||
|  |         if(n<(m_TRperiod/2)) n=n+m_TRperiod; | ||||||
|  |         auto const& period_start=now.addSecs(-n); | ||||||
|  |         m_fnameWE=m_config.save_directory().absoluteFilePath (period_start.toString("yyMMdd_hhmmss")); | ||||||
|  |       } else { | ||||||
|  |         auto const& period_start = now.addSecs (-(now.time ().minute () % (m_TRperiod / 60)) * 60); | ||||||
|  |         m_fnameWE=m_config.save_directory ().absoluteFilePath (period_start.toString ("yyMMdd_hhmm")); | ||||||
|  |       } | ||||||
|       m_fileToSave.clear (); |       m_fileToSave.clear (); | ||||||
|  | 
 | ||||||
|       // the following is potential a threading hazard - not a good
 |       // the following is potential a threading hazard - not a good
 | ||||||
|       // idea to pass pointer to be processed in another thread
 |       // idea to pass pointer to be processed in another thread
 | ||||||
|       m_saveWAVWatcher.setFuture (QtConcurrent::run (std::bind (&MainWindow::save_wave_file, |       m_saveWAVWatcher.setFuture (QtConcurrent::run (std::bind (&MainWindow::save_wave_file, | ||||||
| @ -1529,6 +1544,7 @@ void MainWindow::on_actionSettings_triggered()               //Setup Dialog | |||||||
|     bool b = vhf && (m_mode=="JT4" or m_mode=="JT65" or m_mode=="ISCAT" or |     bool b = vhf && (m_mode=="JT4" or m_mode=="JT65" or m_mode=="ISCAT" or | ||||||
|                      m_mode=="JT9" or m_mode=="MSK144"); |                      m_mode=="JT9" or m_mode=="MSK144"); | ||||||
|     if(b) VHF_features_enabled(b); |     if(b) VHF_features_enabled(b); | ||||||
|  |     if(m_mode=="FT8") on_actionFT8_triggered(); | ||||||
|     if(m_mode=="JT4") on_actionJT4_triggered(); |     if(m_mode=="JT4") on_actionJT4_triggered(); | ||||||
|     if(m_mode=="JT9") on_actionJT9_triggered(); |     if(m_mode=="JT9") on_actionJT9_triggered(); | ||||||
|     if(m_mode=="JT9+JT65") on_actionJT9_JT65_triggered(); |     if(m_mode=="JT9+JT65") on_actionJT9_JT65_triggered(); | ||||||
| @ -4239,6 +4255,45 @@ void MainWindow::displayWidgets(int n) | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void MainWindow::on_actionFT8_triggered() | ||||||
|  | { | ||||||
|  |   m_mode="FT8"; | ||||||
|  |   bool bVHF=m_config.enable_VHF_features(); | ||||||
|  |   if(bVHF) { | ||||||
|  |     displayWidgets(nWidgets("111110101100111110010000")); | ||||||
|  |   } else { | ||||||
|  |     displayWidgets(nWidgets("111010000000111000010000")); | ||||||
|  |   } | ||||||
|  |   m_bFast9=false; | ||||||
|  |   m_bFastMode=false; | ||||||
|  |   WSPR_config(false); | ||||||
|  |   switch_mode (Modes::FT8); | ||||||
|  |   m_modeTx="FT8"; | ||||||
|  |   m_nsps=6912; | ||||||
|  |   m_FFTSize = m_nsps / 2; | ||||||
|  |   Q_EMIT FFTSize (m_FFTSize); | ||||||
|  |   m_hsymStop=48; | ||||||
|  |   setup_status_bar (bVHF); | ||||||
|  |   m_toneSpacing=0.0;                   //???
 | ||||||
|  |   ui->actionFT8->setChecked(true);     //???
 | ||||||
|  |   m_wideGraph->setMode(m_mode); | ||||||
|  |   m_wideGraph->setModeTx(m_modeTx); | ||||||
|  |   VHF_features_enabled(bVHF); | ||||||
|  |   ui->cbAutoSeq->setVisible(true); | ||||||
|  |   ui->cbAutoSeq->setChecked(true); | ||||||
|  |   m_TRperiod=15; | ||||||
|  |   m_fastGraph->hide(); | ||||||
|  |   m_wideGraph->show(); | ||||||
|  |   ui->decodedTextLabel->setText("UTC   dB   DT Freq    Message"); | ||||||
|  |   ui->decodedTextLabel2->setText("UTC   dB   DT Freq    Message"); | ||||||
|  |   m_wideGraph->setPeriod(m_TRperiod,m_nsps); | ||||||
|  |   m_modulator->setPeriod(m_TRperiod); // TODO - not thread safe
 | ||||||
|  |   m_detector->setPeriod(m_TRperiod);  // TODO - not thread safe
 | ||||||
|  |   ui->label_6->setText("Band Activity"); | ||||||
|  |   ui->label_7->setText("Rx Frequency"); | ||||||
|  |   statusChanged(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void MainWindow::on_actionJT4_triggered() | void MainWindow::on_actionJT4_triggered() | ||||||
| { | { | ||||||
|   m_mode="JT4"; |   m_mode="JT4"; | ||||||
|  | |||||||
| @ -174,6 +174,7 @@ private slots: | |||||||
|   void on_actionJT65_triggered(); |   void on_actionJT65_triggered(); | ||||||
|   void on_actionJT9_JT65_triggered(); |   void on_actionJT9_JT65_triggered(); | ||||||
|   void on_actionJT4_triggered(); |   void on_actionJT4_triggered(); | ||||||
|  |   void on_actionFT8_triggered(); | ||||||
|   void on_TxFreqSpinBox_valueChanged(int arg1); |   void on_TxFreqSpinBox_valueChanged(int arg1); | ||||||
|   void on_actionSave_decoded_triggered(); |   void on_actionSave_decoded_triggered(); | ||||||
|   void on_actionQuickDecode_toggled (bool); |   void on_actionQuickDecode_toggled (bool); | ||||||
|  | |||||||
| @ -2,6 +2,14 @@ | |||||||
| <ui version="4.0"> | <ui version="4.0"> | ||||||
|  <class>MainWindow</class> |  <class>MainWindow</class> | ||||||
|  <widget class="QMainWindow" name="MainWindow"> |  <widget class="QMainWindow" name="MainWindow"> | ||||||
|  |   <property name="geometry"> | ||||||
|  |    <rect> | ||||||
|  |     <x>0</x> | ||||||
|  |     <y>0</y> | ||||||
|  |     <width>872</width> | ||||||
|  |     <height>583</height> | ||||||
|  |    </rect> | ||||||
|  |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|    <string>WSJT-X   by K1JT</string> |    <string>WSJT-X   by K1JT</string> | ||||||
|   </property> |   </property> | ||||||
| @ -2316,6 +2324,14 @@ QPushButton[state="ok"] { | |||||||
|    </layout> |    </layout> | ||||||
|   </widget> |   </widget> | ||||||
|   <widget class="QMenuBar" name="menuBar"> |   <widget class="QMenuBar" name="menuBar"> | ||||||
|  |    <property name="geometry"> | ||||||
|  |     <rect> | ||||||
|  |      <x>0</x> | ||||||
|  |      <y>0</y> | ||||||
|  |      <width>872</width> | ||||||
|  |      <height>21</height> | ||||||
|  |     </rect> | ||||||
|  |    </property> | ||||||
|    <widget class="QMenu" name="menuFile"> |    <widget class="QMenu" name="menuFile"> | ||||||
|     <property name="title"> |     <property name="title"> | ||||||
|      <string>File</string> |      <string>File</string> | ||||||
| @ -2384,6 +2400,7 @@ QPushButton[state="ok"] { | |||||||
|     <property name="title"> |     <property name="title"> | ||||||
|      <string>Mode</string> |      <string>Mode</string> | ||||||
|     </property> |     </property> | ||||||
|  |     <addaction name="actionFT8"/> | ||||||
|     <addaction name="actionJT4"/> |     <addaction name="actionJT4"/> | ||||||
|     <addaction name="actionJT9"/> |     <addaction name="actionJT9"/> | ||||||
|     <addaction name="actionJT9_JT65"/> |     <addaction name="actionJT9_JT65"/> | ||||||
| @ -2953,6 +2970,17 @@ QPushButton[state="ok"] { | |||||||
|     <string>Experimental LF/MF mode</string> |     <string>Experimental LF/MF mode</string> | ||||||
|    </property> |    </property> | ||||||
|   </action> |   </action> | ||||||
|  |   <action name="actionFT8"> | ||||||
|  |    <property name="checkable"> | ||||||
|  |     <bool>true</bool> | ||||||
|  |    </property> | ||||||
|  |    <property name="enabled"> | ||||||
|  |     <bool>false</bool> | ||||||
|  |    </property> | ||||||
|  |    <property name="text"> | ||||||
|  |     <string>FT8</string> | ||||||
|  |    </property> | ||||||
|  |   </action> | ||||||
|  </widget> |  </widget> | ||||||
|  <layoutdefault spacing="6" margin="11"/> |  <layoutdefault spacing="6" margin="11"/> | ||||||
|  <customwidgets> |  <customwidgets> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user