Blinker node.js library for hardware. Works with Raspberry Pi, Banana Pi, linux, windows, macos.
MIT License
本SDK可用于 Linux/Windows/MacOS 设备MQTT接入 亦适用于树莓派等带操作系统的嵌入式设备
使用WiFi接入,当设备和手机在同一个局域网中,为局域网通信 其余情况,使用MQTT远程通信
开始使用前您需要做好如下准备:
下载并安装blinker APP Android下载: 点击下载 或 在android应用商店搜索“blinker”下载安装 IOS下载: 点击下载 或 在app store中搜索“blinker”下载
运行blinker程序需要最新nodejs LTS版本及Ts-Node支持
npm i -g ts-node
git clone https://github.com/blinker-iot/blinker-js.git
cd blinker-js
npm i
.\example\example_hello.ts 为入门示例, 替换示例中的以下语句,修改参数为app中申请到的设备的Secret Key
let device = new BlinkerDevice('xxxxxxxxxxxx');
运行示例程序:
ts-node .\example\example_hello.ts
blinker在局域网通信时会使用到81端口,如遇到权限报错,请使用sudo等方式提权运行
在APP中点击刚才您添加的设备,即可进入控制界面,点点按钮就可以控制设备了 另一个按钮也点下试试,放心,您的手机不会爆炸~
看看添加设备
看看Nodejs开发入门 和 JavaScript/TypeScript 支持库函数参考)
看看Github
看看自定义界面
看看pigpio
import { BlinkerDevice } from '../lib/blinker';
import { ButtonWidget, NumberWidget } from '../lib/widget';
let device = new BlinkerDevice(/*您申请到的Secret Key*/);
// 注册组件
let button1: ButtonWidget = device.addWidget(new ButtonWidget('btn-123'));
let button2: ButtonWidget = device.addWidget(new ButtonWidget('btn-abc'));
let number1: NumberWidget = device.addWidget(new NumberWidget('num-abc'));
let num = 0;
device.ready().then(() => {
device.dataRead.subscribe(message => {
console.log('otherData:', message);
})
button1.listen().subscribe(message => {
console.log('button1:', message.data);
num++;
number1.value(num).update();
})
button2.listen().subscribe(message => {
console.log('button2:', message.data);
// 其他控制代码
})
})
blinker App在 App打开时、进入设备页面时、在设备页面中每隔一定时间 会向设备发送心跳请求,内容为**{"get":"state"}**。 设备收到请求后,会返回 {"state":"online"},app接收到这个返回,即会显示设备在线。
解决办法:重新上传,上传后打开串口监视器,确认程序正确运行
解决办法:设置后再重新上传程序,上传后打开串口监视器,确认程序正确运行
解决办法:先使用并理解blinker例程,再自由发挥
解决办法:换电源 或 换USB口
解决办法:关闭路由器AP隔离功能 或 允许UDP通信;如果找不到相关设置,通常可重置路由器解决
解决办法:在首页下拉刷新,可以重新搜索局域网中的设备