Package Exports
- magic-home
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (magic-home) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Magic Home for Node
Functionality ported from https://github.com/beville/flux_led to Node.js.
Features
Control lights which are usually controlled with this app with Node.
Control: Turn lights on and off. Set colors. Start effects. Make programmatic effects.
Discovery: Discover lights on the network (Not implemented yet)
CustomMode: Install custom effects (color fade, jump or strobe) with up to 16 colors (Not implemented yet)
Installation
npm install magic-home
Usage
Simple example:
var MagicHomeControl = require('magic-home').Control;
var light = new MagicHomeControl("192.168.1.100");
light.turnOn(function(err, success) {
//do something with the result
});
More examples are in the test directory.
Methods
Control
constructor(address)
Creates a new instance of the API. This does not connect to the light yet.
turnOn(callback)
turnOff(callback)
setColor(red, green, blue, callback)
setColorWithBrightness(red, green, blue, brightness, callback)
Convenience method to automatically scale down the rgb values to match the brightness parameter
setPattern(pattern, speed, callback)
Sets the light to play a built-in pattern. The pattern
parameter is a string which indicates the pattern (complete list below). The speed parameter has to be between 0 and 100.
queryState(callback)
Gets the state of the light. Example state:
{
"on": true,
"mode": "color", //color, warm_white, custom, special, or one of the build in patterns
"speed": 50, //playback speed of the current pattern
"color": {
"red": 255,
"green": 0,
"blue": 255
},
"warm_white_percent": 0
}
startEffectMode(callback)
Start the effect mode. In this mode, a single connection will be kept open, instead of reconnecting for every command. The callback gets called with one parameter, which is the EffectInterface
(documented below). An example can be found in test/effect_test.js.
EffectInterface
An instance of this class is obtained by calling startEffectMode
.
start(interval_function)
Starts the effect mode. The interval_function
will be called every time the last command has been fully processed. It will be called without any parameters.
setColor(red, green, blue)
This method is only supposed to be called from within the interval_function
. Sets the color.
delay(milliseconds)
This method is only supposed to be called from within the interval_function
. Calling this method, will lead to the next call to the interval function to happen after the specified time.
stop()
Closes the connection to the light and leads to the interval function not being called anymore.
Discovery
Not implemented yet
CustomMode
Not implemented yet
Pattern list
seven_color_cross_fade
red_gradual_change
green_gradual_change
blue_gradual_change
yellow_gradual_change
cyan_gradual_change
purple_gradual_change
white_gradual_change
red_green_cross_fade
red_blue_cross_fade
green_blue_cross_fade
seven_color_strobe_flash
red_strobe_flash
green_strobe_flash
blue_stobe_flash
yellow_strobe_flash
cyan_strobe_flash
purple_strobe_flash
white_strobe_flash
seven_color_jumping