Transparent connection to local i2c-bus or remote i2c-bus via http rest interface.
$ i2c-server --help
Usage: i2c-server [options]
Options:
-b, --busNumber <nr> I²C-Bus number (default: "0")
-p, --port <port> Port to bind on (default: "8080")
-h, --host <hostname> Host, IP, ... to bind on (default: "0.0.0.0")
--help display help for command
$ i2c-read --help
Usage: i2c-read [options]
Options:
-p, --port <port> Port for send request to (default: "8080")
-h, --host <hostname> Host for send request to (default: "localhost")
-a, --address <address> i²C Address (default: "0")
-c, --count <count> Number of bytes to read (default: "1")
--help display help for command
For remote connection, first start server on the remote device.
// const {HardwareI2C} = require('@zebrajaeger/remote-i2c');
const {HardwareI2C, HttpI2C} = require('../src/client');
// for local execution use this one
//const i2c = new HardwareI2C(1); // on raspberry pi, we use i2c-bus #1
// for remote execution use this one
const i2c = new HttpI2C('192.168.178.69', 8080); // remote raspberry pi
(async () => {
try {
// read two 16 bit values (from i2c-joystick)
const buffer = await i2c.read(0x30, 4);
const x = buffer.readInt16LE(0);
const y = buffer.readInt16LE(2);
console.log({x, y});
// read as hex-string for whatever
const hexString = await i2c.readAsHex(0x30, 4);
console.log({hexString});
} catch (err) {
console.log('Error', err)
}
})();