The HMC5883 only needs power (3v3), ground, and the two wires of a TWI.
One of the larger API changes of the port is the Arduino line:
Wire.requestFrom( HMC5883_ADDRESS_MAG, 6 );
Which takes the TWI address of the chip you want 6 bytes from. It has to be prefixed by another TWI transmission to set the read byte address to start from where you would like, in this case HMC5883_REGISTER_MAG_OUT_X_H_M = 0x03.
On the Bonescript side this becomes the following. The TWI address isn't used because the wire object already knows that, but you pass the register address to start reading from directly to the request to read bytes:
self.wire.readBytes( HMC5883_REGISTER_MAG_OUT_X_H_M,
BUFFER_SIZE,
function(err, res) { ... });
I pushed the code up to github bbbMagnetometerHMC5883. Note that getting "north" requires both a proper declination angle for your location and also some modification to allow for how your magneto chip is physically oriented on your robot. Actual use of the chip is really easy with the async style of nodejs.
I pushed the code up to github bbbMagnetometerHMC5883. Note that getting "north" requires both a proper declination angle for your location and also some modification to allow for how your magneto chip is physically oriented on your robot. Actual use of the chip is really easy with the async style of nodejs.
No comments:
Post a Comment