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", | ||||
|     "MSK144", | ||||
|     "QRA64", | ||||
|     "FreqCal" | ||||
|     "FreqCal", | ||||
|     "FT8" | ||||
|   }; | ||||
|   std::size_t constexpr mode_names_size = sizeof (mode_names) / sizeof (mode_names[0]); | ||||
| } | ||||
|  | ||||
| @ -49,6 +49,7 @@ public: | ||||
|     MSK144, | ||||
|     QRA64, | ||||
|     FreqCal, | ||||
|     FT8, | ||||
|     MODES_END_SENTINAL_AND_COUNT // this must be last
 | ||||
|   }; | ||||
|   Q_ENUM (Mode) | ||||
|  | ||||
| @ -486,6 +486,7 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | ||||
|   on_EraseButton_clicked (); | ||||
| 
 | ||||
|   QActionGroup* modeGroup = new QActionGroup(this); | ||||
|   ui->actionFT8->setActionGroup(modeGroup); | ||||
|   ui->actionJT9->setActionGroup(modeGroup); | ||||
|   ui->actionJT65->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; | ||||
|   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=="JT9") on_actionJT9_triggered(); | ||||
|   if(m_mode=="JT65") on_actionJT65_triggered(); | ||||
| @ -875,8 +877,10 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | ||||
|   splashTimer.start (20 * 1000); | ||||
| 
 | ||||
|   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->actionFT8->setEnabled(true); | ||||
|       ui->actionWSPR_LF->setEnabled(true); | ||||
|   } | ||||
| 
 | ||||
|   // this must be the last statement of constructor
 | ||||
|   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; | ||||
|   } else if (m_mode=="FreqCal"){ | ||||
|     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_diskData) {                        //Always save; may delete later
 | ||||
| 
 | ||||
|       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_fnameWE=m_config.save_directory ().absoluteFilePath (period_start.toString ("yyMMdd_hhmm")); | ||||
|       } | ||||
|       m_fileToSave.clear (); | ||||
| 
 | ||||
|       // the following is potential a threading hazard - not a good
 | ||||
|       // idea to pass pointer to be processed in another thread
 | ||||
|       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 | ||||
|                      m_mode=="JT9" or m_mode=="MSK144"); | ||||
|     if(b) VHF_features_enabled(b); | ||||
|     if(m_mode=="FT8") on_actionFT8_triggered(); | ||||
|     if(m_mode=="JT4") on_actionJT4_triggered(); | ||||
|     if(m_mode=="JT9") on_actionJT9_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() | ||||
| { | ||||
|   m_mode="JT4"; | ||||
|  | ||||
| @ -174,6 +174,7 @@ private slots: | ||||
|   void on_actionJT65_triggered(); | ||||
|   void on_actionJT9_JT65_triggered(); | ||||
|   void on_actionJT4_triggered(); | ||||
|   void on_actionFT8_triggered(); | ||||
|   void on_TxFreqSpinBox_valueChanged(int arg1); | ||||
|   void on_actionSave_decoded_triggered(); | ||||
|   void on_actionQuickDecode_toggled (bool); | ||||
|  | ||||
| @ -2,6 +2,14 @@ | ||||
| <ui version="4.0"> | ||||
|  <class>MainWindow</class> | ||||
|  <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"> | ||||
|    <string>WSJT-X   by K1JT</string> | ||||
|   </property> | ||||
| @ -2316,6 +2324,14 @@ QPushButton[state="ok"] { | ||||
|    </layout> | ||||
|   </widget> | ||||
|   <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"> | ||||
|     <property name="title"> | ||||
|      <string>File</string> | ||||
| @ -2384,6 +2400,7 @@ QPushButton[state="ok"] { | ||||
|     <property name="title"> | ||||
|      <string>Mode</string> | ||||
|     </property> | ||||
|     <addaction name="actionFT8"/> | ||||
|     <addaction name="actionJT4"/> | ||||
|     <addaction name="actionJT9"/> | ||||
|     <addaction name="actionJT9_JT65"/> | ||||
| @ -2953,6 +2970,17 @@ QPushButton[state="ok"] { | ||||
|     <string>Experimental LF/MF mode</string> | ||||
|    </property> | ||||
|   </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> | ||||
|  <layoutdefault spacing="6" margin="11"/> | ||||
|  <customwidgets> | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user