mirror of
				https://github.com/hyperion-project/hyperion.ng.git
				synced 2025-03-01 10:33:28 +00:00 
			
		
		
		
	* std::string -> qstring part 1 * more string migration * more string migration ... * ... * more qstring mogrations add sysinfo via json * remove unneccessary includes * integrate sysinfo into webui
		
			
				
	
	
		
			130 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| // Qt includes
 | |
| #include <QString>
 | |
| #include <QColor>
 | |
| #include <QImage>
 | |
| #include <QTcpSocket>
 | |
| #include <QTimer>
 | |
| #include <QMap>
 | |
| 
 | |
| // hyperion util
 | |
| #include <utils/Image.h>
 | |
| #include <utils/ColorRgb.h>
 | |
| #include <utils/GrabbingMode.h>
 | |
| #include <utils/VideoMode.h>
 | |
| #include <utils/Logger.h>
 | |
| 
 | |
| #include <message.pb.h>
 | |
| 
 | |
| ///
 | |
| /// Connection class to setup an connection to the hyperion server and execute commands
 | |
| ///
 | |
| class ProtoConnection : public QObject
 | |
| {
 | |
| 
 | |
| 	Q_OBJECT
 | |
| 
 | |
| public:
 | |
| 	///
 | |
| 	/// Constructor
 | |
| 	///
 | |
| 	/// @param address The address of the Hyperion server (for example "192.168.0.32:19444)
 | |
| 	///
 | |
| 	ProtoConnection(const QString & address);
 | |
| 
 | |
| 	///
 | |
| 	/// Destructor
 | |
| 	///
 | |
| 	~ProtoConnection();
 | |
| 
 | |
| 	/// Do not read reply messages from Hyperion if set to true
 | |
| 	void setSkipReply(bool skip);
 | |
| 
 | |
| 	///
 | |
| 	/// Set all leds to the specified color
 | |
| 	///
 | |
| 	/// @param color The color
 | |
| 	/// @param priority The priority
 | |
| 	/// @param duration The duration in milliseconds
 | |
| 	///
 | |
| 	void setColor(const ColorRgb & color, int priority, int duration = 1);
 | |
| 
 | |
| 	///
 | |
| 	/// Set the leds according to the given image (assume the image is stretched to the display size)
 | |
| 	///
 | |
| 	/// @param image The image
 | |
| 	/// @param priority The priority
 | |
| 	/// @param duration The duration in milliseconds
 | |
| 	///
 | |
| 	void setImage(const Image<ColorRgb> & image, int priority, int duration = -1);
 | |
| 
 | |
| 	///
 | |
| 	/// Clear the given priority channel
 | |
| 	///
 | |
| 	/// @param priority The priority
 | |
| 	///
 | |
| 	void clear(int priority);
 | |
| 
 | |
| 	///
 | |
| 	/// Clear all priority channels
 | |
| 	///
 | |
| 	void clearAll();
 | |
| 
 | |
| 	///
 | |
| 	/// Send a command message and receive its reply
 | |
| 	///
 | |
| 	/// @param message The message to send
 | |
| 	///
 | |
| 	void sendMessage(const proto::HyperionRequest & message);
 | |
| 
 | |
| private slots:
 | |
| 	/// Try to connect to the Hyperion host
 | |
| 	void connectToHost();
 | |
| 
 | |
| 	///
 | |
| 	/// Slot called when new data has arrived
 | |
| 	///
 | |
| 	void readData();
 | |
| 
 | |
| signals:
 | |
| 
 | |
| 	///
 | |
| 	/// KODI Video Checker Message
 | |
| 	///
 | |
| 	void setGrabbingMode(const GrabbingMode mode);
 | |
| 	void setVideoMode(const VideoMode videoMode);
 | |
| 
 | |
| private:
 | |
| 
 | |
| 	///
 | |
| 	/// Parse a reply message
 | |
| 	///
 | |
| 	/// @param reply The received reply
 | |
| 	///
 | |
| 	/// @return true if the reply indicates success
 | |
| 	///
 | |
| 	bool parseReply(const proto::HyperionReply & reply);
 | |
| 
 | |
| private:
 | |
| 	/// The TCP-Socket with the connection to the server
 | |
| 	QTcpSocket _socket;
 | |
| 
 | |
| 	/// Host address
 | |
| 	QString _host;
 | |
| 
 | |
| 	/// Host port
 | |
| 	uint16_t _port;
 | |
| 
 | |
| 	/// Skip receiving reply messages from Hyperion if set
 | |
| 	bool _skipReply;
 | |
| 
 | |
| 	QTimer _timer;
 | |
| 	QAbstractSocket::SocketState  _prevSocketState;
 | |
| 	
 | |
| 	/// The buffer used for reading data from the socket
 | |
| 	QByteArray _receiveBuffer;
 | |
| 	
 | |
| 	Logger * _log;
 | |
| };
 |