// Part of BNC, a utility for retrieving decoding and // converting GNSS data streams from NTRIP broadcasters. // // Copyright (C) 2007 // German Federal Agency for Cartography and Geodesy (BKG) // http://www.bkg.bund.de // Czech Technical University Prague, Department of Geodesy // http://www.fsv.cvut.cz // // Email: euref-ip@bkg.bund.de // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation, version 2. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #ifndef RTCM3CODECODER_H #define RTCM3CODECODER_H #include #include #include #include "GPSDecoder.h" extern "C" { #ifdef USE_SSR_RTCM #include "../RTCM3/clock_and_orbit/clock_orbit_rtcm.h" #elif USE_SSR_IGS #include "../RTCM3/clock_and_orbit/clock_orbit_igs.h" #endif } class RTCM3coDecoder : public QObject, public GPSDecoder { Q_OBJECT public: RTCM3coDecoder(const QString& staID); virtual ~RTCM3coDecoder(); virtual t_irc Decode(char* buffer, int bufLen, std::vector& errmsg); virtual int corrGPSEpochTime() const {return int(_lastTime.gpssec());} signals: void newOrbCorrections(QList); void newClkCorrections(QList); void newCodeBiases(QList); void newPhaseBiases(QList); void newTec(t_vTec); void newMessage(QByteArray msg, bool showOnScreen); void providerIDChanged(QString staID); private: void reset(); void setEpochTime(); void sendResults(); void reopen(); void checkProviderID(); std::string codeTypeToRnxType(char system, CodeType type) const; std::ofstream* _out; QString _staID; QString _fileNameSkl; QString _fileName; QByteArray _buffer; ClockOrbit _clkOrb; CodeBias _codeBias; PhaseBias _phaseBias; VTEC _vTEC; int _providerID[3]; bncTime _lastTime; QMap _IODs; QMap > _orbCorrections; QMap > _clkCorrections; QMap _lastClkCorrections; QMap > _codeBiases; QMap > _phaseBiases; QMap _vTecMap; }; #endif