mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-26 10:30:25 -04:00 
			
		
		
		
	(Possibly need to add a mutex for MainCore::getPluginManager, so only can be used by one thread) Add option to automatically update My Position based on GPS. This is started in MainCore, so we get position as soon as possible. Don't set QFileDialog::DontUseNativeDialog on Android, as Qt's file dialog can't access user storage. Set globally for Linux/Windows, rather than for each dialog. MainWindow: - Add welcome dialog for Android. - Don't show menu bar or status bar on Android to save screen space. - On Android, change tab position when screen orientation changes. - Load default configurations and presets first time SDRangel is run. - Change loadConfiguration to use a QProgressDialog rather than QMessageBox, as the latter was crashing on Android. - Use DialogPositioner to ensure dialogs are on screen.
		
			
				
	
	
		
			368 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			368 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef INCLUDE_PLUGININTERFACE_H
 | |
| #define INCLUDE_PLUGININTERFACE_H
 | |
| 
 | |
| #include <QtPlugin>
 | |
| #include <QString>
 | |
| 
 | |
| #include "export.h"
 | |
| 
 | |
| struct SDRBASE_API PluginDescriptor {
 | |
|     const QString hardwareId;
 | |
| 	// general plugin description
 | |
| 	const QString displayedName;
 | |
| 	const QString version;
 | |
| 	const QString copyright;
 | |
| 	const QString website;
 | |
| 	bool licenseIsGPL;
 | |
| 	const QString sourceCodeURL;
 | |
| };
 | |
| 
 | |
| class PluginAPI;
 | |
| class DeviceAPI;
 | |
| class DeviceSet;
 | |
| class DeviceUISet;
 | |
| class FeatureUISet;
 | |
| class WebAPIAdapterInterface;
 | |
| class DeviceGUI;
 | |
| class QWidget;
 | |
| class DeviceSampleSource;
 | |
| class DeviceSampleSink;
 | |
| class DeviceSampleMIMO;
 | |
| class BasebandSampleSink;
 | |
| class BasebandSampleSource;
 | |
| class MIMOChannel;
 | |
| class ChannelAPI;
 | |
| class ChannelGUI;
 | |
| class ChannelWebAPIAdapter;
 | |
| class DeviceWebAPIAdapter;
 | |
| class FeatureWebAPIAdapter;
 | |
| class Feature;
 | |
| class FeatureGUI;
 | |
| 
 | |
| class SDRBASE_API PluginInterface {
 | |
| public:
 | |
| 	struct SamplingDevice
 | |
| 	{
 | |
|         enum SamplingDeviceType
 | |
|         {
 | |
|             PhysicalDevice,
 | |
|             BuiltInDevice
 | |
|         };
 | |
| 
 | |
|         enum StreamType
 | |
|         {
 | |
|             StreamSingleRx, //!< Exposes a single input stream that can be one of the streams of a physical device
 | |
|             StreamSingleTx, //!< Exposes a single output stream that can be one of the streams of a physical device
 | |
|             StreamMIMO      //!< May expose any number of input and/or output streams
 | |
|         };
 | |
| 
 | |
| 		QString displayedName;    //!< The human readable name
 | |
| 		QString hardwareId;       //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
 | |
| 		QString id;               //!< The internal plugin ID corresponding to the device (i.e. for HackRF input, for HackRF output ...)
 | |
| 		QString serial;           //!< The device serial number defined by the vendor or a fake one (SDRplay)
 | |
| 		int sequence;             //!< The device sequence. >0 when more than one device of the same type is connected
 | |
| 		SamplingDeviceType type;  //!< The sampling device type for behavior information
 | |
| 		StreamType streamType;    //!< This is the type of stream supported
 | |
| 		int deviceNbItems;        //!< Number of items (or streams) in the device. >1 for composite devices.
 | |
| 		int deviceItemIndex;      //!< For composite devices this is the Rx or Tx stream index. -1 if not initialized
 | |
| 		int claimed;              //!< This is the device set index if claimed else -1
 | |
|         bool removed;             //!< Set if device has been removed
 | |
| 
 | |
| 		SamplingDevice(const QString& _displayedName,
 | |
|                 const QString& _hardwareId,
 | |
| 				const QString& _id,
 | |
| 				const QString& _serial,
 | |
| 				int _sequence,
 | |
| 				SamplingDeviceType _type,
 | |
| 				StreamType _streamType,
 | |
| 				int _deviceNbItems,
 | |
| 				int _deviceItemIndex) :
 | |
| 			displayedName(_displayedName),
 | |
| 			hardwareId(_hardwareId),
 | |
| 			id(_id),
 | |
| 			serial(_serial),
 | |
| 			sequence(_sequence),
 | |
| 			type(_type),
 | |
| 			streamType(_streamType),
 | |
| 			deviceNbItems(_deviceNbItems),
 | |
| 			deviceItemIndex(_deviceItemIndex),
 | |
| 			claimed(-1),
 | |
|             removed(false)
 | |
| 		{ }
 | |
| 
 | |
|         bool operator==(const SamplingDevice& rhs) const
 | |
|         {
 | |
|             return displayedName == rhs.displayedName
 | |
|                 && hardwareId == rhs.hardwareId
 | |
|                 && id == rhs.id
 | |
|                 && serial == rhs.serial;
 | |
|         }
 | |
| 	};
 | |
| 	typedef QList<SamplingDevice> SamplingDevices;
 | |
| 
 | |
|     /** This is the device from which the sampling devices are derived. For physical devices this represents
 | |
|      * a single physical unit (a LimeSDR, HackRF, BladeRF, RTL-SDR dongle, ...) that is enumerated once and
 | |
|      * reported in the system so that the "sampling devices" used in the system can be registered
 | |
|     */
 | |
|     struct OriginDevice
 | |
|     {
 | |
|         QString displayableName; //!< A human readable name
 | |
|         QString hardwareId;      //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
 | |
|         QString serial;          //!< The device serial number defined by the vendor or a fake one (SDRplay)
 | |
|         int sequence;            //!< The device sequence in order of enumeration
 | |
|         int nbRxStreams;         //!< Number of receiver streams
 | |
|         int nbTxStreams;         //!< Number of transmitter streams
 | |
| 
 | |
|         OriginDevice(
 | |
|                 const QString& _displayableName,
 | |
|                 const QString& _hardwareId,
 | |
| 				const QString& _serial,
 | |
| 				int _sequence,
 | |
|                 int _nbRxStreams,
 | |
|                 int _nbTxStreams
 | |
|         ) :
 | |
|             displayableName(_displayableName),
 | |
|             hardwareId(_hardwareId),
 | |
|             serial(_serial),
 | |
|             sequence(_sequence),
 | |
|             nbRxStreams(_nbRxStreams),
 | |
|             nbTxStreams(_nbTxStreams)
 | |
|         {}
 | |
|     };
 | |
|     typedef QList<OriginDevice> OriginDevices;
 | |
| 
 | |
|     virtual ~PluginInterface() { }
 | |
| 
 | |
| 	virtual const PluginDescriptor& getPluginDescriptor() const = 0;
 | |
| 	virtual void initPlugin(PluginAPI* pluginAPI) = 0;
 | |
| 
 | |
| 	// channel Rx plugins
 | |
| 
 | |
|     virtual void createRxChannel(DeviceAPI *deviceAPI, BasebandSampleSink **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
|     virtual ChannelGUI* createRxChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             BasebandSampleSink *rxChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) rxChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // channel Tx plugins
 | |
| 
 | |
|     virtual void createTxChannel(DeviceAPI *deviceAPI, BasebandSampleSource **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
| 	virtual ChannelGUI* createTxChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             BasebandSampleSource *txChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) txChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // channel MIMO plugins
 | |
| 
 | |
|     virtual void createMIMOChannel(DeviceAPI *deviceAPI, MIMOChannel **bs, ChannelAPI **cs) const
 | |
|     {
 | |
|         (void) deviceAPI;
 | |
|         (void) bs;
 | |
|         (void) cs;
 | |
|     }
 | |
| 
 | |
| 	virtual ChannelGUI* createMIMOChannelGUI(
 | |
|             DeviceUISet *deviceUISet,
 | |
|             MIMOChannel *mimoChannel) const
 | |
|     {
 | |
|         (void) deviceUISet;
 | |
|         (void) mimoChannel;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any channel
 | |
| 
 | |
|     virtual ChannelWebAPIAdapter* createChannelWebAPIAdapter() const
 | |
|     {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any feature
 | |
| 
 | |
|     virtual FeatureWebAPIAdapter* createFeatureWebAPIAdapter() const
 | |
|     {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // any device
 | |
| 
 | |
|     virtual void enumOriginDevices(QStringList& listedHwIds, OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) listedHwIds;
 | |
|         (void) originDevices;
 | |
|     }
 | |
| 
 | |
|     virtual SamplingDevice::SamplingDeviceType getSamplingDeviceType() const {
 | |
|         return SamplingDevice::SamplingDeviceType::PhysicalDevice;
 | |
|     }
 | |
| 
 | |
|     virtual QString getDeviceTypeId() const {
 | |
|         return QString("");
 | |
|     }
 | |
| 
 | |
|     // device source plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleSources(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleSourcePluginInstanceGUI(
 | |
|             const QString& sourceId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) sourceId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleSource* createSampleSourcePluginInstance( // creates the input "core"
 | |
|             const QString& sourceId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) sourceId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 	virtual void deleteSampleSourcePluginInstanceInput(DeviceSampleSource *source);
 | |
| 
 | |
|     virtual int getDefaultRxNbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
| 	// device sink plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleSinks(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleSinkPluginInstanceGUI(
 | |
|             const QString& sinkId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) sinkId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleSink* createSampleSinkPluginInstance( // creates the output "core"
 | |
|             const QString& sinkId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) sinkId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual void deleteSampleSinkPluginInstanceOutput(DeviceSampleSink *sink);
 | |
| 
 | |
|     virtual int getDefaultTxNbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     // device MIMO plugins only
 | |
| 
 | |
| 	virtual SamplingDevices enumSampleMIMO(const OriginDevices& originDevices)
 | |
|     {
 | |
|         (void) originDevices;
 | |
|         return SamplingDevices();
 | |
|     }
 | |
| 
 | |
| 	virtual DeviceGUI* createSampleMIMOPluginInstanceGUI(
 | |
|             const QString& mimoId,
 | |
|             QWidget **widget,
 | |
|             DeviceUISet *deviceUISet)
 | |
|     {
 | |
|         (void) mimoId;
 | |
|         (void) widget;
 | |
|         (void) deviceUISet;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual DeviceSampleMIMO* createSampleMIMOPluginInstance( // creates the MIMO "core"
 | |
|             const QString& mimoId,
 | |
|             DeviceAPI *deviceAPI)
 | |
|     {
 | |
|         (void) mimoId;
 | |
|         (void) deviceAPI;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual void deleteSampleMIMOPluginInstanceMIMO(DeviceSampleMIMO *mimo);
 | |
| 
 | |
|     virtual int getDefaultMIMONbItems() const {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     // Callback to allow plugin to add elements to top-level GUI (such as menu items)
 | |
|     virtual bool createTopLevelGUI()
 | |
|     {
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     // Serialise global plugin settings (i.e. settings that are not per-instance)
 | |
|     virtual QByteArray serializeGlobalSettings() const
 | |
|     {
 | |
|         QByteArray empty;
 | |
|         return empty;
 | |
|     }
 | |
| 
 | |
|     virtual bool deserializeGlobalSettings(const QByteArray& data)
 | |
|     {
 | |
|         (void) data;
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     // all devices
 | |
| 
 | |
|     virtual DeviceWebAPIAdapter* createDeviceWebAPIAdapter() const {
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     // Features
 | |
| 
 | |
|     virtual FeatureGUI* createFeatureGUI(FeatureUISet *featureUISet, Feature *feature) const
 | |
|     {
 | |
|         (void) featureUISet;
 | |
|         (void) feature;
 | |
|         return nullptr;
 | |
|     }
 | |
| 
 | |
|     virtual Feature* createFeature(WebAPIAdapterInterface *webAPIAdapterInterface) const
 | |
|     {
 | |
|         (void) webAPIAdapterInterface;
 | |
|         return nullptr;
 | |
|     }
 | |
| };
 | |
| 
 | |
| Q_DECLARE_INTERFACE(PluginInterface, "SDRangel.PluginInterface/0.1")
 | |
| 
 | |
| #endif // INCLUDE_PLUGININTERFACE_H
 |