mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-24 17:40:26 -04:00 
			
		
		
		
	Fast mode audio recording behaves the same way as slow modes
Fixed naming of fast recording files. Tidied some signal/slot plumbing in the fast plotter. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@6806 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									529ad6eec9
								
							
						
					
					
						commit
						c69bfee149
					
				| @ -32,8 +32,7 @@ FastGraph::FastGraph(QSettings * settings, QWidget *parent) : | ||||
|   ui->greenZeroSlider->setValue(ui->fastPlot->m_greenZero); | ||||
|   m_settings->endGroup(); | ||||
| 
 | ||||
|   connect(ui->fastPlot, SIGNAL(fastPick1(int,int,int)),this, | ||||
|           SLOT(fastPick1a(int,int,int))); | ||||
|   connect (ui->fastPlot, &FPlotter::fastPick, this, &FastGraph::fastPick); | ||||
| } | ||||
| 
 | ||||
| FastGraph::~FastGraph() | ||||
| @ -84,11 +83,6 @@ void FastGraph::on_greenZeroSlider_valueChanged(int value) | ||||
|   ui->fastPlot->draw(); | ||||
| } | ||||
| 
 | ||||
| void FastGraph::fastPick1a(int x0, int x1, int y) | ||||
| { | ||||
|   Q_EMIT fastPick(x0,x1,y); | ||||
| } | ||||
| 
 | ||||
| void FastGraph::on_pbAutoLevel_clicked() | ||||
| { | ||||
|   float sum=0.0; | ||||
|  | ||||
| @ -27,9 +27,6 @@ public: | ||||
| signals: | ||||
|   void fastPick(int x0, int x1, int y); | ||||
| 
 | ||||
| public slots: | ||||
|   void fastPick1a(int x0, int x1, int y); | ||||
| 
 | ||||
| private slots: | ||||
|   void on_gainSlider_valueChanged(int value); | ||||
|   void on_zeroSlider_valueChanged(int value);   | ||||
|  | ||||
| @ -216,7 +216,7 @@ void FPlotter::mousePressEvent(QMouseEvent *event)             //mousePressEvent | ||||
|   int x1=x+n*m_pixPerSecond; | ||||
|   if(x0 < 0) x0=0; | ||||
|   if(x1 > 702) x1=702; | ||||
|   Q_EMIT fastPick1(x0,x1,y); | ||||
|   Q_EMIT fastPick (x0,x1,y); | ||||
|   int y0=64; | ||||
|   if(y >= 120) y0+=100; | ||||
|   if(m_x0+m_x1 != 0) { | ||||
|  | ||||
| @ -35,7 +35,7 @@ public: | ||||
|   void drawScale(); | ||||
| 
 | ||||
| signals: | ||||
|   void fastPick1(int x0, int x1, int y); | ||||
|   void fastPick (int x0, int x1, int y); | ||||
| 
 | ||||
| protected: | ||||
|   //re-implemented widget event handlers
 | ||||
|  | ||||
| @ -234,7 +234,6 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | ||||
|   m_ihsym {0}, | ||||
|   m_nzap {0}, | ||||
|   m_px {0.0}, | ||||
|   m_decodeEarly {false}, | ||||
|   m_iptt0 {0}, | ||||
|   m_btxok0 {false}, | ||||
|   m_nsendingsh {0}, | ||||
| @ -388,8 +387,7 @@ MainWindow::MainWindow(QDir const& temp_directory, bool multiple, | ||||
|   connect(m_wideGraph.data (), SIGNAL(f11f12(int)),this,SLOT(bumpFqso(int))); | ||||
|   connect(m_wideGraph.data (), SIGNAL(setXIT2(int)),this,SLOT(setXIT(int))); | ||||
| 
 | ||||
|   connect(m_fastGraph.data(),SIGNAL(fastPick(int,int,int)),this, | ||||
|           SLOT(fastPick(int,int,int))); | ||||
|   connect (m_fastGraph.data (), &FastGraph::fastPick, this, &MainWindow::fastPick); | ||||
| 
 | ||||
|   connect (this, &MainWindow::finished, m_wideGraph.data (), &WideGraph::close); | ||||
|   connect (this, &MainWindow::finished, m_echoGraph.data (), &EchoGraph::close); | ||||
| @ -1077,23 +1075,19 @@ void MainWindow::dataSink(qint64 frames) | ||||
|     dec_data.params.newdat=1; | ||||
|     dec_data.params.nagain=0; | ||||
|     dec_data.params.nzhsym=m_hsymStop; | ||||
|     QDateTime t = QDateTime::currentDateTimeUtc(); | ||||
|     m_dateTime=t.toString("yyyy-MMM-dd hh:mm"); | ||||
|     QDateTime now {QDateTime::currentDateTimeUtc ()}; | ||||
|     m_dateTime = now.toString ("yyyy-MMM-dd hh:mm"); | ||||
|     if(!m_mode.startsWith ("WSPR")) decode(); //Start decoder
 | ||||
| 
 | ||||
|     if(!m_diskData) {                        //Always save; may delete later
 | ||||
|       int ihr=t.time().toString("hh").toInt(); | ||||
|       int imin=t.time().toString("mm").toInt(); | ||||
|       imin=imin - (imin%(m_TRperiod/60)); | ||||
|       QString t2; | ||||
|       t2.sprintf("%2.2d%2.2d",ihr,imin); | ||||
|       auto const& period_start = now.addSecs (-now.time ().minute () % (m_TRperiod / 60)); | ||||
|       m_fnameWE = m_config.save_directory ().absoluteFilePath (period_start.toString ("yyMMdd_hhmm")); | ||||
|       m_fileToSave.clear (); | ||||
|       m_fname = m_config.save_directory ().absoluteFilePath (t.date().toString("yyMMdd") + "_" + t2); | ||||
|       // 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 | ||||
|                                                                 , this | ||||
|                                                                 , m_fname | ||||
|                                                                 , m_fnameWE | ||||
|                                                                 , &dec_data.d2[0] | ||||
|                                                                 , m_TRperiod | ||||
|                                                                 , m_config.my_callsign () | ||||
| @ -1104,7 +1098,7 @@ void MainWindow::dataSink(qint64 frames) | ||||
|                                                                 , m_hisCall | ||||
|                                                                 , m_hisGrid))); | ||||
|       if (m_mode.startsWith ("WSPR")) { | ||||
|         QString c2name_string {m_fname + ".c2"}; | ||||
|         QString c2name_string {m_fnameWE + ".c2"}; | ||||
|         int len1=c2name_string.length(); | ||||
|         char c2name[80]; | ||||
|         strcpy(c2name,c2name_string.toLatin1 ().constData ()); | ||||
| @ -1129,7 +1123,7 @@ void MainWindow::dataSink(qint64 frames) | ||||
|       } else { | ||||
|         cmnd='"' + m_appDir + '"' + "/wsprd -a \"" + | ||||
|             QDir::toNativeSeparators(m_dataDir.absolutePath()) + "\" " + | ||||
|             t2 + '"' + m_fname + ".wav\""; | ||||
|             t2 + '"' + m_fnameWE + ".wav\""; | ||||
|       } | ||||
|       QString t3=cmnd; | ||||
|       int i1=cmnd.indexOf("/wsprd "); | ||||
| @ -1198,28 +1192,12 @@ void MainWindow::fastSink(qint64 frames) | ||||
|   int k (frames); | ||||
|   bool decodeNow=false; | ||||
| 
 | ||||
|   if(m_k0==9999999) { | ||||
|     memset(fast_green,0,sizeof(float)*703);        //Zero fast_gereen[]
 | ||||
|     memset(fast_s2,0,sizeof(float)*703*64);        //Zero fast_s2[]
 | ||||
|   if(k < m_k0) {                                 //New sequence ?
 | ||||
|     memcpy(fast_green2,fast_green,4*703);        //Copy fast_green[] to fast_green2[]
 | ||||
|     memcpy(fast_s2,fast_s,4*703*64);             //Copy fast_s[] into fast_s2[]
 | ||||
|     fast_jh2=fast_jh; | ||||
|     if(!m_diskData) memset(dec_data.d2,0,2*30*12000);   //Zero the d2[] array
 | ||||
|     m_bFastDecodeCalled=false; | ||||
|   } else { | ||||
|     if(k < m_k0) {                                 //New sequence ?
 | ||||
|       memcpy(fast_green2,fast_green,4*703);        //Copy fast_green[] to fast_green2[]
 | ||||
|       memcpy(fast_s2,fast_s,4*703*64);             //Copy fast_s[] into fast_s2[]
 | ||||
|       fast_jh2=fast_jh; | ||||
|       if(!m_diskData) memset(dec_data.d2,0,2*30*12000);   //Zero the d2[] array
 | ||||
|       m_decodeEarly=false; | ||||
|       m_bFastDecodeCalled=false; | ||||
|       QDateTime t=QDateTime::currentDateTimeUtc();     //.addSecs(2-m_TRperiod);
 | ||||
|       int ihr=t.toString("hh").toInt(); | ||||
|       int imin=t.toString("mm").toInt(); | ||||
|       int isec=t.toString("ss").toInt(); | ||||
|       isec=isec - isec%m_TRperiod; | ||||
|       QString t2; | ||||
|       t2.sprintf("%2.2d%2.2d%2.2d.wav",ihr,imin,isec); | ||||
|       m_fname = m_config.save_directory().absoluteFilePath( | ||||
|             t.date().toString("yyMMdd") + "_" + t2); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   hspec_(dec_data.d2, &k, &m_inGain, fast_green, fast_s, &fast_jh); | ||||
| @ -1244,13 +1222,16 @@ void MainWindow::fastSink(qint64 frames) | ||||
|       m_bFastDecodeCalled=true; | ||||
|       decode(); | ||||
|     } | ||||
|     if(!m_diskData and (m_saveAll or m_saveDecoded) and m_fname != "" and | ||||
|        !m_decodeEarly) { | ||||
|     if(!m_diskData) { | ||||
|       QDateTime now {QDateTime::currentDateTimeUtc()}; | ||||
|       auto const& period_start = now.addSecs (-now.time ().second () % m_TRperiod); | ||||
|       m_fnameWE = m_config.save_directory ().absoluteFilePath (period_start.toString ("yyMMdd_hhmmss")); | ||||
|       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 | ||||
|                                                                 , this | ||||
|                                                                 , m_fname | ||||
|                                                                 , m_fnameWE | ||||
|                                                                 , &dec_data.d2[0] | ||||
|                                                                 , m_TRperiod | ||||
|                                                                 , m_config.my_callsign () | ||||
| @ -1260,10 +1241,8 @@ void MainWindow::fastSink(qint64 frames) | ||||
|                                                                 , m_freqNominal | ||||
|                                                                 , m_hisCall | ||||
|                                                                 , m_hisGrid))); | ||||
|       m_fileToKill=m_fname; | ||||
|       killFileTimer.start (3*1000*m_TRperiod/4); //Kill 3/4 period from now
 | ||||
|     } | ||||
|     m_decodeEarly=false; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @ -1472,7 +1451,7 @@ void MainWindow::keyPressEvent( QKeyEvent *e )                //keyPressEvent | ||||
|       break; | ||||
|     case Qt::Key_V: | ||||
|       if(e->modifiers() & Qt::AltModifier) { | ||||
|         m_fileToSave=m_fname; | ||||
|         m_fileToSave = m_fnameWE; | ||||
|         return; | ||||
|       } | ||||
|       break; | ||||
| @ -2313,15 +2292,12 @@ void MainWindow::readFromStdout()                             //readFromStdout | ||||
| 
 | ||||
| void MainWindow::killFile () | ||||
| { | ||||
|   QString f=m_fname; | ||||
|   if(m_bFastMode) f=m_fileToKill; | ||||
|   if (!m_fname.isEmpty() && | ||||
|       !(m_saveAll || (m_saveDecoded && m_bDecoded) || m_fname == m_fileToSave)) { | ||||
|     if(m_fname.indexOf(".wav")<0) f+= ".wav"; | ||||
|     QFile f1{f}; | ||||
|   if (m_fnameWE.size () && | ||||
|       !(m_saveAll || (m_saveDecoded && m_bDecoded) || m_fnameWE == m_fileToSave)) { | ||||
|     QFile f1 {m_fnameWE + ".wav"}; | ||||
|     if(f1.exists()) f1.remove(); | ||||
|     if(m_mode.startsWith ("WSPR")) { | ||||
|       QFile f2{m_fname + ".c2"}; | ||||
|       QFile f2 {m_fnameWE + ".c2"}; | ||||
|       if(f2.exists()) f2.remove(); | ||||
|     } | ||||
|   } | ||||
|  | ||||
| @ -417,7 +417,6 @@ private: | ||||
|   int			m_npts8; | ||||
|   float		m_px; | ||||
|   float		m_df3; | ||||
|   bool		m_decodeEarly; | ||||
|   int			m_iptt0; | ||||
|   bool		m_btxok0; | ||||
|   int			m_nsendingsh; | ||||
| @ -468,7 +467,7 @@ private: | ||||
|   QString m_dateTime; | ||||
|   QString m_mode; | ||||
|   QString m_modeTx; | ||||
|   QString m_fname; | ||||
|   QString m_fnameWE;            // save path without extension
 | ||||
|   QString m_rpt; | ||||
|   QString m_rptSent; | ||||
|   QString m_rptRcvd; | ||||
| @ -476,7 +475,6 @@ private: | ||||
|   QString m_qsoStop; | ||||
|   QString m_cmnd; | ||||
|   QString m_msgSent0; | ||||
|   QString m_fileToKill; | ||||
|   QString m_fileToSave; | ||||
|   QString m_calls; | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user