ws2812 - 幻彩灯带RGB控制器(WS2812系列)#

示例

-- 本库尚在开发阶段

ws2812.create(mode, count, id)#

创建上下文

参数

传入值类型

解释

int

传输模式, 例如 ws2812.GPIO, ws2812.PWM, ws2812.SPI

int

RGB灯总个数

int

主参数id, 对于不同的模式有不同的值

返回值

返回值类型

解释

userdata

创建成功返回上下文,否则返回nil

例子

-- GPIO模式, 64个灯, 使用GPIO9
local leds = ws2812.create(ws2812.GPIO, 64, 9)
-- SPI模式, 32个灯, 使用SPI1
local leds = ws2812.create(ws2812.SPI, 32, 1)
-- PWM模式, 16个灯, 使用PWM4
local leds = ws2812.create(ws2812.PWM, 16, 4)
-- HW模式, 64个灯, 使用硬件专用实现,具体id需要对照手册
local leds = ws2812.create(ws2812.RMT, 64, 2)

-- 注意: 并非所有模块都支持以上所有模式
-- 而且, 固件需要开启对应的GPIO/SPI/PWM功能才能使用对应的模式

ws2812.set(leds,index, R, G, B)#

设置灯的颜色

参数

传入值类型

解释

userdata

通过ws2812.create获取到的上下文

int

灯的编号,从0开始

int

RGB值中的R值

int

RGB值中的G值

int

RGB值中的B值

返回值

返回值类型

解释

boolean

设置成功返回true,否则返回nil

例子

-- RGB逐个颜色传递
ws2812.set(leds, 5, 0xFF, 0xAA, 0x11)
-- 也支持一个参数传完, 与前一条等价
ws2812.set(leds, 5, 0xFFAA11)

ws2812.send(leds)#

发送数据到设备

参数

传入值类型

解释

userdata

通过ws2812.create获取到的上下文

返回值

返回值类型

解释

boolean

设置成功返回true,否则返回nil

例子

-- 没有更多参数, 发就完事了
ws2812.send(leds)

ws2812.args(leds, arg0, arg1, arg2, arg3, arg4)#

配置额外参数

参数

传入值类型

解释

userdata

通过ws2812.create获取到的上下文

int

额外参数0

int

额外参数1

int

额外参数2

int

额外参数3

int

额外参数4

返回值

返回值类型

解释

boolean

设置成功返回true,否则返回nil

例子

-- 本函数与具体模式有关

--GPIO模式可调整T0H T0L, T1H T1L 的具体延时
ws2812.send(leds, t0h, t0l, t1h, t1l)