zh CN zh CN KNX Node Configuration - Supergiovane/node-red-contrib-knx-ultimate GitHub Wiki
🌐 Language: EN | IT | DE | FR | ES | 简体中文
导航: 首页 概览: Changelog • 常见问题 • 安全 • 文档:语言栏 KNX 设备: 网关 • 设备 • 节点保护 其他 KNX 节点: 场景控制器 • 看门狗 • 日志节点 • 全局上下文 • 告警器 • 负载控制 • 查看器 • 自动响应 • HA 翻译器 • 物联网桥接 HUE: Bridge • 灯 • 电池 • 按钮 • 接触 • 设备软件更新 • 光照传感器 • 运动 • 场景 • Tap Dial • 温度 • Zigbee 连接 示例: 日志 • Switch Light • Dimming • RGB color • RGBW color + White • Command a scene actuator • Datapoint 213.x 4x Setpoint • Datapoint 222.x 3x Setpoint • Datapoint 237.x DALI diags • Datapoint 2.x 1 bit proprity • Datapoint 22.x RCHH Status • Datetime to BUS • Read Status • Virtual Device • Subtype decoded • Alexa • Apple Homekit • Google Home • Switch on/off POE port of Unifi switch • Set configuration by msg • Scene Controller node • WatchDog node • Global Context node • Alerter node • Load control node • Viewer node • MySQL, InfluxDB, MQTT Sample Contribute to Wiki: Link
该节点用于控制 KNX 组地址(Group Address),是最常用的节点。
配置
属性 | 说明 |
---|---|
Gateway | 选择要使用的 KNX 网关 |
GA 类型 | 组地址类型。默认 **3‑层级 ** (可输入三层组地址或名称,若已导入 ETS);**Global ** 启动时从全局变量读取;Flow ** 在流程作用域读取;$Env variable ** 从环境变量读取;通用模式(监听所有组地址) 对所有 GA 做出响应。 |
Group Addr. | 需要控制的组地址。若已导入 ETS,可直接输入设备名进行匹配。也可留空,之后通过输入消息 msg.setConfig 设置。 |
Datapoint | 与节点关联的 Datapoint。 |
属性 | 说明 |
---|---|
通用 | |
节点名称 | 显示名。 |
Topic | 输出消息的 topic。留空则使用组地址。 |
Passthrough | 将输入消息透传到输出。 |
节点输入 → KNX 总线 | |
Telegram 类型 |
write 发送写报文(常用);也可选择响应其他类型。 |
RBE 过滤 | 按变化上报。启用后,仅当值变化时才发送到总线。需要重复发送相同值时请关闭。启用后在节点名中显示 "rbe”。 |
KNX 总线 → 节点输出 | |
启动时读取状态 | 在 Node‑RED 启动及每次重连时读取 GA 状态。节点会缓存值到文件,可选择从文件或总线读取。 |
RBE 过滤 | 同上,但作用于输出到流程。 |
响应写报文 | 收到写报文时向流程输出一条消息。 |
响应应答报文 | 收到应答报文时向流程输出。 |
响应读报文 | 收到读报文时向流程输出(用于自定义返回值)。 |
Multiply/Decimals/Negatives | 数值缩放、四舍五入、小数与负值处理(仅数值)。 |
可使用 JavaScript 自定义:对来自流程的输入消息、以及发送到总线的报文的处理逻辑。编辑器提供若干对象/函数,用于读取任意 GA 的值:导入 ETS 时可不指定 DPT,未导入则需指定 DPT。 脚本在每次收到输入消息或总线报文时执行。启用后,节点名会显示 "f(x)”。
属性 | 说明 |
---|---|
Search GA | 仅在已导入 ETS 时可用:输入并选择 GA,然后将完整字段粘贴到 getGAValue 中。 |
对象/函数 | 说明 |
---|---|
msg |
当前消息对象。 |
getGAValue(GA, DPT?) |
读取 GA 值,如 '1/0/1' 或 '1/0/1 Bed table light' (空格后的文字被忽略)。未导入 ETS 时需提供 DPT。 |
setGAValue(GA, value, DPT?) |
设置 GA 值;DPT 同上。 |
self(value) |
设置当前节点的值并发送到总线(注意循环)。 |
toggle() |
切换当前值并发送到总线。 |
node , RED , return(msg)
|
节点对象,RED 对象,返回消息以继续流转。 |
const statusGA = getGAValue('0/0/09','1.001'); if (msg.payload !== statusGA){ return msg; } else { return; }
```javascript
if (msg.payload){
setGAValue('0/1/8', true)
setTimeout(function(){ self(off); }, 2000);
}
return msg;
```### 示例(总线 → 输出)```javascript
msg.externalTemperature = getGAValue('0/0/10'); // 未导入 ETS:getGAValue('0/0/10','9.001')
return msg;
if (msg.payload === false && getGAValue('0/0/11','1.001') === false){ return; } else { return msg; }
```### 输入(Inputs)
**destination (string) ** :三层组地址,如 `1/1/0`。**payload (any) ** :要发送的值。**event (string) ** :`GroupValue_Write` / `GroupValue_Response` / `Update_NoWrite`(仅更新内部值,不发送)。**readstatus (boolean) ** :向总线发起读取。**dpt (string) ** :如 `1.001`。**writeraw (buffer) ** 、**bitlenght (int) ** :发送 RAW,`bitlenght` 为比特长度。**resetRBE (boolean) ** :重置内部 RBE 过滤。**setConfig (json)** :通过消息修改节点的 GA 与 DPT。
### setConfig 详情```javascript
var config= { setGroupAddress: "0/1/2", setDPT: "1.001" };
msg.setConfig = config; return msg;
var config= { setGroupAddress: "0/1/2", setDPT: "auto" };
msg.setConfig = config; return msg;
```### 输出(Outputs)
1. 标准输出:PIN1 上的 `payload`。
2. 错误:PIN2 上的 `error`(详细错误)。
### 输出消息示例```json
msg = {
topic: "0/1/2",
payload: false,
previouspayload: true,
payloadmeasureunit: "%",
payloadsubtypevalue: "Start",
devicename: "餐桌灯",
gainfo: {
maingroupname: "Light actuators",
middlegroupname: "First flow lights",
ganame: "Table Light",
maingroupnumber: "1",
middlegroupnumber: "1",
ganumber: "0"
},
echoed: true,
knx: {
event: "GroupValue_Write",
dpt: "1.001",
dptdesc: "Humidity",
source: "15.15.22",
destination: "0/1/2",
rawValue: "<buffer>"
}
}
```---
# 流程输入消息(INPUT FLOW MESSAGE)
## 控制 KNX 设备
节点会将来自流程的消息发送到 KNX 总线;当总线有报文到达时也会输出到流程。除 `payload` 外,下列属性均为可选。
**msg.destination ** :如 `0/0/1`。**msg.payload ** :如 `true/false/21/"Hello"`。**msg.event** :`Write`/`Response`/`Update_NoWrite`。当为 `Update_NoWrite` 时,所有相同 GA 的节点都会向流程输出包含 `event: 'Update_NoWrite'` 的消息。
需要"读取”时请使用 `msg.readstatus = true`。
**msg.readstatus = true ** :向总线发起读取。**msg.dpt ** :如 `1.001`(也接受 `9`、`"9"`、`"DPT9.001"`)。**msg.writeraw ** 、**msg.bitlenght ** :发送 RAW;会忽略节点上设置的 DPT。**msg.resetRBE = true** :重置 RBE 过滤。
## 通过消息修改配置
[示例页请见此处](https://github.com/Supergiovane/node-red-contrib-knx-ultimate/wiki/-Sample-setConfig)
---
# 快速上手(QUICK HOW TO)
更多示例见:[SamplesHome](https://github.com/Supergiovane/node-red-contrib-knx-ultimate/wiki/-SamplesHome)
**打开灯** ```javascript
msg.payload = true; return msg;
``` **绝对调光** ```javascript
msg.payload = 30; return msg;
``` **向显示屏发送文本** ```javascript
msg.payload = "Output Tem. 35°C"; return msg;
``` **读取状态** ```javascript
// 发送读取请求;需在节点上勾选"React to response telegrams”以接收应答
msg.readstatus = true; return msg;
``` **发送 RAW 到总线** ```javascript
// DPT1 示例:开灯 = Buffer<01>,bitlength = 1
msg.writeraw = Buffer.from('01','hex');
msg.bitlenght = 1; return msg;
// 温度(DPT9)示例:18.4 °C = <0730>
// msg.writeraw = Buffer.from('0730','hex'); return msg;