| [280] | 1 | // Part of BNC, a utility for retrieving decoding and | 
|---|
| [464] | 2 | // converting GNSS data streams from NTRIP broadcasters. | 
|---|
| [280] | 3 | // | 
|---|
| [464] | 4 | // Copyright (C) 2007 | 
|---|
| [280] | 5 | // German Federal Agency for Cartography and Geodesy (BKG) | 
|---|
|  | 6 | // http://www.bkg.bund.de | 
|---|
| [464] | 7 | // Czech Technical University Prague, Department of Geodesy | 
|---|
| [280] | 8 | // http://www.fsv.cvut.cz | 
|---|
|  | 9 | // | 
|---|
|  | 10 | // Email: euref-ip@bkg.bund.de | 
|---|
|  | 11 | // | 
|---|
|  | 12 | // This program is free software; you can redistribute it and/or | 
|---|
|  | 13 | // modify it under the terms of the GNU General Public License | 
|---|
|  | 14 | // as published by the Free Software Foundation, version 2. | 
|---|
|  | 15 | // | 
|---|
|  | 16 | // This program is distributed in the hope that it will be useful, | 
|---|
|  | 17 | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 18 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
|---|
|  | 19 | // GNU General Public License for more details. | 
|---|
|  | 20 | // | 
|---|
|  | 21 | // You should have received a copy of the GNU General Public License | 
|---|
|  | 22 | // along with this program; if not, write to the Free Software | 
|---|
|  | 23 | // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 
|---|
| [82] | 24 |  | 
|---|
|  | 25 | #ifndef BNCAPP_H | 
|---|
|  | 26 | #define BNCAPP_H | 
|---|
|  | 27 |  | 
|---|
| [4070] | 28 | #include <QtGui> | 
|---|
| [82] | 29 |  | 
|---|
| [243] | 30 | #include "bnccaster.h" | 
|---|
| [2519] | 31 | #include "bncrawfile.h" | 
|---|
| [511] | 32 | #include "RTCM3/RTCM3Decoder.h" | 
|---|
| [243] | 33 |  | 
|---|
| [2865] | 34 | class bncComb; | 
|---|
| [3027] | 35 | class bncPPPclient; | 
|---|
| [3232] | 36 | class bncTableItem; | 
|---|
| [2865] | 37 |  | 
|---|
| [82] | 38 | class bncApp : public QApplication { | 
|---|
|  | 39 | Q_OBJECT | 
|---|
| [4070] | 40 |  | 
|---|
|  | 41 | friend class bncSettings; | 
|---|
|  | 42 | QSettings::SettingsMap   _settings; | 
|---|
|  | 43 |  | 
|---|
| [82] | 44 | public: | 
|---|
| [3280] | 45 | enum e_mode {interactive, nonInteractive, batchPostProcessing}; | 
|---|
| [1291] | 46 | bncApp(int& argc, char* argv[], bool GUIenabled); | 
|---|
| [82] | 47 | virtual ~bncApp(); | 
|---|
| [3280] | 48 | e_mode mode() const {return _mode;} | 
|---|
|  | 49 | void   setMode(e_mode mode) {_mode = mode;} | 
|---|
| [937] | 50 | void setPort(int port); | 
|---|
|  | 51 | void setPortCorr(int port); | 
|---|
| [621] | 52 | void setCaster(bncCaster* caster) {_caster = caster;} | 
|---|
| [1155] | 53 | QDateTime* _currentDateAndTimeGPS; | 
|---|
| [1538] | 54 | void setConfFileName(const QString& confFileName); | 
|---|
|  | 55 | QString confFileName() const {return _confFileName;} | 
|---|
| [2518] | 56 | void writeRawData(const QByteArray& data, const QByteArray& staID, | 
|---|
|  | 57 | const QByteArray& format); | 
|---|
| [2672] | 58 | void storeGlonassSlotNums(const int GLOFreq[]); | 
|---|
|  | 59 | void getGlonassSlotNums(int GLOFreq[]); | 
|---|
| [2909] | 60 | void initCombination(); | 
|---|
| [3231] | 61 | void stopCombination(); | 
|---|
| [3927] | 62 | const QString& pgmName() {return _pgmName;} | 
|---|
|  | 63 | const QString& userName() {return _userName;} | 
|---|
| [4346] | 64 | QWidget* mainWindow() const {return _mainWindow;}; | 
|---|
|  | 65 | void setMainWindow(QWidget* mainWindow){_mainWindow = mainWindow;} | 
|---|
| [4447] | 66 | bool GUIenabled() const {return _GUIenabled;} | 
|---|
| [4167] | 67 | protected: | 
|---|
|  | 68 | virtual bool event(QEvent* ev); | 
|---|
| [1538] | 69 |  | 
|---|
| [82] | 70 | public slots: | 
|---|
| [1383] | 71 | void slotMessage(QByteArray msg, bool showOnScreen); | 
|---|
| [511] | 72 | void slotNewGPSEph(gpsephemeris* gpseph); | 
|---|
|  | 73 | void slotNewGlonassEph(glonassephemeris* glonasseph); | 
|---|
| [2770] | 74 | void slotNewGalileoEph(galileoephemeris* galileoeph); | 
|---|
| [974] | 75 | void slotNewCorrLine(QString line, QString staID, long coTime); | 
|---|
| [621] | 76 | void slotQuit(); | 
|---|
| [994] | 77 |  | 
|---|
| [1044] | 78 | signals: | 
|---|
| [1299] | 79 | void newMessage(QByteArray msg, bool showOnScreen); | 
|---|
| [1044] | 80 | void newEphGPS(gpsephemeris gpseph); | 
|---|
| [1164] | 81 | void newEphGlonass(glonassephemeris glonasseph); | 
|---|
| [2770] | 82 | void newEphGalileo(galileoephemeris galileoeph); | 
|---|
| [2001] | 83 | void newCorrections(QList<QString>); | 
|---|
| [621] | 84 |  | 
|---|
| [589] | 85 | private slots: | 
|---|
|  | 86 | void slotNewConnection(); | 
|---|
| [937] | 87 | void slotNewConnectionCorr(); | 
|---|
| [109] | 88 | private: | 
|---|
| [516] | 89 | void printEphHeader(); | 
|---|
| [600] | 90 | void printGPSEph(gpsephemeris* ep, bool printFile); | 
|---|
|  | 91 | void printGlonassEph(glonassephemeris* ep, bool printFile); | 
|---|
| [2770] | 92 | void printGalileoEph(galileoephemeris* ep, bool printFile); | 
|---|
| [944] | 93 | void printOutput(bool printFile, QTextStream* stream, | 
|---|
| [4020] | 94 | const QString& strV2, const QString& strV3); | 
|---|
| [976] | 95 | void dumpCorrs(long minTime, long maxTime); | 
|---|
| [3109] | 96 | void dumpCorrs(); | 
|---|
|  | 97 | void dumpCorrs(const QList<QString>& allCorrs); | 
|---|
| [991] | 98 | void messagePrivate(const QByteArray& msg); | 
|---|
| [4245] | 99 | void checkEphemeris(gpsephemeris* oldEph, gpsephemeris* newEph); | 
|---|
| [516] | 100 |  | 
|---|
|  | 101 | QFile*            _logFile; | 
|---|
|  | 102 | QTextStream*      _logStream; | 
|---|
|  | 103 | int               _logFileFlag; | 
|---|
|  | 104 | QMutex            _mutex; | 
|---|
| [1218] | 105 | QMutex            _mutexMessage; | 
|---|
| [533] | 106 | QString           _ephPath; | 
|---|
|  | 107 | QString           _ephFileNameGPS; | 
|---|
| [534] | 108 | int               _rinexVers; | 
|---|
| [533] | 109 | QFile*            _ephFileGPS; | 
|---|
|  | 110 | QTextStream*      _ephStreamGPS; | 
|---|
|  | 111 | QFile*            _ephFileGlonass; | 
|---|
|  | 112 | QTextStream*      _ephStreamGlonass; | 
|---|
| [2770] | 113 | QFile*            _ephFileGalileo; | 
|---|
|  | 114 | QTextStream*      _ephStreamGalileo; | 
|---|
| [516] | 115 | gpsephemeris*     _gpsEph[PRN_GPS_END - PRN_GPS_START + 1]; | 
|---|
|  | 116 | glonassephemeris* _glonassEph[PRN_GLONASS_END - PRN_GLONASS_START + 1]; | 
|---|
| [2770] | 117 | galileoephemeris* _galileoEph[PRN_GALILEO_END - PRN_GALILEO_START + 1]; | 
|---|
| [559] | 118 | QString           _userName; | 
|---|
|  | 119 | QString           _pgmName; | 
|---|
| [589] | 120 | int                 _port; | 
|---|
|  | 121 | QTcpServer*         _server; | 
|---|
|  | 122 | QList<QTcpSocket*>* _sockets; | 
|---|
| [937] | 123 | int                 _portCorr; | 
|---|
|  | 124 | QTcpServer*         _serverCorr; | 
|---|
|  | 125 | QList<QTcpSocket*>* _socketsCorr; | 
|---|
| [2181] | 126 | int                 _portNMEA; | 
|---|
|  | 127 | QTcpServer*         _serverNMEA; | 
|---|
|  | 128 | QList<QTcpSocket*>* _socketsNMEA; | 
|---|
| [621] | 129 | bncCaster*          _caster; | 
|---|
| [973] | 130 | long                _lastDumpCoSec; | 
|---|
|  | 131 | long                _waitCoTime; | 
|---|
| [975] | 132 | QMultiMap<long, QString>* _corrs; | 
|---|
| [1538] | 133 | QString             _confFileName; | 
|---|
| [2519] | 134 | QDate               _fileDate; | 
|---|
|  | 135 | bncRawFile*         _rawFile; | 
|---|
| [2673] | 136 | int                 _GLOFreq[PRN_GLONASS_NUM]; | 
|---|
| [2865] | 137 | bncComb*            _bncComb; | 
|---|
| [3280] | 138 | e_mode              _mode; | 
|---|
| [4346] | 139 | QWidget*            _mainWindow; | 
|---|
| [4447] | 140 | bool                _GUIenabled; | 
|---|
| [3027] | 141 | public: | 
|---|
|  | 142 | bncPPPclient*       _bncPPPclient; | 
|---|
| [3232] | 143 | QMap<int, bncTableItem*> _uploadTableItems; | 
|---|
| [82] | 144 | }; | 
|---|
|  | 145 | #endif | 
|---|