20 KiB
LightHub: Примеры конфигурации для всех типов каналов (0-22)
Практический справочник с готовыми примерами JSON конфигурации для каждого типа канала. Каждый пример показывает полный синтаксис, включая MQTT топики и все параметры.
Содержание
- CH_DIMMER (0)
- CH_RGBW (1)
- CH_RGB (2)
- CH_PWM (3)
- CH_MODBUS (4)
- CH_THERMO (5)
- CH_RELAY (6)
- CH_GROUP (7)
- CH_VCTEMP (8)
- CH_VC (9)
- CH_AC (10)
- CH_SPILED (11)
- CH_MOTOR (12)
- CH_PID (13)
- CH_MBUS (14)
- CH_UARTBRIDGE (15)
- CH_RELAYX (16)
- CH_RGBWW (17)
- CH_MULTIVENT (18)
- CH_ELEVATOR (19)
- CH_COUNTER (20)
- CH_HUMIDIFIER (21)
- CH_MERCURY (22)
CH_DIMMER (0) - DMX диммер
Назначение: Регулировка яркости одного или нескольких DMX каналов
Синтаксис
"dimmer_name": [0, дмx_канал_или_массив]
Примеры
{
"items": {
"lamp_bedroom": [0, 1],
"lamp_kitchen": [0, 2],
"lamp_hall": [0, [3, 4, 5]],
"lamp_stage": [0, 10, 255, 1]
}
}
MQTT команды
myhome/dev/lamp_bedroom/cmd ← ON, OFF, TOGGLE, SET
myhome/dev/lamp_bedroom/set ← 150 (яркость 0-255)
myhome/dev/lamp_bedroom/val ← текущая яркость
myhome/s_out/lamp_bedroom/val → опубликованная яркость
CH_RGBW (1) - DMX RGBW
Назначение: Управление RGB + White каналом через DMX (4 канала DMX)
Синтаксис
"rgb_name": [1, стартовый_dmx_канал]
Пример
{
"mqtt": ["lighthub", "192.168.88.2"],
"dmx": [512],
"items": {
"rgb_light": [1, 10], // RGB+W на DMX 10-13
"rgb_light2": [1, 20, 255, 0] // с начальной яркостью 255
}
}
MQTT команды
myhome/dev/rgb_light/hue ← 240 (0-359°)
myhome/dev/rgb_light/sat ← 100 (0-100%)
myhome/dev/rgb_light/val ← 200 (0-255)
myhome/dev/rgb_light/temp ← 6500 (температура цвета, K)
myhome/dev/rgb_light/RGB ← 255,0,0 (красный)
myhome/dev/rgb_light/RGB ← 255,0,0,100 (RGB+White)
CH_RGB (2) - DMX RGB
Назначение: Управление RGB каналом через DMX (3 канала DMX)
Пример
{
"items": {
"mood_light": [2, 15] // RGB на DMX 15-17
}
}
MQTT команды
myhome/dev/mood_light/RGB ← 0,255,0 (зелёный)
myhome/dev/mood_light/HSV ← 120,100,100 (зелёный в HSV)
CH_PWM (3) - GPIO PWM
Назначение: PWM выход через GPIO пины (для плат Arduino, ESP)
Синтаксис
"pwm_name": [3, gpio_пин_или_массив]
Примеры
{
"items": {
"pwm_dim": [3, 9], // PWM на GPIO D9
"pwm_4ch": [3, [11, 12, 13, 14]], // 4-х канальный PWM
"led_pwm": [3, 5, 255, 1] // с начальным значением
}
}
MQTT команды
myhome/dev/pwm_dim/set ← 128
myhome/dev/pwm_dim/val ← текущее значение
CH_MODBUS (4) - Modbus AC Dimmer (Legacy)
Назначение: Управление AC-диммером через Modbus RTU (устаревший тип, использовать CH_MBUS (14))
Синтаксис
"mbus_dim": [4, [адрес, регистр, маска, макс_значение]]
Пример
{
"items": {
"ac_dimmer": [4, [96, 0, 0, 255]]
// Адрес: 96 (0x60)
// Регистр: 0
// Маска: 0 (LSB)
// Макс значение: 255
}
}
⚠️ Примечание: Для новых проектов используйте CH_MBUS (14) вместо этого
CH_THERMO (5) - ON/OFF Термостат
Назначение: Простой ON/OFF термостат с гистерезисом
Синтаксис
"thermo_name": [5, gpio_пин, целевая_температура°C]
Примеры
{
"items": {
"thermo_bath": [5, 24, 33], // GPIO 24, уставка 33°C
"thermo_bedroom": [5, 25, 22], // GPIO 25, уставка 22°C
"floor_heating": [5, 26, 28, 1, 1] // с начальным значением
}
}
MQTT команды
myhome/dev/thermo_bath/set ← 35 (установить целевую T)
myhome/dev/thermo_bath/val ← 1 (нагревается) или 0
myhome/dev/thermo_bath/cmd ← ON, OFF
CH_RELAY (6) - GPIO Реле
Назначение: Простое электромагнитное реле ON/OFF
Синтаксис
"relay_name": [6, gpio_пин]
"relay_name": ["RELAY", gpio_пин, [начальное_значение, [начальная_команда]]]
Примеры
{
"items": {
"relay_water": [6, 23], // Реле на GPIO 23
"relay_pump": [6, 24, 0, 0], // начально OFF
"relay_heat": ["RELAY", 28, 1, 1] // начально ON, команда ON
}
}
MQTT команды
myhome/dev/relay_water/cmd ← ON, OFF, TOGGLE
myhome/dev/relay_water/val ← 1 (включено) или 0 (выключено)
CH_GROUP (7) - Группа каналов
Назначение: Логическая группа для синхронного управления несколькими каналами
Синтаксис
"group_name": [7, [канал1, канал2, канал3, ...]]
Примеры
{
"items": {
"lamps": [0, 1],
"lamps2": [0, 2],
"rgb1": [1, 10],
"lights_all": [7, [
"lamps",
"lamps2",
"rgb1"
]],
"lights_bedroom": [7, ["lamps"]],
"lights_common": [7, ["lamps", "lamps2"]]
}
}
MQTT команды
myhome/dev/lights_all/cmd ← ON (включит ВСЕ в группе)
myhome/dev/lights_all/cmd ← OFF (выключит ВСЕ в группе)
myhome/dev/lights_all/cmd ← SET 100 (установит яркость для диммеров)
CH_VCTEMP (8) - Vacom PID Терморегулятор
Назначение: PID регулятор температуры для систем вентиляции Vacom
Синтаксис
"vacom_heat": [8, [modbus_адрес, экземпляр]]
Пример
{
"modbus": {
"vacom_10": {
"baud": 9600,
"serial": "8N1",
"poll": {"regs": [[0, 50]], "delay": 1000}
}
},
"items": {
"fan_heat": [8, [96, 0]], // Vacom адрес 96, экземпляр 0
"fan_cool": [8, [96, 1]] // Vacom адрес 96, экземпляр 1
}
}
CH_VC (9) - Vacom Мотор-регулятор
Назначение: Управление мотор-регулятором вентилятора Vacom
Пример
{
"items": {
"vent_motor": [9, [96, {
"mode": {"emit": "vent/mode"},
"speed": {"emit": "vent/speed"}
}]]
}
}
CH_AC (10) - Кондиционер Haier
Назначение: Управление кондиционером Haier через Modbus/RS485
Полный пример
{
"mqtt": ["lighthub", "192.168.88.2"],
"modbus": {
"haier_ac": {
"baud": 9600,
"serial": "8N1",
"poll": {
"regs": [[1, 30]],
"delay": 1000
},
"par": {
"power": {
"reg": 1,
"type": "u16",
"map": {"cmd": [["OFF", 0], ["ON", 1]]}
},
"mode": {
"reg": 2,
"type": "u16",
"map": {"cmd": [["COOL", 0], ["HEAT", 1], ["DRY", 2], ["FAN", 3]]}
},
"temperature": {
"reg": 3,
"type": "i16",
"scale": 0.1
},
"fan_speed": {
"reg": 4,
"type": "u16"
}
}
}
},
"items": {
"ac_hall": [10, [1, {
"power": {"emit": "ac/power"},
"mode": {"emit": "ac/mode"},
"temperature": {"emit": "ac/temp"},
"fan_speed": {"emit": "ac/fan"}
}]]
}
}
MQTT команды
myhome/dev/ac_hall/cmd ← ON, OFF
myhome/dev/ac_hall/mode ← COOL, HEAT, DRY, FAN
myhome/dev/ac_hall/set ← 22 (температура)
myhome/dev/ac_hall/fan ← 0, 1, 2, 3 (скорость)
CH_SPILED (11) - SPI LED Лента
Назначение: Управление адресуемой SPI LED лентой (WS2812B, APA102)
Синтаксис
"led_name": [11, [clk_pin, data_pin]]
Пример
{
"items": {
"led_strip": [11, [7, 8]], // CLK=GPIO7, DATA=GPIO8
"led_bar": [11, [10, 11]]
}
}
CH_MOTOR (12) - Шаговый двигатель
Назначение: Управление шаговым двигателем с обратной связью (для задвижек, жалюзи)
Синтаксис
"motor_name": [12, [pwm_pin, open_pin, close_pin, feedback_off_val, feedback_on_val, max_time_ms]]
Пример
{
"items": {
"gate_motor": [12, [9, 10, 11, 0, 255, 30000]],
// PWM pin: 9
// Open pin: 10
// Close pin: 11
// Feedback off: 0
// Feedback on: 255
// Max time: 30 сек
"blinds": [12, [5, 6, 7, 100, 900, 20000]]
}
}
MQTT команды
myhome/dev/gate_motor/cmd ← ON (открыть), OFF (закрыть)
myhome/dev/gate_motor/val ← текущая позиция обратной связи
CH_PID (13) - PID Регулятор
Назначение: Универсальный PID контроллер для процессов
Синтаксис
"pid_name": [13, [
[Kp, Ki, Kd, dT, timeout, alarm_val, min_out, max_out],
{выходной_execObj},
{каскадный_execObj}
]]
Пример
{
"items": {
"pid_heater": [13, [
[1.0, 0.05, 0.02, 5.0, 3600, 50, 0, 255],
{"emit": "heater/output"},
{"emit": "heater/cascade"}
]],
"pid_cooler": [13, [
[0.8, 0.03, 0.01, 5.0, 1800, 100, 0, 200],
{"item": "fan_speed/set"},
null
]]
}
}
Параметры
| Параметр | Описание |
|---|---|
Kp |
Коэффициент пропорциональности |
Ki |
Коэффициент интеграла |
Kd |
Коэффициент дифференциала |
dT |
Интервал расчёта (секунды) |
timeout |
Время срабатывания аварии (сек) |
alarm_val |
Значение аварии |
min_out, max_out |
Диапазон выхода |
CH_MBUS (14) - Universal Modbus
Назначение: Универсальный Modbus канал с полной поддержкой шаблонизации
Полный пример
{
"mqtt": ["lighthub", "192.168.88.2"],
"modbus": {
"temperature_sensor": {
"baud": 9600,
"serial": "8N1",
"poll": {
"regs": [[0, 10]],
"delay": 2000
},
"par": {
"temperature": {
"reg": 0,
"type": "i16",
"scale": 0.1
},
"humidity": {
"reg": 1,
"type": "u16",
"scale": 0.01
}
}
}
},
"items": {
"sensor_outdoor": [14, ["temperature_sensor", {
"temperature": {"emit": "sensors/outdoor/temp"},
"humidity": {"emit": "sensors/outdoor/humidity"}
}]],
"sensor_indoor": [14, ["temperature_sensor", {
"temperature": {"item": "thermo_room/set"},
"humidity": {"emit": "sensors/indoor/humidity"}
}]]
}
}
CH_UARTBRIDGE (15) - UART Мост
Назначение: Мост между двумя UART портами с отладкой через UDP
Пример
{
"items": {
"uart_debug": [15, {
"port1": 1,
"port2": 0
}]
}
}
CH_RELAYX (16) - Медленный PWM через реле
Назначение: Медленный PWM через реле для инертных систем (тепловые системы, комплексы)
Синтаксис
"relay_pwm": [16, [gpio_pin, период_цикла_сек]]
Пример
{
"items": {
"floor_heating": [16, [22, 60]], // GPIO 22, период 60 сек
"radiator": [16, [23, 120]], // GPIO 23, период 120 сек
"underfloor": [16, [24, 300, 128]] // с начальным PWM 128
}
}
MQTT команды
myhome/dev/floor_heating/set ← 200 (PWM 0-255)
myhome/dev/floor_heating/val ← текущий PWM
CH_RGBWW (17) - DMX RGBWW
Назначение: DMX управление RGB + тёплый белый + холодный белый (6 каналов)
Пример
{
"dmx": [512],
"items": {
"led_tunable_white": [17, 30] // RGB+W+W на DMX 30-35
}
}
MQTT команды
myhome/dev/led_tunable_white/RGB ← 255,128,0,200,50
// R, G, B, Warm White, Cold White
CH_MULTIVENT (18) - Многозональная вентиляция
Назначение: Каскадная система вентиляции с независимым регулированием по зонам
Полный пример
{
"mqtt": ["lighthub", "192.168.88.2"],
"items": {
"multivent_main": [18, [96, {
"": {
"val": {"emit": "vents/main/temp"},
"mode": {"emit": "vents/main/mode"}
},
"bedroom": {
"val": {"emit": "vents/bedroom/temp"},
"fan": {"emit": "vents/bedroom/fan"},
"set": {"emit": "vents/bedroom/setpoint"},
"V": 40,
"pid": [1.0, 0.05, 0.02, 5.0]
},
"living_room": {
"val": {"emit": "vents/living/temp"},
"set": 21,
"V": 60
},
"kitchen": {
"val": {"emit": "vents/kitchen/temp"},
"set": 20,
"V": 30
}
}]]
}
}
MQTT команды
myhome/dev/multivent_main/bedroom/set ← 22 (уставка T)
myhome/dev/multivent_main/bedroom/fan ← 50 (открытие жалюзи)
myhome/dev/multivent_main/bedroom/mode ← HEAT, COOL, FAN
CH_ELEVATOR (19) - Управление лифтом
Назначение: Управление лифтом (зарезервировано для будущего использования)
Статус: TBD (To Be Determined)
CH_COUNTER (20) - Счётчик импульсов
Назначение: Счётчик импульсов (электроэнергия, газ, вода)
Синтаксис
"counter_name": [20, [коэффициент, масштаб]]
"counter_name": [20, коэффициент]
Примеры
{
"items": {
"energy_meter": [20, [0.02, 1.2]], // коэфф 0.02, масштаб 1.2
"gas_meter": [20, 0.001], // коэфф 0.001
"water_meter": [20, 0.01, 0, 0] // с начальным значением 0
}
}
MQTT команды
myhome/dev/energy_meter/val ← текущее значение (кВт·ч)
myhome/dev/gas_meter/val ← текущее значение (м³)
CH_HUMIDIFIER (21) - Управление увлажнителем
Назначение: Управление увлажнителем воздуха
Пример
{
"items": {
"humidifier_room": [21, {
"humidity": {"emit": "humidifier/setpoint"},
"mode": {"emit": "humidifier/mode"},
"power": {"emit": "humidifier/power"}
}]
}
}
MQTT команды
myhome/dev/humidifier_room/set ← 60 (целевая влажность %)
myhome/dev/humidifier_room/cmd ← ON, OFF
myhome/dev/humidifier_room/mode ← режим
CH_MERCURY (22) - Счётчик энергии Mercury
Назначение: Счётчик энергии Mercury по RS485/Modbus
Синтаксис
"mercury": [22, [адрес, baudrate, формат, сдвиг, флаги, timeout]]
Пример
{
"items": {
"energy_mercury": [22, [1, 9600, "8N1", 2, [2,2,2,2,2,2], 10000]]
// Адрес: 1
// Baudrate: 9600
// Формат: 8N1
// Сдвиг: 2
// Флаги: [2,2,2,2,2,2]
// Timeout: 10000 мс
}
}
MQTT команды
myhome/dev/energy_mercury/val ← текущие показания энергии
Полная реальная конфигурация (интеграция всех типов)
{
"mqtt": ["lh-smart-home", "192.168.88.2", 1883, "mqtt_user", "mqtt_pass"],
"topics": {"root": "myhome", "out": "s_out"},
"syslog": ["192.168.88.2", 514],
"dmx": [512],
"modbus": {
"haier_ac": {
"baud": 9600,
"serial": "8N1",
"poll": {"regs": [[1, 30]], "delay": 1000},
"par": {
"power": {"reg": 1, "type": "u16"},
"mode": {"reg": 2, "type": "u16"},
"temperature": {"reg": 3, "type": "i16", "scale": 0.1}
}
}
},
"items": {
"lights_all": [7, ["lamp1", "lamp2", "rgb1", "rgb2"]],
"lamp1": [0, 1],
"lamp2": [0, 2],
"rgb1": [1, 10],
"rgb2": [1, 20],
"relay_water": [6, 23],
"relay_pump": [6, 24],
"relay_heat": [6, 25],
"pwm_fan": [3, 9],
"thermo_bath": [5, 26, 33],
"thermo_hall": [5, 27, 22],
"ac_main": [14, ["haier_ac", {
"power": {"emit": "ac/power"},
"mode": {"emit": "ac/mode"},
"temperature": {"emit": "ac/temp"}
}]],
"energy_counter": [20, [0.02, 1.2]],
"multivent": [18, [96, {
"": {"val": {"emit": "vent/main"}},
"bedroom": {"val": {"emit": "vent/bedroom"}, "V": 40},
"kitchen": {"val": {"emit": "vent/kitchen"}, "V": 60}
}]]
},
"in": {
"37": {"item": "lights_all", "scmd": "TOGGLE"},
"38": {"item": "relay_water", "scmd": "OFF"},
"39": {"emit": "/status/water_leak"}
}
}
Полезные ссылки
- Справочник типов каналов — типы 0-22
- Справочник суффиксов — /cmd, /val, /set, /hue, /sat, /temp
- Полное описание конфигурации
- Исходный код item.h
Версия документа: 1.0
Дата обновления: 2025-01-24