mirror of
				https://github.com/hyperion-project/hyperion.ng.git
				synced 2025-03-01 10:33:28 +00:00 
			
		
		
		
	Revert "Merge pull request #7 from tvdzwan/master"
This reverts commitae218b85ff[formerly b57904d64f0fbdd2e97f0326de4378489206e357], reversing changes made tocda2232080[formerly 6949fe847d9c4181c924a13ed0715ecd71b98499]. Former-commit-id: 0261bc7735663dba45681a5c0e4026b4c1fddeba
This commit is contained in:
		| @@ -23,10 +23,8 @@ git submodule update | ||||
| mkdir "$HYPERION_DIR/build" | ||||
| cd "$HYPERION_DIR/build" | ||||
|  | ||||
| # run cmake to generate make files on the raspberry pi WITHOUT PWM SUPPORT | ||||
| # run cmake to generate make files on the raspberry pi | ||||
| cmake  -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| # run cmake to generate make files on the raspberry pi WITH PWM SUPPORT | ||||
| cmake -DENABLE_WS2812BPWM=ON -DENABLE_WS281XPWM=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| # or if you are not compiling on the raspberry pi and need to disable the Dispmanx grabber and support for spi devices | ||||
| cmake -DENABLE_DISPMANX=OFF -DENABLE_SPIDEV=OFF -DENABLE_X11=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| # as an alternative for the dispmanx grabber on non-rpi devices (e.g. cubox-i) you could try the framebuffer grabber | ||||
| @@ -46,7 +44,7 @@ cmake -DENABLE_DISPMANX=OFF -DENABLE_SPIDEV=OFF -DENABLE_V4L2=OFF -DENABLE_OSX=O | ||||
| make | ||||
| # or if you have a system with more then 1 cpu core | ||||
| make -j 4 | ||||
| # "4" is  the number of cpu cores (e.g. 4 on RPi2 and RPi3), this makes compile faster | ||||
| # "4" is  the number of cpu cores (e.g. 4 on RPi2), this makes compile faster | ||||
|  | ||||
| #after compile, to remove any stuff not needed for a release version. | ||||
| strip bin/* | ||||
|   | ||||
| @@ -1,43 +1,43 @@ | ||||
| #!/bin/sh | ||||
| # create all directly for release with -DCMAKE_BUILD_TYPE=Release -Wno-dev | ||||
| # Create the x64 build | ||||
| mkdir build-x32x64 | ||||
| cd build-x32x64 | ||||
| mkdir build-x64 | ||||
| cd build-x64 | ||||
| cmake -DENABLE_DISPMANX=OFF -DENABLE_X11=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| make -j 4 | ||||
| cd .. | ||||
|  | ||||
| # Create the x32 build | ||||
| #mkdir build-x32 | ||||
| #cd build-x32 | ||||
| #cmake -DIMPORT_PROTOC=../build-x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_X11=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| #make -j 4 | ||||
| #cd .. | ||||
| mkdir build-x32 | ||||
| cd build-x32 | ||||
| cmake -DIMPORT_PROTOC=../build-x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_X11=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| make -j 4 | ||||
| cd .. | ||||
|  | ||||
| # Create the RPI build | ||||
| mkdir build-rpi | ||||
| cd build-rpi | ||||
| cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-rpi.cmake" -DIMPORT_PROTOC=../build-x32x64/protoc_export.cmake -DENABLE_WS2812BPWM=ON -DENABLE_WS281XPWM=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-rpi.cmake" -DIMPORT_PROTOC=../build-x64/protoc_export.cmake -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| make -j 4 | ||||
| cd .. | ||||
|  | ||||
| # Create the WETEK build | ||||
| mkdir build-wetek | ||||
| cd build-wetek | ||||
| cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-rpi.cmake" -DIMPORT_PROTOC=../build-x32x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_FB=ON -DENABLE_AMLOGIC=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-rpi.cmake" -DIMPORT_PROTOC=../build-x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_FB=ON -DENABLE_AMLOGIC=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| make -j 4 | ||||
| cd .. | ||||
|  | ||||
| # Create the IMX6 build | ||||
| #mkdir build-imx6 | ||||
| #cd build-imx6 | ||||
| #cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-imx6.cmake" -DIMPORT_PROTOC=../build-x32x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_FB=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| #make -j 4 | ||||
| #cd .. | ||||
| mkdir build-imx6 | ||||
| cd build-imx6 | ||||
| cmake -DCMAKE_TOOLCHAIN_FILE="../Toolchain-imx6.cmake" -DIMPORT_PROTOC=../build-x64/protoc_export.cmake -DENABLE_DISPMANX=OFF -DENABLE_FB=ON -DCMAKE_BUILD_TYPE=Release -Wno-dev .. | ||||
| make -j 4 | ||||
| cd .. | ||||
|  | ||||
| bin/create_release.sh . x32x64 | ||||
| #bin/create_release.sh . x32 | ||||
| bin/create_release.sh . x64 | ||||
| bin/create_release.sh . x32 | ||||
| bin/create_release.sh . rpi | ||||
| bin/create_release.sh . wetek | ||||
| #bin/create_release.sh . imx6 | ||||
| bin/create_release.sh . imx6 | ||||
|  | ||||
|   | ||||
| @@ -22,6 +22,6 @@ tar --create --verbose --gzip --absolute-names --show-transformed-names --derefe | ||||
| 	"$IMX6_ROOTFS/usr/lib/arm-linux-gnueabihf/libXext.so.6" \ | ||||
| 	"$IMX6_ROOTFS/usr/lib/arm-linux-gnueabihf/libXrender.so.1" \ | ||||
| 	"$IMX6_ROOTFS/usr/lib/arm-linux-gnueabihf/libXt.so.6" \ | ||||
| 	"./openelec/hyperiond.sh" \ | ||||
| 	"./openelec/hyperion-remote.sh" | ||||
| 	"./hyperiond.sh" \ | ||||
| 	"./hyperion-remote.sh" | ||||
|  | ||||
|   | ||||
| @@ -18,23 +18,23 @@ fi | ||||
| outfile="$repodir/deploy/hyperion_$buildid.tar.gz" | ||||
| echo create $outfile | ||||
|  | ||||
| tar --create --gzip --absolute-names --show-transformed-names --ignore-failed-read\ | ||||
| tar --create --verbose --gzip --absolute-names --show-transformed-names --ignore-failed-read\ | ||||
| 	--file "$outfile" \ | ||||
| 	--transform "s:$builddir/bin/:hyperion/bin/:" \ | ||||
| 	--transform "s:$repodir/effects/:hyperion/effects/:" \ | ||||
| 	--transform "s:$repodir/config/:hyperion/config/:" \ | ||||
| 	--transform "s:$repodir/bin/service/hyperion.init.sh:hyperion/init.d/hyperion.init.sh:" \ | ||||
| 	--transform "s:$repodir/bin/service/hyperion.systemd.sh:hyperion/init.d/hyperion.systemd.sh:" \ | ||||
| 	--transform "s:$repodir/bin/service/hyperion.initctl.sh:hyperion/init.d/hyperion.initctl.sh:" \ | ||||
| 	--transform "s:$repodir/bin/hyperion.init.sh:hyperion/init.d/hyperion.init.sh:" \ | ||||
| 	--transform "s:$repodir/bin/hyperion.systemd.sh:hyperion/init.d/hyperion.systemd.sh:" \ | ||||
| 	--transform "s:$repodir/bin/hyperion.initctl.sh:hyperion/init.d/hyperion.initctl.sh:" \ | ||||
| 	--transform "s://:/:g" \ | ||||
| 	"$builddir/bin/hyperiond" \ | ||||
| 	"$builddir/bin/hyperion-remote" \ | ||||
| 	"$builddir/bin/hyperion-v4l2" \ | ||||
| 	"$builddir/bin/hyperion-x11" \ | ||||
| 	"$builddir/bin/hyperion-dispmanx" \ | ||||
| 	"$builddir/bin/gpio2spi" \ | ||||
| 	"$builddir/bin/dispmanx2png" \ | ||||
| 	"$repodir/effects/"* \ | ||||
| 	"$repodir/bin/service/hyperion.init.sh" \ | ||||
| 	"$repodir/bin/service/hyperion.systemd.sh" \ | ||||
| 	"$repodir/bin/service/hyperion.initctl.sh" \ | ||||
| 	"$repodir/bin/hyperion.init.sh" \ | ||||
| 	"$repodir/bin/hyperion.systemd.sh" \ | ||||
| 	"$repodir/bin/hyperion.initctl.sh" \ | ||||
| 	"$repodir/config/hyperion.config.json" | ||||
|  | ||||
|   | ||||
| @@ -31,10 +31,10 @@ OS_OSMC=`grep -m1 -c OSMC /etc/issue` | ||||
| CPU_RPI=`grep -m1 -c 'BCM2708\|BCM2709\|BCM2710' /proc/cpuinfo` | ||||
| CPU_IMX6=`grep -m1 -c i.MX6 /proc/cpuinfo` | ||||
| CPU_WETEK=`grep -m1 -c Amlogic /proc/cpuinfo` | ||||
| CPU_X32X64=`uname -m | grep 'x86_32\|i686\|x86_64' | wc -l` | ||||
| #CPU_X32=`uname -m | grep 'x86_32\|i686' | wc -l` | ||||
| CPU_X64=`uname -m | grep x86_64 | wc -l` | ||||
| CPU_X32=`uname -m | grep 'x86_32\|i686' | wc -l` | ||||
| # Check that we have a known configuration | ||||
| if [ $CPU_RPI -ne 1 ] && [ $CPU_IMX6 -ne 1 ] && [ $CPU_WETEK -ne 1 ] && [ $CPU_X32X64 -ne 1 ]; then | ||||
| if [ $CPU_RPI -ne 1 ] && [ $CPU_IMX6 -ne 1 ] && [ $CPU_WETEK -ne 1 ] && [ $CPU_X64 -ne 1 ] && [ $CPU_X32 -ne 1 ]; then | ||||
| 	echo '---> Critical Error: CPU information does not match any known releases -> abort' | ||||
| 	exit 1 | ||||
| fi | ||||
| @@ -117,12 +117,12 @@ elif [ $CPU_IMX6 -eq 1 ]; then | ||||
| elif [ $CPU_WETEK -eq 1 ]; then | ||||
| 	HYPERION_RELEASE=$HYPERION_ADDRESS/hyperion_wetek.tar.gz | ||||
| 	OE_DEPENDECIES=$HYPERION_ADDRESS/hyperion.deps.openelec-rpi.tar.gz | ||||
| elif [ $CPU_X32X64 -eq 1 ]; then | ||||
| 	HYPERION_RELEASE=$HYPERION_ADDRESS/hyperion_x32x64.tar.gz | ||||
| 	OE_DEPENDECIES=$HYPERION_ADDRESS/hyperion.deps.openelec-x32x64.tar.gz | ||||
| #elif [ $CPU_X32 -eq 1 ]; then | ||||
| #	HYPERION_RELEASE=$HYPERION_ADDRESS/hyperion_x32.tar.gz | ||||
| #	OE_DEPENDECIES=$HYPERION_ADDRESS/hyperion.deps.openelec-x32x64.tar.gz | ||||
| elif [ $CPU_X64 -eq 1 ]; then | ||||
| 	HYPERION_RELEASE=$HYPERION_ADDRESS/hyperion_x64.tar.gz | ||||
| 	OE_DEPENDECIES=$HYPERION_ADDRESS/hyperion.deps.openelec-rpi.tar.gz | ||||
| elif [ $CPU_X32 -eq 1 ]; then | ||||
| 	HYPERION_RELEASE=$HYPERION_ADDRESS/hyperion_x32.tar.gz | ||||
| 	OE_DEPENDECIES=$HYPERION_ADDRESS/hyperion.deps.openelec-rpi.tar.gz | ||||
| else | ||||
| 	echo "---> Critical Error: Target platform unknown -> abort" | ||||
| 	exit 1 | ||||
|   | ||||
| @@ -64,7 +64,7 @@ fi | ||||
| #Disabling and delete service files | ||||
| if [ $USE_INITCTL -eq 1 ]; then | ||||
| 	echo '---> Delete and disable Hyperion initctl script' | ||||
| 	rm -v /etc/init/hyperion.conf 2>/dev/null | ||||
| 	rm -v /etc/init/hyperion 2>/dev/null | ||||
| 	initctl reload-configuration | ||||
| elif [ $OS_OPENELEC -eq 1 ]; then | ||||
| 	# Remove Hyperion from OpenELEC autostart.sh | ||||
| @@ -94,8 +94,6 @@ else | ||||
| 	rm -v /usr/bin/hyperiond 2>/dev/null | ||||
| 	rm -v /usr/bin/hyperion-remote 2>/dev/null | ||||
| 	rm -v /usr/bin/hyperion-v4l2 2>/dev/null | ||||
| 	rm -v /usr/bin/hyperion-dispmanx 2>/dev/null | ||||
| 	rm -v /usr/bin/hyperion-x11 2>/dev/null | ||||
| 	rm -v /etc/hyperion.config.json 2>/dev/null | ||||
| 	echo "---> Remove binaries" | ||||
| 	rm -rv /opt/hyperion 2>/dev/null | ||||
|   | ||||
| @@ -1 +0,0 @@ | ||||
| e55dbd6444d070f519115e83e4fda96b6911e5db | ||||
| @@ -1 +1 @@ | ||||
| 63bda72fdb3fb504564f067795f74e9b45eb99ba | ||||
| 6465f4220aa1a8b4bdfed82492bf3ed079f586c4 | ||||
| @@ -1 +1 @@ | ||||
| 03e78585af86a18889ecd1d8b910d76155608cd6 | ||||
| 752ebb4ffc19892d1c99af0993913eb922195e38 | ||||
							
								
								
									
										1
									
								
								deploy/hyperion_x32.tar.gz.REMOVED.git-id
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								deploy/hyperion_x32.tar.gz.REMOVED.git-id
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| f7b19344829d6df11bd624bbf722a5d8ec6b1dbe | ||||
| @@ -1 +0,0 @@ | ||||
| 9a00f3dc5684cab0fede56348df91c046634ff11 | ||||
							
								
								
									
										1
									
								
								deploy/hyperion_x64.tar.gz.REMOVED.git-id
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								deploy/hyperion_x64.tar.gz.REMOVED.git-id
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| 294f14bdc79d9d8306432681bf3c8468a4097a48 | ||||
| @@ -1,165 +0,0 @@ | ||||
| // Automatically generated configuration file for 'Hyperion daemon' | ||||
| // Generated by: HyperCon (The Hyperion deamon configuration file builder) | ||||
| // Created with HyperCon V1.00.0 (11.03.2016) | ||||
|  | ||||
| { | ||||
| 	/// Device configuration contains the following fields:  | ||||
| 	/// * 'name'       : The user friendly name of the device (only used for display purposes) | ||||
| 	/// * 'type'       : The type of the device or leds (known types for now are | ||||
| 	/// APA102, Adalight, AdalightAPA102, AmbiLed, Atmo, Hyperion-USBASP-WS2801, Hyperion-USBASP-WS2812, Lightberry, Lightpack, LPD6803, LPD8806, Multi-Lightpack, P9813, Paintpack, PhilipsHUE, PiBlaster, SEDU, Test, ThinkerForge, TPM2, WS2801, WS2812b, None) | ||||
| 	/// * [device type specific configuration] | ||||
| 	/// * 'colorOrder' : The order of the color bytes ('rgb', 'rbg', 'bgr', etc.). | ||||
| 	/// | ||||
| 	/// * 'Specific for AtmoOrb: | ||||
| 	/// * 'transitiontime'	 : Set the time of transition between color of Orb (not implemented) | ||||
| 	/// * 'port'  		 : Multicast UDP port | ||||
| 	/// * 'numLeds'	 : Number of leds in Orb | ||||
| 	/// * 'orbIds'	 : The Orb ids to use  | ||||
| 	/// * 'switchOffOnBlack': Define if Orb is to switch off when black is detected  | ||||
| 	"device" : | ||||
| 	{	 | ||||
| 		"name"       : "MyPi", | ||||
| 		"type"       : "atmoorb", | ||||
| 		"output"     : "239.15.18.2", | ||||
| 		"transitiontime"     : 0, | ||||
| 		"port"     : 49692, | ||||
| 		"numLeds"     : 24, | ||||
| 		"orbIds"   : "1", | ||||
| 		"switchOffOnBlack"     : true, | ||||
| 		"colorOrder" : "rgb" | ||||
| 	}, | ||||
|  | ||||
| 	/// Color manipulation configuration used to tune the output colors to specific surroundings.  | ||||
| 	/// The configuration contains a list of color-transforms. Each transform contains the  | ||||
| 	/// following fields: | ||||
| 	///  * 'id'   : The unique identifier of the color transformation (eg 'device_1')	///  * 'leds' : The indices (or index ranges) of the leds to which this color transform applies | ||||
| 	///             (eg '0-5, 9, 11, 12-17'). The indices are zero based.	///  * 'hsv' : The manipulation in the Hue-Saturation-Value color domain with the following  | ||||
| 	///            tuning parameters: | ||||
| 	///            - 'saturationGain'  The gain adjustement of the saturation | ||||
| 	///            - 'valueGain'       The gain adjustement of the value | ||||
| 	///  * 'red'/'green'/'blue' : The manipulation in the Red-Green-Blue color domain with the  | ||||
| 	///                           following tuning parameters for each channel: | ||||
| 	///            - 'threshold'       The minimum required input value for the channel to be on  | ||||
| 	///                                (else zero) | ||||
| 	///            - 'gamma'           The gamma-curve correction factor | ||||
| 	///            - 'blacklevel'      The lowest possible value (when the channel is black) | ||||
| 	///            - 'whitelevel'      The highest possible value (when the channel is white) | ||||
| 	/// | ||||
| 	/// Next to the list with color transforms there is also a smoothing option. | ||||
| 	///  * 'smoothing' : Smoothing of the colors in the time-domain with the following tuning  | ||||
| 	///                  parameters: | ||||
| 	///            - 'type'            The type of smoothing algorithm ('linear' or 'none') | ||||
| 	///            - 'time_ms'         The time constant for smoothing algorithm in milliseconds | ||||
| 	///            - 'updateFrequency' The update frequency of the leds in Hz | ||||
| 	///            - 'updateDelay'     The delay of the output to leds (in periods of smoothing) | ||||
| 	"color" : | ||||
| 	{ | ||||
| 		"transform" : | ||||
| 		[ | ||||
| 			{ | ||||
| 				"id"   : "default", | ||||
| 				"leds" : "*", | ||||
| 				"hsv" : | ||||
| 				{ | ||||
| 					"saturationGain" : 1.0000, | ||||
| 					"valueGain"      : 1.0000 | ||||
| 				}, | ||||
| 				"red" : | ||||
| 				{ | ||||
| 					"threshold"  : 0.0000, | ||||
| 					"gamma"      : 2.2000, | ||||
| 					"blacklevel" : 0.0000, | ||||
| 					"whitelevel" : 1.0000 | ||||
| 				}, | ||||
| 				"green" : | ||||
| 				{ | ||||
| 					"threshold"  : 0.0000, | ||||
| 					"gamma"      : 2.2000, | ||||
| 					"blacklevel" : 0.0000, | ||||
| 					"whitelevel" : 1.0000 | ||||
| 				}, | ||||
| 				"blue" : | ||||
| 				{ | ||||
| 					"threshold"  : 0.0000, | ||||
| 					"gamma"      : 2.2000, | ||||
| 					"blacklevel" : 0.0000, | ||||
| 					"whitelevel" : 1.0000 | ||||
| 				} | ||||
| 			} | ||||
| 		], | ||||
| 		"smoothing" : | ||||
| 		{ | ||||
| 			"type"            : "linear", | ||||
| 			"time_ms"         : 100, | ||||
| 			"updateFrequency" : 60.0000, | ||||
| 			"updateDelay"     : 0 | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	/// The black border configuration, contains the following items:  | ||||
| 	///  * enable    			: true if the detector should be activated | ||||
| 	///  * threshold 			: Value below which a pixel is regarded as black (value between 0.0 and 1.0) | ||||
| 	///  * unknownFrameCnt		: Number of frames without any detection before the border is set to 0 (default 600) | ||||
| 	///  * borderFrameCnt		: Number of frames before a consistent detected border gets set (default 50) | ||||
| 	///  * maxInconsistentCnt 	: Number of inconsistent frames that are ignored before a new border gets a chance to proof consistency | ||||
| 	///  * blurRemoveCnt		: Number of pixels that get removed from the detected border to cut away blur (default 1) | ||||
| 	///  * mode 				: Border detection mode (values=default,classic,osd) | ||||
| 	"blackborderdetector" :  | ||||
| 	{ | ||||
| 		"enable" : false, | ||||
| 		"threshold" : 0.01, | ||||
| 		"unknownFrameCnt" : 600, | ||||
| 		"borderFrameCnt" : 50, | ||||
| 		"maxInconsistentCnt" : 10, | ||||
| 		"blurRemoveCnt" : 1, | ||||
| 		"mode" : "default" | ||||
| 	}, | ||||
|  | ||||
| 	/// The configuration of the effect engine, contains the following items:  | ||||
| 	///  * paths		: An array with absolute location(s) of directories with effects  | ||||
| 	///  * color 		: Set static color after boot -> set effect to "" (empty) and input the values [R,G,B] and set duration_ms NOT to 0 (use 1) instead  | ||||
| 	///  * effect 		: The effect selected as 'boot sequence'  | ||||
| 	///  * duration_ms	: The duration of the selected effect (0=endless)  | ||||
| 	///  * priority 	: The priority of the selected effect/static color (default=990) HINT: lower value result in HIGHER priority!  | ||||
| 	"effects" :  | ||||
| 	{ | ||||
| 		"paths" :  | ||||
| 		[ | ||||
| 			"/opt/hyperion/effects" | ||||
| 		] | ||||
| 	}, | ||||
| 	 | ||||
| 	/// The configuration of the Json server which enables the json remote interface | ||||
| 	///  * port : Port at which the json server is started | ||||
| 	"jsonServer" :  | ||||
| 	{ | ||||
| 		"port" : 19446 | ||||
| 	}, | ||||
|  | ||||
| 	/// The configuration of the Proto server which enables the protobuffer remote interface | ||||
| 	///  * port : Port at which the protobuffer server is started | ||||
| 	"protoServer" :  | ||||
| 	{ | ||||
| 		"port" : 19447 | ||||
| 	}, | ||||
|  | ||||
| 	///  The configuration for each individual led. This contains the specification of the area  | ||||
| 	///  averaged of an input image for each led to determine its color. Each item in the list  | ||||
| 	///  contains the following fields: | ||||
| 	///  * index: The index of the led. This determines its location in the string of leds; zero  | ||||
| 	///           being the first led. | ||||
| 	///  * hscan: The fractional part of the image along the horizontal used for the averaging  | ||||
| 	///           (minimum and maximum inclusive) | ||||
| 	///  * vscan: The fractional part of the image along the vertical used for the averaging  | ||||
| 	///           (minimum and maximum inclusive) | ||||
| 	"leds" :  | ||||
| 	[ | ||||
|         { | ||||
|             "index" : 0, | ||||
|             "hscan" : { "minimum" : 0.0000, "maximum" : 1.0000 }, | ||||
|             "vscan" : { "minimum" : 0.0000, "maximum" : 1.0000 } | ||||
|         } | ||||
| 	], | ||||
|  | ||||
| 	"endOfJson" : "endOfJson" | ||||
| } | ||||
| @@ -17,7 +17,6 @@ SET(Leddevice_QT_HEADERS | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAdalight.h | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAdalightApa102.h | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAmbiLed.h | ||||
|     ${CURRENT_SOURCE_DIR}/LedDeviceAtmoOrb.h | ||||
| 		${CURRENT_SOURCE_DIR}/LedDevicePhilipsHue.h | ||||
| 		${CURRENT_SOURCE_DIR}/LedHIDDevice.h | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceRawHID.h | ||||
| @@ -51,7 +50,6 @@ SET(Leddevice_SOURCES | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAdalight.cpp | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAdalightApa102.cpp | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceAmbiLed.cpp | ||||
|     ${CURRENT_SOURCE_DIR}/LedDeviceAtmoOrb.cpp | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceRawHID.cpp | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceLightpack.cpp | ||||
| 		${CURRENT_SOURCE_DIR}/LedDeviceMultiLightpack.cpp | ||||
|   | ||||
| @@ -1,131 +0,0 @@ | ||||
| // Local-Hyperion includes | ||||
| #include "LedDeviceAtmoOrb.h" | ||||
|  | ||||
| // qt includes | ||||
| #include <QtCore/qmath.h> | ||||
| #include <QEventLoop> | ||||
| #include <QtNetwork> | ||||
| #include <QNetworkReply> | ||||
|  | ||||
| #include <stdexcept> | ||||
| #include <string> | ||||
| #include <set> | ||||
|  | ||||
| AtmoOrbLight::AtmoOrbLight(unsigned int id) { | ||||
|     // Not implemented | ||||
| } | ||||
|  | ||||
| LedDeviceAtmoOrb::LedDeviceAtmoOrb(const std::string &output, bool switchOffOnBlack, | ||||
|                                    int transitiontime, int port, int numLeds, std::vector<unsigned int> orbIds) : | ||||
|         multicastGroup(output.c_str()), switchOffOnBlack(switchOffOnBlack), transitiontime(transitiontime), | ||||
|         multiCastGroupPort(port), numLeds(numLeds), orbIds(orbIds) { | ||||
|     manager = new QNetworkAccessManager(); | ||||
|     groupAddress = QHostAddress(multicastGroup); | ||||
|  | ||||
|     udpSocket = new QUdpSocket(this); | ||||
|     udpSocket->bind(multiCastGroupPort, QUdpSocket::ShareAddress | QUdpSocket::ReuseAddressHint); | ||||
|  | ||||
|     joinedMulticastgroup = udpSocket->joinMulticastGroup(groupAddress); | ||||
| } | ||||
|  | ||||
| int LedDeviceAtmoOrb::write(const std::vector <ColorRgb> &ledValues) { | ||||
|  | ||||
|     // If not in multicast group return | ||||
|     if (!joinedMulticastgroup) { | ||||
|         return 0; | ||||
|     } | ||||
|  | ||||
|     // Iterate through colors and set Orb color | ||||
|     // Start off with idx 1 as 0 is reserved for controlling all orbs at once | ||||
|     unsigned int idx = 1; | ||||
|     for (const ColorRgb &color : ledValues) { | ||||
|         // Options parameter: | ||||
|         // | ||||
|         // 1 = force off | ||||
|         // 2 = use lamp smoothing and validate by Orb ID | ||||
|         // 4 = validate by Orb ID | ||||
|         // | ||||
|  | ||||
|         if (switchOffOnBlack && color.red == 0 && color.green == 0 && color.blue == 0) { | ||||
|             // Force to black | ||||
|             for (unsigned int i = 0; i < orbIds.size(); i++) { | ||||
|                 if (orbIds[i] == idx) { | ||||
|                     setColor(idx, color, 1); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             // Default send color | ||||
|             for (unsigned int i = 0; i < orbIds.size(); i++) { | ||||
|                 if (orbIds[i] == idx) { | ||||
|                     setColor(idx, color, 4); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Next light id. | ||||
|         idx++; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| void LedDeviceAtmoOrb::setColor(unsigned int orbId, const ColorRgb &color, int commandType) { | ||||
|     QByteArray bytes; | ||||
|     bytes.resize(5 + numLeds * 3); | ||||
|     bytes.fill('\0'); | ||||
|  | ||||
|     // Command identifier: C0FFEE | ||||
|     bytes[0] = 0xC0; | ||||
|     bytes[1] = 0xFF; | ||||
|     bytes[2] = 0xEE; | ||||
|  | ||||
|     // Command type | ||||
|     bytes[3] = 2; | ||||
|  | ||||
|     // Orb ID | ||||
|     bytes[4] = orbId; | ||||
|  | ||||
|     // RED / GREEN / BLUE | ||||
|     bytes[5] = color.red; | ||||
|     bytes[6] = color.green; | ||||
|     bytes[7] = color.blue; | ||||
|  | ||||
|     sendCommand(bytes); | ||||
| } | ||||
|  | ||||
| void LedDeviceAtmoOrb::sendCommand(const QByteArray &bytes) { | ||||
|     QByteArray datagram = bytes; | ||||
|     udpSocket->writeDatagram(datagram.data(), datagram.size(), | ||||
|                              groupAddress, multiCastGroupPort); | ||||
| } | ||||
|  | ||||
| int LedDeviceAtmoOrb::switchOff() { | ||||
|     for (unsigned int i = 0; i < orbIds.size(); i++) { | ||||
|         QByteArray bytes; | ||||
|         bytes.resize(5 + numLeds * 3); | ||||
|         bytes.fill('\0'); | ||||
|  | ||||
|         // Command identifier: C0FFEE | ||||
|         bytes[0] = 0xC0; | ||||
|         bytes[1] = 0xFF; | ||||
|         bytes[2] = 0xEE; | ||||
|  | ||||
|         // Command type | ||||
|         bytes[3] = 1; | ||||
|  | ||||
|         // Orb ID | ||||
|         bytes[4] = orbIds[i]; | ||||
|  | ||||
|         // RED / GREEN / BLUE | ||||
|         bytes[5] = 0; | ||||
|         bytes[6] = 0; | ||||
|         bytes[7] = 0; | ||||
|  | ||||
|         sendCommand(bytes); | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| LedDeviceAtmoOrb::~LedDeviceAtmoOrb() { | ||||
|     delete manager; | ||||
| } | ||||
| @@ -1,129 +0,0 @@ | ||||
| #pragma once | ||||
|  | ||||
| // STL includes | ||||
| #include <string> | ||||
|  | ||||
| // Qt includes | ||||
| #include <QObject> | ||||
| #include <QString> | ||||
| #include <QNetworkAccessManager> | ||||
| #include <QHostAddress> | ||||
|  | ||||
| // Leddevice includes | ||||
| #include <leddevice/LedDevice.h> | ||||
|  | ||||
| class QUdpSocket; | ||||
|  | ||||
| class AtmoOrbLight { | ||||
| public: | ||||
|     unsigned int id; | ||||
|  | ||||
|     /// | ||||
|     /// Constructs the light. | ||||
|     /// | ||||
|     /// @param id the orb id | ||||
|     AtmoOrbLight(unsigned int id); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Implementation for the AtmoOrb | ||||
|  * | ||||
|  * To use set the device to "atmoorb". | ||||
|  * | ||||
|  * @author RickDB (github) | ||||
|  */ | ||||
| class LedDeviceAtmoOrb : public QObject, public LedDevice { | ||||
|     Q_OBJECT | ||||
| public: | ||||
|     // Last color sent | ||||
|     int lastRed; | ||||
|     int lastGreen; | ||||
|     int lastBlue; | ||||
|  | ||||
|     // Multicast status | ||||
|     bool joinedMulticastgroup; | ||||
|  | ||||
|     /// | ||||
|     /// Constructs the device. | ||||
|     /// | ||||
|     /// @param output is the multicast address of Orbs | ||||
|     /// | ||||
|     /// @param switchOffOnBlack turn off Orbs on black (default: false) | ||||
|     /// | ||||
|     /// @param transitiontime is optional and not used at the moment | ||||
|     /// | ||||
|     /// @param port is the multicast port. | ||||
|     /// | ||||
|     /// @param numLeds is the total amount of leds per Orb | ||||
|     /// | ||||
|     /// @param array containing orb ids | ||||
|     /// | ||||
|     LedDeviceAtmoOrb(const std::string &output, bool switchOffOnBlack = | ||||
|     false, int transitiontime = 0, int port = 49692, int numLeds = 24, | ||||
|                      std::vector<unsigned int> orbIds = std::vector < unsigned int | ||||
|  | ||||
|     >()); | ||||
|  | ||||
|     /// | ||||
|     /// Destructor of this device | ||||
|     /// | ||||
|     virtual ~LedDeviceAtmoOrb(); | ||||
|  | ||||
|     /// | ||||
|     /// Sends the given led-color values to the Orbs | ||||
|     /// | ||||
|     /// @param ledValues The color-value per led | ||||
|     /// | ||||
|     /// @return Zero on success else negative | ||||
|     /// | ||||
|     virtual int write(const std::vector <ColorRgb> &ledValues); | ||||
|  | ||||
|     virtual int switchOff(); | ||||
|  | ||||
| private: | ||||
|     /// QNetworkAccessManager object for sending requests. | ||||
|     QNetworkAccessManager *manager; | ||||
|  | ||||
|     /// String containing multicast group IP address | ||||
|     QString multicastGroup; | ||||
|  | ||||
|     /// Switch off when detecting black | ||||
|     bool switchOffOnBlack; | ||||
|  | ||||
|     /// Transition time between colors (not implemented) | ||||
|     int transitiontime; | ||||
|  | ||||
|     /// Multicast port to send data to | ||||
|     int multiCastGroupPort; | ||||
|  | ||||
|     /// Number of leds in Orb, used to determine buffer size | ||||
|     int numLeds; | ||||
|  | ||||
|     /// QHostAddress object of multicast group IP address | ||||
|     QHostAddress groupAddress; | ||||
|  | ||||
|     /// QUdpSocket object used to send data over | ||||
|     QUdpSocket *udpSocket; | ||||
|  | ||||
|     /// Array of the orb ids. | ||||
|     std::vector<unsigned int> orbIds; | ||||
|  | ||||
|     /// | ||||
|     /// Set Orbcolor | ||||
|     /// | ||||
|     /// @param orbId the orb id | ||||
|     /// | ||||
|     /// @param color which color to set | ||||
|     /// | ||||
|     /// | ||||
|     /// @param commandType which type of command to send (off / smoothing / etc..) | ||||
|     /// | ||||
|     void setColor(unsigned int orbId, const ColorRgb &color, int commandType); | ||||
|  | ||||
|     /// | ||||
|     /// Send Orb command | ||||
|     /// | ||||
|     /// @param bytes the byte array containing command to send over multicast | ||||
|     /// | ||||
|     void sendCommand(const QByteArray &bytes); | ||||
| }; | ||||
| @@ -37,7 +37,6 @@ | ||||
| #include "LedDeviceTpm2.h" | ||||
| #include "LedDeviceAtmo.h" | ||||
| #include "LedDeviceAdalightApa102.h" | ||||
| #include "LedDeviceAtmoOrb.h" | ||||
|  | ||||
| #ifdef ENABLE_WS2812BPWM | ||||
| 	#include "LedDeviceWS2812b.h" | ||||
| @@ -246,35 +245,6 @@ LedDevice * LedDeviceFactory::construct(const Json::Value & deviceConfig) | ||||
| 		} | ||||
| 		device = new LedDevicePhilipsHue(output, username, switchOffOnBlack, transitiontime, lightIds); | ||||
| 	} | ||||
|   else if (type == "atmoorb") | ||||
|   { | ||||
| 		const std::string output = deviceConfig["output"].asString(); | ||||
| 		const bool switchOffOnBlack = deviceConfig.get("switchOffOnBlack", true).asBool(); | ||||
| 		const int transitiontime = deviceConfig.get("transitiontime", 1).asInt(); | ||||
| 		const int port = deviceConfig.get("port", 1).asInt(); | ||||
| 		const int numLeds = deviceConfig.get("numLeds", 1).asInt(); | ||||
| 	  	const std::string orbId = deviceConfig["orbIds"].asString(); | ||||
| 		std::vector<unsigned int> orbIds; | ||||
|  | ||||
| 		// If we find multiple Orb ids separate them and add to list | ||||
| 		const std::string separator (","); | ||||
| 		if (orbId.find(separator) != std::string::npos) { | ||||
| 			std::stringstream ss(orbId); | ||||
| 			std::vector<int> output; | ||||
| 			unsigned int i; | ||||
| 			while (ss >> i) { | ||||
| 				orbIds.push_back(i); | ||||
| 					if (ss.peek() == ',' || ss.peek() == ' ') | ||||
| 					ss.ignore(); | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			orbIds.push_back(atoi(orbId.c_str())); | ||||
| 		} | ||||
|  | ||||
| 		device = new LedDeviceAtmoOrb(output, switchOffOnBlack, transitiontime, port, numLeds, orbIds); | ||||
|   } | ||||
| 	else if (type == "test") | ||||
| 	{ | ||||
| 		const std::string output = deviceConfig["output"].asString(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user