mirror of
				https://github.com/hyperion-project/hyperion.ng.git
				synced 2025-03-01 10:33:28 +00:00 
			
		
		
		
	* Handle Exceptions in main & Pythoninit * Have SSDPDiscover generic again * Have SSDPDiscover generic again * Change Info- to Debug logs as technical service messages * Nanoleaf - When switched on, ensure UDP mode * Include SQL Database in Cross-Compile instructions * Fix Clazy (QT code checker) and clang Warnings * Stop LedDevice:write for disabled device * Nanoleaf: Fix uint printfs * NanoLeaf: Fix indents to tabs * NanoLeaf - Add debug verbosity switches * Device switchability support, FileDevice with timestamp support * Nanoleaf Light Panels now support External Control V2 * Enhance LedDeviceFile by Timestamp + fix readyness * Stop color stream, if LedDevice disabled * Nanoleaf - remove switchability * Fix MultiColorAdjustment, if led-range is greater lednum * Fix logging * LedFileDevice/LedDevice - add testing support * New "Led Test" effect * LedDeviceFile - Add chrono include + Allow Led rewrites for testing * Stabilize Effects for LedDevices where latchtime = 0 * Update LedDeviceFile, allow latchtime = 0 * Distangle LinearColorSmoothing and LEDDevice, Fix Effect configuration updates * Updates LedDeviceFile - Initialize via Open * Updates LedDeviceNanoleaf - Initialize via Open, Remove throwing exceptions * Updates ProviderUDP - Remove throwing exceptions * Framebuffer - Use precise timer * TestSpi - Align to LedDevice updates * Pretty Print CrossCompileHowTo as markdown-file * Ensure that output is only written when LedDevice is ready * Align APA102 Device to new device staging * Logger - Remove clang warnings on extra semicolon * Devices SPI - Align to Device stages and methods * Fix cppcheck and clang findings * Add Code-Template for new Devices * Align devices to stages and methods, clean-up some code * Allow to reopen LedDevice without restart * Revert change "Remove Connect (PriorityMuxer::visiblePriorityChanged -> Hyperion::update) due to double writes" * Remove visiblePriorityChanged from LedDevice to decouple LedDevice from hyperion logic * Expose LedDevice getLedCount and align signedness
		
			
				
	
	
		
			76 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| // Linux-SPI includes
 | |
| #include <linux/spi/spidev.h>
 | |
| 
 | |
| // Hyperion includes
 | |
| #include <leddevice/LedDevice.h>
 | |
| 
 | |
| ///
 | |
| /// The ProviderSpi implements an abstract base-class for LedDevices using the SPI-device.
 | |
| ///
 | |
| class ProviderSpi : public LedDevice
 | |
| {
 | |
| public:
 | |
| 	///
 | |
| 	/// Constructs specific LedDevice
 | |
| 	///
 | |
| 	ProviderSpi();
 | |
| 
 | |
| 	///
 | |
| 	/// Sets configuration
 | |
| 	///
 | |
| 	/// @param deviceConfig the json device config
 | |
| 	/// @return true if success
 | |
|     virtual bool init(const QJsonObject &deviceConfig) override;
 | |
| 
 | |
| 	///
 | |
| 	/// Destructor of the LedDevice; closes the output device if it is open
 | |
| 	///
 | |
|     virtual ~ProviderSpi() override;
 | |
| 
 | |
| 	///
 | |
| 	/// Opens and configures the output device
 | |
| 	///
 | |
| 	/// @return Zero on succes else negative
 | |
| 	///
 | |
|     int open() override;
 | |
| 
 | |
| public slots:
 | |
| 	///
 | |
| 	/// Closes the output device.
 | |
| 	/// Includes switching-off the device and stopping refreshes
 | |
| 	///
 | |
| 	virtual void close() override;
 | |
| 
 | |
| protected:
 | |
| 	///
 | |
| 	/// Writes the given bytes/bits to the SPI-device and sleeps the latch time to ensure that the
 | |
| 	/// values are latched.
 | |
| 	///
 | |
| 	/// @param[in[ size The length of the data
 | |
| 	/// @param[in] data The data
 | |
| 	///
 | |
| 	/// @return Zero on succes else negative
 | |
| 	///
 | |
| 	int writeBytes(const unsigned size, const uint8_t *data);
 | |
| 
 | |
| 	/// The name of the output device
 | |
| 	QString _deviceName;
 | |
| 
 | |
| 	/// The used baudrate of the output device
 | |
| 	int _baudRate_Hz;
 | |
| 
 | |
| 	/// The File Identifier of the opened output device (or -1 if not opened)
 | |
| 	int _fid;
 | |
| 
 | |
| 	/// which spi clock mode do we use? (0..3)
 | |
| 	int _spiMode;
 | |
| 
 | |
| 	/// 1=>invert the data pattern
 | |
| 	bool _spiDataInvert;
 | |
| 
 | |
| 	/// The transfer structure for writing to the spi-device
 | |
| 	spi_ioc_transfer _spi;
 | |
| };
 |