mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-01 08:07:10 -04:00
0f395a4794
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@5595 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
563 lines
16 KiB
C++
563 lines
16 KiB
C++
// -*- Mode: C++ -*-
|
|
#ifndef MAINWINDOW_H
|
|
#define MAINWINDOW_H
|
|
#ifdef QT5
|
|
#include <QtWidgets>
|
|
#else
|
|
#include <QtGui>
|
|
#endif
|
|
#include <QThread>
|
|
#include <QTimer>
|
|
#include <QDateTime>
|
|
#include <QList>
|
|
#include <QAudioDeviceInfo>
|
|
#include <QScopedPointer>
|
|
#include <QDir>
|
|
#include <QProgressDialog>
|
|
#include <QAbstractSocket>
|
|
#include <QHostAddress>
|
|
#include <QPointer>
|
|
|
|
#include "soundin.h"
|
|
#include "AudioDevice.hpp"
|
|
#include "soundout.h"
|
|
#include "commons.h"
|
|
#include "Radio.hpp"
|
|
#include "Modes.hpp"
|
|
#include "Configuration.hpp"
|
|
#include "WSPRBandHopping.hpp"
|
|
#include "Transceiver.hpp"
|
|
#include "psk_reporter.h"
|
|
#include "signalmeter.h"
|
|
#include "logbook/logbook.h"
|
|
#include "Detector.hpp"
|
|
#include "Modulator.hpp"
|
|
#include "decodedtext.h"
|
|
|
|
#define NUM_JT4_SYMBOLS 206
|
|
#define NUM_JT65_SYMBOLS 126
|
|
#define NUM_JT9_SYMBOLS 85
|
|
#define NUM_WSPR_SYMBOLS 162
|
|
#define NUM_CW_SYMBOLS 250
|
|
#define TX_SAMPLE_RATE 48000
|
|
|
|
extern int volatile itone[NUM_JT4_SYMBOLS]; //Audio tones for all Tx symbols
|
|
extern int volatile icw[NUM_CW_SYMBOLS]; //Dits for CW ID
|
|
|
|
//--------------------------------------------------------------- MainWindow
|
|
namespace Ui {
|
|
class MainWindow;
|
|
}
|
|
|
|
class QSettings;
|
|
class QLineEdit;
|
|
class QFont;
|
|
class QHostInfo;
|
|
class EchoGraph;
|
|
class WideGraph;
|
|
class LogQSO;
|
|
class Transceiver;
|
|
class Astro;
|
|
class MessageAveraging;
|
|
class MessageClient;
|
|
class QTime;
|
|
class WSPRBandHopping;
|
|
class HelpTextWindow;
|
|
class WSPRNet;
|
|
|
|
class MainWindow : public QMainWindow
|
|
{
|
|
Q_OBJECT;
|
|
|
|
public:
|
|
using Frequency = Radio::Frequency;
|
|
using Mode = Modes::Mode;
|
|
|
|
// Multiple instances: call MainWindow() with *thekey
|
|
explicit MainWindow(bool multiple, QSettings *, QSharedMemory *shdmem,
|
|
unsigned downSampleFactor, QWidget *parent = 0);
|
|
~MainWindow();
|
|
|
|
public slots:
|
|
void showSoundInError(const QString& errorMsg);
|
|
void showSoundOutError(const QString& errorMsg);
|
|
void showStatusMessage(const QString& statusMsg);
|
|
void dataSink(qint64 frames);
|
|
void diskDat();
|
|
void diskWriteFinished();
|
|
void freezeDecode(int n);
|
|
void guiUpdate();
|
|
void doubleClickOnCall(bool shift, bool ctrl);
|
|
void doubleClickOnCall2(bool shift, bool ctrl);
|
|
void readFromStdout();
|
|
void readFromStderr();
|
|
void jt9_error(QProcess::ProcessError);
|
|
void p1ReadFromStdout();
|
|
void p1ReadFromStderr();
|
|
void p1Error(QProcess::ProcessError);
|
|
void setXIT(int n);
|
|
void setFreq4(int rxFreq, int txFreq);
|
|
void msgAvgDecode2();
|
|
|
|
protected:
|
|
virtual void keyPressEvent( QKeyEvent *e );
|
|
void closeEvent(QCloseEvent*);
|
|
virtual bool eventFilter(QObject *object, QEvent *event);
|
|
|
|
private slots:
|
|
void on_tx1_editingFinished();
|
|
void on_tx2_editingFinished();
|
|
void on_tx3_editingFinished();
|
|
void on_tx4_editingFinished();
|
|
void on_tx5_currentTextChanged (QString const&);
|
|
void on_tx6_editingFinished();
|
|
void on_actionSettings_triggered();
|
|
void on_monitorButton_clicked (bool);
|
|
void on_actionAbout_triggered();
|
|
void on_autoButton_clicked (bool);
|
|
void on_stopTxButton_clicked();
|
|
void on_stopButton_clicked();
|
|
void on_actionOnline_User_Guide_triggered();
|
|
void on_actionLocal_User_Guide_triggered();
|
|
void on_actionWide_Waterfall_triggered();
|
|
void on_actionOpen_triggered();
|
|
void on_actionOpen_next_in_directory_triggered();
|
|
void on_actionDecode_remaining_files_in_directory_triggered();
|
|
void on_actionDelete_all_wav_files_in_SaveDir_triggered();
|
|
void on_actionOpen_log_directory_triggered ();
|
|
void on_actionNone_triggered();
|
|
void on_actionSave_all_triggered();
|
|
void on_actionKeyboard_shortcuts_triggered();
|
|
void on_actionSpecial_mouse_commands_triggered();
|
|
void on_DecodeButton_clicked (bool);
|
|
void decode();
|
|
void decodeBusy(bool b);
|
|
void on_EraseButton_clicked();
|
|
void on_txb1_clicked();
|
|
void on_txFirstCheckBox_stateChanged(int arg1);
|
|
void set_ntx(int n);
|
|
void on_txb2_clicked();
|
|
void on_txb3_clicked();
|
|
void on_txb4_clicked();
|
|
void on_txb5_clicked();
|
|
void on_txb6_clicked();
|
|
void on_lookupButton_clicked();
|
|
void on_addButton_clicked();
|
|
void on_dxCallEntry_textChanged(const QString &arg1);
|
|
void on_dxGridEntry_textChanged(const QString &arg1);
|
|
void on_genStdMsgsPushButton_clicked();
|
|
void on_logQSOButton_clicked();
|
|
void on_actionJT9_1_triggered();
|
|
void on_actionJT65_triggered();
|
|
void on_actionJT9_JT65_triggered();
|
|
void on_actionJT4_triggered();
|
|
void on_TxFreqSpinBox_valueChanged(int arg1);
|
|
void on_actionSave_decoded_triggered();
|
|
void on_actionQuickDecode_triggered();
|
|
void on_actionMediumDecode_triggered();
|
|
void on_actionDeepestDecode_triggered();
|
|
void on_inGain_valueChanged(int n);
|
|
void bumpFqso(int n);
|
|
void on_actionErase_ALL_TXT_triggered();
|
|
void on_actionErase_wsjtx_log_adi_triggered();
|
|
void startTx2();
|
|
void stopTx();
|
|
void stopTx2();
|
|
void on_pbCallCQ_clicked();
|
|
void on_pbAnswerCaller_clicked();
|
|
void on_pbSendRRR_clicked();
|
|
void on_pbAnswerCQ_clicked();
|
|
void on_pbSendReport_clicked();
|
|
void on_pbSend73_clicked();
|
|
void on_rbGenMsg_clicked(bool checked);
|
|
void on_rbFreeText_clicked(bool checked);
|
|
void on_freeTextMsg_currentTextChanged (QString const&);
|
|
void on_rptSpinBox_valueChanged(int n);
|
|
void killFile();
|
|
void on_tuneButton_clicked (bool);
|
|
void on_pbR2T_clicked();
|
|
void on_pbT2R_clicked();
|
|
void acceptQSO2(QDateTime const&, QString const& call, QString const& grid
|
|
, Frequency dial_freq, QString const& mode
|
|
, QString const& rpt_sent, QString const& rpt_received
|
|
, QString const& tx_power, QString const& comments
|
|
, QString const& name);
|
|
void on_bandComboBox_currentIndexChanged (int index);
|
|
void on_bandComboBox_activated (int index);
|
|
void on_readFreq_clicked();
|
|
void on_pbTxMode_clicked();
|
|
void on_RxFreqSpinBox_valueChanged(int n);
|
|
void on_cbTxLock_clicked(bool checked);
|
|
void on_outAttenuation_valueChanged (int);
|
|
void rigOpen ();
|
|
void handle_transceiver_update (Transceiver::TransceiverState);
|
|
void handle_transceiver_failure (QString reason);
|
|
void on_actionAstronomical_data_triggered();
|
|
void on_actionShort_list_of_add_on_prefixes_and_suffixes_triggered();
|
|
void getpfx();
|
|
void on_actionJT9W_1_triggered();
|
|
void band_changed (Frequency);
|
|
void monitor (bool);
|
|
void stop_tuning ();
|
|
void stopTuneATU();
|
|
void auto_tx_mode (bool);
|
|
void on_actionMessage_averaging_triggered();
|
|
void on_sbTol_valueChanged(int i);
|
|
void on_actionInclude_averaging_triggered();
|
|
void on_actionInclude_correlation_triggered();
|
|
void on_sbDT_valueChanged(double x);
|
|
void VHF_controls_visible(bool b);
|
|
void VHF_features_enabled(bool b);
|
|
void on_cbEME_toggled(bool b);
|
|
void on_sbMinW_valueChanged(int n);
|
|
void on_sbSubmode_valueChanged(int n);
|
|
void on_cbShMsgs_toggled(bool b);
|
|
void on_cbTx6_toggled(bool b);
|
|
void networkError (QString const&);
|
|
void on_ClrAvgButton_clicked();
|
|
void on_actionWSPR_2_triggered();
|
|
void on_actionWSPR_15_triggered();
|
|
void on_syncSpinBox_valueChanged(int n);
|
|
void on_TxPowerComboBox_currentIndexChanged(const QString &arg1);
|
|
void on_sbTxPercent_valueChanged(int n);
|
|
void on_cbUploadWSPR_Spots_toggled(bool b);
|
|
void WSPR_config(bool b);
|
|
void uploadSpots();
|
|
void uploadResponse(QString response);
|
|
void p3ReadFromStdout();
|
|
void p3ReadFromStderr();
|
|
void p3Error(QProcess::ProcessError e);
|
|
void on_WSPRfreqSpinBox_valueChanged(int n);
|
|
void on_pbTxNext_clicked(bool b);
|
|
void on_tabWidget_currentChanged (int);
|
|
|
|
void on_actionEcho_Graph_triggered();
|
|
|
|
void on_actionEcho_triggered();
|
|
void DopplerTracking_toggled (bool);
|
|
|
|
private:
|
|
Q_SIGNAL void initializeAudioOutputStream (QAudioDeviceInfo,
|
|
unsigned channels, unsigned msBuffered) const;
|
|
Q_SIGNAL void stopAudioOutputStream () const;
|
|
Q_SIGNAL void startAudioInputStream (QAudioDeviceInfo const&,
|
|
int framesPerBuffer, AudioDevice * sink,
|
|
unsigned downSampleFactor, AudioDevice::Channel) const;
|
|
Q_SIGNAL void suspendAudioInputStream () const;
|
|
Q_SIGNAL void resumeAudioInputStream () const;
|
|
Q_SIGNAL void startDetector (AudioDevice::Channel) const;
|
|
Q_SIGNAL void detectorClose () const;
|
|
Q_SIGNAL void finished () const;
|
|
Q_SIGNAL void transmitFrequency (double) const;
|
|
Q_SIGNAL void endTransmitMessage (bool quick = false) const;
|
|
Q_SIGNAL void tune (bool = true) const;
|
|
Q_SIGNAL void sendMessage (unsigned symbolsLength, double framesPerSymbol,
|
|
double frequency, double toneSpacing,
|
|
SoundOutput *, AudioDevice::Channel = AudioDevice::Mono,
|
|
bool synchronize = true, double dBSNR = 99.) const;
|
|
Q_SIGNAL void outAttenuationChanged (qreal) const;
|
|
Q_SIGNAL void toggleShorthand () const;
|
|
|
|
private:
|
|
QDir m_dataDir;
|
|
QString m_revision;
|
|
bool m_multiple;
|
|
QSettings * m_settings;
|
|
|
|
Ui::MainWindow * ui;
|
|
|
|
// other windows
|
|
Configuration m_config;
|
|
WSPRBandHopping m_WSPR_band_hopping;
|
|
QMessageBox m_rigErrorMessageBox;
|
|
|
|
QScopedPointer<WideGraph> m_wideGraph;
|
|
QScopedPointer<EchoGraph> m_echoGraph;
|
|
QScopedPointer<LogQSO> m_logDlg;
|
|
QScopedPointer<Astro> m_astroWidget;
|
|
QScopedPointer<HelpTextWindow> m_shortcuts;
|
|
QScopedPointer<HelpTextWindow> m_prefixes;
|
|
QScopedPointer<HelpTextWindow> m_mouseCmnds;
|
|
QScopedPointer<MessageAveraging> m_msgAvgWidget;
|
|
|
|
Frequency m_dialFreq;
|
|
Frequency m_dialFreqRxWSPR;
|
|
|
|
Detector m_detector;
|
|
SoundInput m_soundInput;
|
|
Modulator m_modulator;
|
|
SoundOutput m_soundOutput;
|
|
QThread * m_audioThread;
|
|
|
|
qint64 m_msErase;
|
|
qint64 m_secBandChanged;
|
|
qint64 m_freqMoon;
|
|
qint64 m_freqNominal;
|
|
qint64 m_dialFreqTx;
|
|
|
|
double m_s6;
|
|
|
|
float m_DTtol;
|
|
float m_rxavg;
|
|
|
|
qint32 m_waterfallAvg;
|
|
qint32 m_ntx;
|
|
qint32 m_timeout;
|
|
qint32 m_XIT;
|
|
qint32 m_setftx;
|
|
qint32 m_ndepth;
|
|
qint32 m_sec0;
|
|
qint32 m_RxLog;
|
|
qint32 m_nutc0;
|
|
qint32 m_nrx;
|
|
qint32 m_ntr;
|
|
qint32 m_tx;
|
|
qint32 m_hsym;
|
|
qint32 m_TRperiod;
|
|
qint32 m_nsps;
|
|
qint32 m_hsymStop;
|
|
qint32 m_len1;
|
|
qint32 m_inGain;
|
|
qint32 m_ncw;
|
|
qint32 m_secID;
|
|
qint32 m_repeatMsg;
|
|
qint32 m_watchdogLimit;
|
|
qint32 m_astroFont;
|
|
qint32 m_nSubMode;
|
|
qint32 m_MinW;
|
|
qint32 m_tol;
|
|
qint32 m_nclearave;
|
|
qint32 m_minSync;
|
|
qint32 m_dBm;
|
|
qint32 m_pctx;
|
|
qint32 m_nseq;
|
|
|
|
bool m_btxok; //True if OK to transmit
|
|
bool m_diskData;
|
|
bool m_loopall;
|
|
bool m_decoderBusy;
|
|
bool m_txFirst;
|
|
bool m_auto;
|
|
bool m_restart;
|
|
bool m_startAnother;
|
|
bool m_saveDecoded;
|
|
bool m_saveAll;
|
|
bool m_widebandDecode;
|
|
bool m_call3Modified;
|
|
bool m_dataAvailable;
|
|
bool m_killAll;
|
|
bool m_bdecoded;
|
|
bool m_monitorStartOFF;
|
|
bool m_pskReporterInit;
|
|
bool m_noSuffix;
|
|
bool m_toRTTY;
|
|
bool m_dBtoComments;
|
|
bool m_promptToLog;
|
|
bool m_blankLine;
|
|
bool m_insertBlank;
|
|
bool m_displayDXCCEntity;
|
|
bool m_clearCallGrid;
|
|
bool m_bMiles;
|
|
bool m_decodedText2;
|
|
bool m_freeText;
|
|
bool m_quickCall;
|
|
bool m_73TxDisable;
|
|
bool m_sentFirst73;
|
|
int m_currentMessageType;
|
|
QString m_currentMessage;
|
|
int m_lastMessageType;
|
|
QString m_lastMessageSent;
|
|
bool m_runaway;
|
|
bool m_bMultipleOK;
|
|
bool m_lockTxFreq;
|
|
bool m_tx2QSO;
|
|
bool m_CATerror;
|
|
bool m_bAstroData;
|
|
bool m_bEME;
|
|
bool m_bShMsgs;
|
|
bool m_uploadSpots;
|
|
bool m_uploading;
|
|
bool m_txNext;
|
|
bool m_grid6;
|
|
bool m_tuneup;
|
|
bool m_bTxTime;
|
|
bool m_rxDone;
|
|
bool m_bSimplex; // not using split even if it is available
|
|
int m_nonWSPRTab;
|
|
bool m_bEchoTxOK;
|
|
bool m_bTransmittedEcho;
|
|
bool m_bEchoTxed;
|
|
|
|
float m_pctZap;
|
|
|
|
// labels in status bar
|
|
QLabel * tx_status_label;
|
|
QLabel * mode_label;
|
|
QLabel * last_tx_label;
|
|
QLabel * auto_tx_label;
|
|
|
|
QProgressBar* progressBar;
|
|
|
|
QMessageBox msgBox0;
|
|
|
|
QFuture<void>* future1;
|
|
QFuture<void>* future2;
|
|
QFuture<void>* future3;
|
|
QFutureWatcher<void>* watcher1;
|
|
QFutureWatcher<void>* watcher2;
|
|
QFutureWatcher<void>* watcher3;
|
|
|
|
QProcess proc_jt9;
|
|
QProcess p1;
|
|
QProcess p3;
|
|
|
|
WSPRNet *wsprNet;
|
|
|
|
QTimer m_guiTimer;
|
|
QTimer* ptt1Timer; //StartTx delay
|
|
QTimer* ptt0Timer; //StopTx delay
|
|
QTimer* logQSOTimer;
|
|
QTimer* killFileTimer;
|
|
QTimer* tuneButtonTimer;
|
|
QTimer* uploadTimer;
|
|
QTimer* tuneATU_Timer;
|
|
|
|
QString m_path;
|
|
QString m_pbdecoding_style1;
|
|
QString m_pbmonitor_style;
|
|
QString m_pbAutoOn_style;
|
|
QString m_pbTune_style;
|
|
QString m_baseCall;
|
|
QString m_hisCall;
|
|
QString m_hisGrid;
|
|
QString m_appDir;
|
|
QString m_dxccPfx;
|
|
QString m_palette;
|
|
QString m_dateTime;
|
|
QString m_mode;
|
|
QString m_modeTx;
|
|
QString m_fname;
|
|
QString m_rpt;
|
|
QString m_rptSent;
|
|
QString m_rptRcvd;
|
|
QString m_qsoStart;
|
|
QString m_qsoStop;
|
|
QString m_cmnd;
|
|
QString m_msgSent0;
|
|
QString m_fileToSave;
|
|
QString m_band;
|
|
QString m_c2name;
|
|
|
|
QStringList m_prefix;
|
|
QStringList m_suffix;
|
|
QStringList m_sunriseBands;
|
|
QStringList m_dayBands;
|
|
QStringList m_sunsetBands;
|
|
QStringList m_nightBands;
|
|
QStringList m_tuneBands;
|
|
|
|
QHash<QString,bool> m_pfx;
|
|
QHash<QString,bool> m_sfx;
|
|
|
|
QDateTime m_dateTimeQSO;
|
|
|
|
QSharedMemory *mem_jt9;
|
|
SignalMeter *signalMeter;
|
|
LogBook m_logBook;
|
|
DecodedText m_QSOText;
|
|
unsigned m_msAudioOutputBuffered;
|
|
unsigned m_framesAudioInputBuffered;
|
|
unsigned m_downSampleFactor;
|
|
QThread::Priority m_audioThreadPriority;
|
|
bool m_bandEdited;
|
|
bool m_splitMode;
|
|
bool m_monitoring;
|
|
bool m_transmitting;
|
|
bool m_tune;
|
|
Frequency m_lastMonitoredFrequency;
|
|
double m_toneSpacing;
|
|
int m_firstDecode;
|
|
QProgressDialog m_optimizingProgress;
|
|
QTimer m_heartbeat;
|
|
MessageClient * m_messageClient;
|
|
PSK_Reporter *psk_Reporter;
|
|
|
|
//---------------------------------------------------- private functions
|
|
void readSettings();
|
|
void setDecodedTextFont (QFont const&);
|
|
void writeSettings();
|
|
void createStatusBar();
|
|
void updateStatusBar();
|
|
void msgBox(QString t);
|
|
void genStdMsgs(QString rpt);
|
|
void lookup();
|
|
void ba2msg(QByteArray ba, char* message);
|
|
void msgtype(QString t, QLineEdit* tx);
|
|
void stub();
|
|
void statusChanged();
|
|
void qsy(Frequency f);
|
|
bool gridOK(QString g);
|
|
bool shortList(QString callsign);
|
|
void transmit (double snr = 99.);
|
|
void rigFailure (QString const& reason, QString const& detail);
|
|
void pskSetLocal ();
|
|
void displayDialFrequency ();
|
|
void transmitDisplay (bool);
|
|
void processMessage(QString const& messages, qint32 position, bool ctrl);
|
|
void replyToCQ (QTime, qint32 snr, float delta_time, quint32 delta_frequency, QString const& mode, QString const& message_text);
|
|
void replayDecodes ();
|
|
void postDecode (bool is_new, QString const& message);
|
|
void enable_DXCC_entity (bool on);
|
|
void switch_mode (Mode);
|
|
void WSPR_scheduling ();
|
|
void astroCalculations (QDateTime const&, bool adjust);
|
|
};
|
|
|
|
extern void getfile(QString fname, int ntrperiod);
|
|
extern void savewav(QString fname, int ntrperiod);
|
|
extern int killbyname(const char* progName);
|
|
extern void getDev(int* numDevices,char hostAPI_DeviceName[][50],
|
|
int minChan[], int maxChan[],
|
|
int minSpeed[], int maxSpeed[]);
|
|
extern int ptt(int nport, int ntx, int* iptt, int* nopen);
|
|
extern int next_tx_state(int pctx);
|
|
|
|
extern "C" {
|
|
//----------------------------------------------------- C and Fortran routines
|
|
void symspec_(int* k, int* ntrperiod, int* nsps, int* ingain, int* minw,
|
|
float* px, float s[], float* df3, int* nhsym, int* npts8);
|
|
|
|
void gen4_(char* msg, int* ichk, char* msgsent, int itone[],
|
|
int* itext, int len1, int len2);
|
|
|
|
void gen9_(char* msg, int* ichk, char* msgsent, int itone[],
|
|
int* itext, int len1, int len2);
|
|
|
|
void gen65_(char* msg, int* ichk, char* msgsent, int itone[],
|
|
int* itext, int len1, int len2);
|
|
|
|
void genwspr_(char* msg, char* msgsent, int itone[], int len1, int len2);
|
|
|
|
bool stdmsg_(const char* msg, int len);
|
|
|
|
void azdist_(char* MyGrid, char* HisGrid, double* utch, int* nAz, int* nEl,
|
|
int* nDmiles, int* nDkm, int* nHotAz, int* nHotABetter,
|
|
int len1, int len2);
|
|
|
|
void morse_(char* msg, int* icw, int* ncw, int len);
|
|
|
|
int ptt_(int nport, int ntx, int* iptt, int* nopen);
|
|
|
|
int fftwf_import_wisdom_from_filename(const char *);
|
|
int fftwf_export_wisdom_to_filename(const char *);
|
|
|
|
void wspr_downsample_(short int d2[], int* k);
|
|
void savec2_(char* fname, int* m_TRseconds, double* m_dialFreq, int len1);
|
|
|
|
void avecho_( short id2[], int* dop, int* nfrit, int* nqual, float* f1,
|
|
float* level, float* sigdb, float* snr, float* dfreq,
|
|
float* width);
|
|
}
|
|
|
|
#endif // MAINWINDOW_H
|