node-brickpi
Node.js bindings for the BrickPi.
Usage
var BrickPi = var brickPi = '/dev/ttyAMA0' { brickPi}
Constructor options
All arguments are optional and order is not important.
Pass a string (path to a serial device), an options object and a callback function to invoke when the BrickPi is ready to use.
Default options are as follows:
var brickPi = baudrate: 500000 // the speed of the connection to the BrickPi timeout: 10000 // stop the motors if no communication is received in this time period (ms) debug: false // whether to print verbose debug output
LED
The BrickPi has two LEDs that can be accessed by passing an index to the led
function:
var led1 = brickPivar led2 = brickPi
An LED supports several methods:
brickPi // turn the LED onbrickPi // turn the LED offbrickPi // if the LED is on, turn it off, otherwise turn it on
Motors
var motor = brickPi // latermotor // continuous motion - full speed aheadmotor // stopmotor // reverse // rotationmotor // rotate 180 degreesmotor // rotate 180 degrees in the opposite direction // optionally specify a speedmotor // rotate 180 degrees at full speedmotor // rotate 180 degrees at half speed brickPibrickPi // immediately stop all motors
Sensors
Valid sensor types are Distance, Light, Sound and Touch.
// add sensorsvar distance = brickPivar light = brickPivar sound = brickPivar touch = brickPi // laterdistancevalue { // value is 0-255 in cm} lightvalue { // value is 0-100 in %}soundvalue { // value is 0-100 in %}touchvalue { // value is true or false}
Notes
What about EV3, NXT2, etc?
I only have the NXT kit, sorry. Hardware donations and/or pull requests gratefully accepted.
Why is the motor control so imprecise?
NXT motors are continuous servos equipped with encoders. This means that you tell the motor how fast to spin then read the encoders to work out what position the motor is in. Once it reaches the desired location, you stop the motor. Because the motor is a mechanical device stopping it involves it slowing down before stopping completely by which point it will most likely be slightly past the desired location. Normal servos do not have this problem because the PWM duty cycle set corresponds to a given orientation of the servo horn.
What about sensor port 5?
The second generation BrickPi has five sensor ports. This driver has been ported from the Python version which doesn't support the fifth sensor port. If a driver that does support it emerges I can add support.