mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 18:10:22 -04:00 
			
		
		
		
	
		
			
	
	
		
			225 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			225 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||
|  | // Copyright (C) 2015-2018 Edouard Griffiths, F4EXB.                             //
 | ||
|  | // Copyright (C) 2023 Jon Beniston, M7RCE                                        //
 | ||
|  | //                                                                               //
 | ||
|  | // 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 as version 3 of the License, or                  //
 | ||
|  | // (at your option) any later version.                                           //
 | ||
|  | //                                                                               //
 | ||
|  | // 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 V3 for more details.                               //
 | ||
|  | //                                                                               //
 | ||
|  | // You should have received a copy of the GNU General Public License             //
 | ||
|  | // along with this program. If not, see <http://www.gnu.org/licenses/>.          //
 | ||
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||
|  | 
 | ||
|  | #ifndef INCLUDE_NAVTEXDEMOD_H
 | ||
|  | #define INCLUDE_NAVTEXDEMOD_H
 | ||
|  | 
 | ||
|  | #include <vector>
 | ||
|  | 
 | ||
|  | #include <QNetworkRequest>
 | ||
|  | #include <QUdpSocket>
 | ||
|  | #include <QThread>
 | ||
|  | #include <QFile>
 | ||
|  | #include <QTextStream>
 | ||
|  | #include <QRegularExpression>
 | ||
|  | #include <QDateTime>
 | ||
|  | 
 | ||
|  | #include "dsp/basebandsamplesink.h"
 | ||
|  | #include "channel/channelapi.h"
 | ||
|  | #include "util/message.h"
 | ||
|  | #include "util/navtex.h"
 | ||
|  | 
 | ||
|  | #include "navtexdemodbaseband.h"
 | ||
|  | #include "navtexdemodsettings.h"
 | ||
|  | 
 | ||
|  | class QNetworkAccessManager; | ||
|  | class QNetworkReply; | ||
|  | class QThread; | ||
|  | class DeviceAPI; | ||
|  | class ScopeVis; | ||
|  | 
 | ||
|  | class NavtexDemod : public BasebandSampleSink, public ChannelAPI { | ||
|  | public: | ||
|  |     class MsgConfigureNavtexDemod : public Message { | ||
|  |         MESSAGE_CLASS_DECLARATION | ||
|  | 
 | ||
|  |     public: | ||
|  |         const NavtexDemodSettings& getSettings() const { return m_settings; } | ||
|  |         bool getForce() const { return m_force; } | ||
|  | 
 | ||
|  |         static MsgConfigureNavtexDemod* create(const NavtexDemodSettings& settings, bool force) | ||
|  |         { | ||
|  |             return new MsgConfigureNavtexDemod(settings, force); | ||
|  |         } | ||
|  | 
 | ||
|  |     private: | ||
|  |         NavtexDemodSettings m_settings; | ||
|  |         bool m_force; | ||
|  | 
 | ||
|  |         MsgConfigureNavtexDemod(const NavtexDemodSettings& settings, bool force) : | ||
|  |             Message(), | ||
|  |             m_settings(settings), | ||
|  |             m_force(force) | ||
|  |         { } | ||
|  |     }; | ||
|  | 
 | ||
|  |     class MsgCharacter : public Message { | ||
|  |         MESSAGE_CLASS_DECLARATION | ||
|  | 
 | ||
|  |     public: | ||
|  |         QString getCharacter() const { return m_character; } | ||
|  | 
 | ||
|  |         static MsgCharacter* create(const QString& character) | ||
|  |         { | ||
|  |             return new MsgCharacter(character); | ||
|  |         } | ||
|  | 
 | ||
|  |     private: | ||
|  |         QString m_character; | ||
|  | 
 | ||
|  |         MsgCharacter(const QString& character) : | ||
|  |             m_character(character) | ||
|  |         {} | ||
|  |     }; | ||
|  | 
 | ||
|  |     class MsgMessage : public Message { | ||
|  |         MESSAGE_CLASS_DECLARATION | ||
|  | 
 | ||
|  |     public: | ||
|  |         const NavtexMessage& getMessage() const { return m_message; } | ||
|  |         int getErrors() const { return m_errors; } | ||
|  |         float getRSSI() const { return m_rssi; } | ||
|  | 
 | ||
|  |         static MsgMessage* create(const NavtexMessage& message, int errors, float rssi) | ||
|  |         { | ||
|  |             return new MsgMessage(message, errors, rssi); | ||
|  |         } | ||
|  | 
 | ||
|  |     private: | ||
|  |         NavtexMessage m_message; | ||
|  |         int m_errors; | ||
|  |         float m_rssi; | ||
|  | 
 | ||
|  |         MsgMessage(const NavtexMessage& message, int errors, float rssi) : | ||
|  |             m_message(message), | ||
|  |             m_errors(errors), | ||
|  |             m_rssi(rssi) | ||
|  |         {} | ||
|  |     }; | ||
|  | 
 | ||
|  |     NavtexDemod(DeviceAPI *deviceAPI); | ||
|  |     virtual ~NavtexDemod(); | ||
|  |     virtual void destroy() { delete this; } | ||
|  |     virtual void setDeviceAPI(DeviceAPI *deviceAPI); | ||
|  |     virtual DeviceAPI *getDeviceAPI() { return m_deviceAPI; } | ||
|  | 
 | ||
|  |     using BasebandSampleSink::feed; | ||
|  |     virtual void feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool po); | ||
|  |     virtual void start(); | ||
|  |     virtual void stop(); | ||
|  |     virtual void pushMessage(Message *msg) { m_inputMessageQueue.push(msg); } | ||
|  |     virtual QString getSinkName() { return objectName(); } | ||
|  | 
 | ||
|  |     virtual void getIdentifier(QString& id) { id = objectName(); } | ||
|  |     virtual QString getIdentifier() const { return objectName(); } | ||
|  |     virtual const QString& getURI() const { return getName(); } | ||
|  |     virtual void getTitle(QString& title) { title = m_settings.m_title; } | ||
|  |     virtual qint64 getCenterFrequency() const { return m_settings.m_inputFrequencyOffset; } | ||
|  |     virtual void setCenterFrequency(qint64 frequency); | ||
|  | 
 | ||
|  |     virtual QByteArray serialize() const; | ||
|  |     virtual bool deserialize(const QByteArray& data); | ||
|  | 
 | ||
|  |     virtual int getNbSinkStreams() const { return 1; } | ||
|  |     virtual int getNbSourceStreams() const { return 0; } | ||
|  | 
 | ||
|  |     virtual qint64 getStreamCenterFrequency(int streamIndex, bool sinkElseSource) const | ||
|  |     { | ||
|  |         (void) streamIndex; | ||
|  |         (void) sinkElseSource; | ||
|  |         return 0; | ||
|  |     } | ||
|  | 
 | ||
|  |     virtual int webapiSettingsGet( | ||
|  |             SWGSDRangel::SWGChannelSettings& response, | ||
|  |             QString& errorMessage); | ||
|  | 
 | ||
|  |     virtual int webapiWorkspaceGet( | ||
|  |             SWGSDRangel::SWGWorkspaceInfo& response, | ||
|  |             QString& errorMessage); | ||
|  | 
 | ||
|  |     virtual int webapiSettingsPutPatch( | ||
|  |             bool force, | ||
|  |             const QStringList& channelSettingsKeys, | ||
|  |             SWGSDRangel::SWGChannelSettings& response, | ||
|  |             QString& errorMessage); | ||
|  | 
 | ||
|  |     virtual int webapiReportGet( | ||
|  |             SWGSDRangel::SWGChannelReport& response, | ||
|  |             QString& errorMessage); | ||
|  | 
 | ||
|  |     static void webapiFormatChannelSettings( | ||
|  |             SWGSDRangel::SWGChannelSettings& response, | ||
|  |             const NavtexDemodSettings& settings); | ||
|  | 
 | ||
|  |     static void webapiUpdateChannelSettings( | ||
|  |             NavtexDemodSettings& settings, | ||
|  |             const QStringList& channelSettingsKeys, | ||
|  |             SWGSDRangel::SWGChannelSettings& response); | ||
|  | 
 | ||
|  |     ScopeVis *getScopeSink(); | ||
|  |     double getMagSq() const { return m_basebandSink->getMagSq(); } | ||
|  | 
 | ||
|  |     void getMagSqLevels(double& avg, double& peak, int& nbSamples) { | ||
|  |         m_basebandSink->getMagSqLevels(avg, peak, nbSamples); | ||
|  |     } | ||
|  | /*    void setMessageQueueToGUI(MessageQueue* queue) override {
 | ||
|  |         ChannelAPI::setMessageQueueToGUI(queue); | ||
|  |         m_basebandSink->setMessageQueueToGUI(queue); | ||
|  |     }*/ | ||
|  | 
 | ||
|  |     uint32_t getNumberOfDeviceStreams() const; | ||
|  | 
 | ||
|  |     static const char * const m_channelIdURI; | ||
|  |     static const char * const m_channelId; | ||
|  | 
 | ||
|  | private: | ||
|  |     DeviceAPI *m_deviceAPI; | ||
|  |     QThread m_thread; | ||
|  |     NavtexDemodBaseband* m_basebandSink; | ||
|  |     NavtexDemodSettings m_settings; | ||
|  |     int m_basebandSampleRate; //!< stored from device message used when starting baseband sink
 | ||
|  |     qint64 m_centerFrequency; | ||
|  |     QUdpSocket m_udpSocket; | ||
|  |     QFile m_logFile; | ||
|  |     QTextStream m_logStream; | ||
|  | 
 | ||
|  |     QNetworkAccessManager *m_networkManager; | ||
|  |     QNetworkRequest m_networkRequest; | ||
|  | 
 | ||
|  |     virtual bool handleMessage(const Message& cmd); | ||
|  |     void applySettings(const NavtexDemodSettings& settings, bool force = false); | ||
|  |     void sendSampleRateToDemodAnalyzer(); | ||
|  |     void webapiReverseSendSettings(QList<QString>& channelSettingsKeys, const NavtexDemodSettings& settings, bool force); | ||
|  |     void webapiFormatChannelSettings( | ||
|  |         QList<QString>& channelSettingsKeys, | ||
|  |         SWGSDRangel::SWGChannelSettings *swgChannelSettings, | ||
|  |         const NavtexDemodSettings& settings, | ||
|  |         bool force | ||
|  |     ); | ||
|  |     void webapiFormatChannelReport(SWGSDRangel::SWGChannelReport& response); | ||
|  | 
 | ||
|  | private slots: | ||
|  |     void networkManagerFinished(QNetworkReply *reply); | ||
|  |     void handleIndexInDeviceSetChanged(int index); | ||
|  | 
 | ||
|  | }; | ||
|  | 
 | ||
|  | #endif // INCLUDE_NAVTEXDEMOD_H
 | ||
|  | 
 |