Consumer IR: различия между версиями

Материал из Wiren Board
(Отметить эту версию для перевода)
 
(не показана 1 промежуточная версия этого же участника)
Строка 1: Строка 1:
<languages/>
<translate>
<!--T:1-->
В этой статье описывается прием и передача сигналов пультов управления бытовой техникой, работающих в инфракрасном диапазоне (то есть большинство пультов от телевизоров, кондиционеров, и т. д.).
В этой статье описывается прием и передача сигналов пультов управления бытовой техникой, работающих в инфракрасном диапазоне (то есть большинство пультов от телевизоров, кондиционеров, и т. д.).


== Аппаратная часть ==
== Аппаратная часть == <!--T:2-->


<!--T:3-->
[[Файл:ИК-приемник.jpg|300px|thumb|right|ИК-приемник]]
[[Файл:ИК-приемник.jpg|300px|thumb|right|ИК-приемник]]
[[Файл:Бластер.JPG|300px|thumb|right|ИК-передатчик]]
[[Файл:Бластер.JPG|300px|thumb|right|ИК-передатчик]]
'''Внимание! В ревизиях контроллера 5.8 и старше ИК-порт для подключения приемопередатчика отсутствует!'''
'''Внимание! В ревизиях контроллера 5.8 и старше ИК-порт для подключения приемопередатчика отсутствует!'''


<!--T:4-->
На [[Wiren Board 5]] ([[Wiren Board 5: Аппаратные ревизии|до ревизии 5.6.1]] включительно) необходимые сигналы выведены на разъем mini-jack 3.5mm с со следующей распиновкой:
На [[Wiren Board 5]] ([[Wiren Board 5: Аппаратные ревизии|до ревизии 5.6.1]] включительно) необходимые сигналы выведены на разъем mini-jack 3.5mm с со следующей распиновкой:
* Tip (левый аудиоканал) - питание 5В/передача IR.
* Tip (левый аудиоканал) - питание 5В/передача IR.
Строка 13: Строка 18:
Распиновка разъёма позволяет подключать распространённые ИК-приёмники и передатчики от бытовой техники.
Распиновка разъёма позволяет подключать распространённые ИК-приёмники и передатчики от бытовой техники.


<!--T:5-->
Для приема ИК-сигналов необходимо подключить приемник (совмещённый приёмопередатчик WB-CIR-TR). Номинальная частота несущей приемника должна примерно соответствовать частоте несущей используемого пульта, в противном случае возможно ухудшение или полная невозможность приема сигнала от пульта.
Для приема ИК-сигналов необходимо подключить приемник (совмещённый приёмопередатчик WB-CIR-TR). Номинальная частота несущей приемника должна примерно соответствовать частоте несущей используемого пульта, в противном случае возможно ухудшение или полная невозможность приема сигнала от пульта.


Для передачи ИК-сигналов рекомендуется использовать готовый совмещённый ИК-приёмопередатчик [[WB-CIR-TR]], Samsung IR Blaster bn96/26652a или подобный.
<!--T:6-->
Для передачи ИК-сигналов рекомендуется использовать готовый совмещённый ИК-приёмопередатчик WB-CIR-TR , Samsung IR Blaster bn96/26652a или подобный.


=== Технические детали ===
=== Технические детали === <!--T:7-->
Распиновка разъёма mini-jack 3.5mm  на [[Wiren Board 5]] :
Распиновка разъёма mini-jack 3.5mm  на [[Wiren Board 5]] :
* Tip (левый аудиоканал) - питание 5В/передача IR.
* Tip (левый аудиоканал) - питание 5В/передача IR.
* Ring (правый аудиоканал) - прием IR
* Ring (правый аудиоканал) - прием IR
* Sleeve (земля) - земля
* Sleeve (земля) - земля
Для приема ИК-сигналов испольются  приемники типа TSOP1738, AX-1838HS или аналогичных. Для передачи ИК-сигналов используется ИК-светодиод, токоограничивающий резистор не обязателен (встроен в контроллер) При передаче напряжение питания будет промодулировано передаваемым сигналом и несущей. Приёмопередатчик [[WB-CIR-TR]] содержит приёмник типа TSOP и ИК-светодиод. Для питания приёмника используется паразитное питание.
Для приема ИК-сигналов испольются  приемники типа TSOP1738, AX-1838HS или аналогичных. Для передачи ИК-сигналов используется ИК-светодиод, токоограничивающий резистор не обязателен (встроен в контроллер) При передаче напряжение питания будет промодулировано передаваемым сигналом и несущей. Приёмопередатчик WB-CIR-TR содержит приёмник типа TSOP и ИК-светодиод. Для питания приёмника используется паразитное питание.


''TODO: нарисовать картинку''


== Программная часть ==


== Программная часть == <!--T:8-->
<!--T:9-->
На уровне ядра за работу с ИК на [[Wiren Board 5]] отвечает драйвер '''lirc-pwm'''. Он предоставляет устройство /dev/lirc1.
На уровне ядра за работу с ИК на [[Wiren Board 5]] отвечает драйвер '''lirc-pwm'''. Он предоставляет устройство /dev/lirc1.


<!--T:10-->
С этим устройством взаимодействует демон '''lircd''' из состава пакета [http://www.lirc.org/ LIRC], осуществляющий декодирование последовательностей импульсов в события нажатых на пульте кнопок согласно файлам конфигурации пультов. Также этот демон способен осуществлять обратное преобразование для передачи сигналов нажатия кнопок управляемым устройствам.  
С этим устройством взаимодействует демон '''lircd''' из состава пакета [http://www.lirc.org/ LIRC], осуществляющий декодирование последовательностей импульсов в события нажатых на пульте кнопок согласно файлам конфигурации пультов. Также этот демон способен осуществлять обратное преобразование для передачи сигналов нажатия кнопок управляемым устройствам.  


<!--T:11-->
Наконец, трансляцию событий от '''lircd''' в сообщения [[MQTT]] и обратно осуществляет демон '''wb-mqtt-lirc'''
Наконец, трансляцию событий от '''lircd''' в сообщения [[MQTT]] и обратно осуществляет демон '''wb-mqtt-lirc'''


=== Установка и настройка ===
=== Установка и настройка === <!--T:12-->
Необходимые пакеты ( wb-mqtt-lirc, lirc-scripts, wb-mqtt-lirc), а так же правильный конфиг-файл /etc/lirc/hardware.conf установлены в стандартном образе, начиная с версии 201512070633.
Необходимые пакеты ( wb-mqtt-lirc, lirc-scripts, wb-mqtt-lirc), а так же правильный конфиг-файл /etc/lirc/hardware.conf установлены в стандартном образе, начиная с версии 201512070633.
* Скачать или сгенерировать файл конфигурации пульта и положить его в '''/etc/lirc/lircd.conf.d/'''.
* Скачать или сгенерировать файл конфигурации пульта и положить его в '''/etc/lirc/lircd.conf.d/'''.


==== Скачивание существующего конфига пульта ====
==== Скачивание существующего конфига пульта ==== <!--T:13-->
<pre>
<pre>
root@wirenboard:~# irdb-get update
root@wirenboard:~# irdb-get update
Строка 48: Строка 58:
</pre>
</pre>


==== Создание нового конфига пульта ====
==== Создание нового конфига пульта ==== <!--T:14-->
''TODO: описать как пользоваться irrecord''
''TODO: описать как пользоваться irrecord''


<!--T:15-->
После завершения конфигурации, следует перезапустить службы '''lirc''' и '''wb-mqtt-lirc'''
После завершения конфигурации, следует перезапустить службы '''lirc''' и '''wb-mqtt-lirc'''
<pre>
<pre>
Строка 56: Строка 67:
</pre>
</pre>


=== MQTT-интерфейс ===
=== MQTT-интерфейс === <!--T:16-->


<!--T:17-->
'''wb-mqtt-lirc''' создает устройство ''/devices/wb-lirc/'', принятые нажатия публикуются в топике ''/devices/wb-lirc/controls/Key'' в формате '''<название_пульта>:<название_кнопки>:<повтор>'''. После отпускания кнопки в этом топике публикуется сообщение с пустым телом.
'''wb-mqtt-lirc''' создает устройство ''/devices/wb-lirc/'', принятые нажатия публикуются в топике ''/devices/wb-lirc/controls/Key'' в формате '''<название_пульта>:<название_кнопки>:<повтор>'''. После отпускания кнопки в этом топике публикуется сообщение с пустым телом.


<!--T:18-->
Пример:
Пример:
<pre>
<pre>
Строка 73: Строка 86:
</pre>
</pre>


<!--T:19-->
Для отправки нажатия кнопки следует опубликовать сообщение в формате '''<название_пульта>:<название_кнопки>''' в топике ''/devices/wb-lirc/controls/Key/on''
Для отправки нажатия кнопки следует опубликовать сообщение в формате '''<название_пульта>:<название_кнопки>''' в топике ''/devices/wb-lirc/controls/Key/on''


== Устранение неисправностей ==
== Устранение неисправностей == <!--T:20-->
=== Не работает прием ===
=== Не работает прием ===
* Убедиться что драйвер "видит" импульсы от приемника.
* Убедиться что драйвер "видит" импульсы от приемника.
Строка 86: Строка 100:
**: Должные бежать строчки при нажатии кнопок на пульте. Если '''mode2''' работает, а '''irw''' - нет, то проблема с конфигом пульта. Стоит попробовать использовать другой конфиг, либо создать новый.
**: Должные бежать строчки при нажатии кнопок на пульте. Если '''mode2''' работает, а '''irw''' - нет, то проблема с конфигом пульта. Стоит попробовать использовать другой конфиг, либо создать новый.


=== Не работает передача ===
=== Не работает передача === <!--T:21-->
* Попробовать передавать обращаясь к LIRC напрямую:
* Попробовать передавать обращаясь к LIRC напрямую:
<pre>
<pre>
Строка 95: Строка 109:
(названия пульта и кнопки должны соответствовать используемому конфигу).
(названия пульта и кнопки должны соответствовать используемому конфигу).
* Убедиться что аппаратная часть работает - например, можно посмотреть на ИК-светодиод через камеру смартфона (светодиод должен мигать при передаче)
* Убедиться что аппаратная часть работает - например, можно посмотреть на ИК-светодиод через камеру смартфона (светодиод должен мигать при передаче)
</translate>

Текущая версия на 16:23, 3 июля 2019

Другие языки:

В этой статье описывается прием и передача сигналов пультов управления бытовой техникой, работающих в инфракрасном диапазоне (то есть большинство пультов от телевизоров, кондиционеров, и т. д.).

Аппаратная часть

ИК-приемник
ИК-передатчик

Внимание! В ревизиях контроллера 5.8 и старше ИК-порт для подключения приемопередатчика отсутствует!

На Wiren Board 5 (до ревизии 5.6.1 включительно) необходимые сигналы выведены на разъем mini-jack 3.5mm с со следующей распиновкой:

  • Tip (левый аудиоканал) - питание 5В/передача IR.
  • Ring (правый аудиоканал) - прием IR
  • Sleeve (земля) - земля

Распиновка разъёма позволяет подключать распространённые ИК-приёмники и передатчики от бытовой техники.

Для приема ИК-сигналов необходимо подключить приемник (совмещённый приёмопередатчик WB-CIR-TR). Номинальная частота несущей приемника должна примерно соответствовать частоте несущей используемого пульта, в противном случае возможно ухудшение или полная невозможность приема сигнала от пульта.

Для передачи ИК-сигналов рекомендуется использовать готовый совмещённый ИК-приёмопередатчик WB-CIR-TR , Samsung IR Blaster bn96/26652a или подобный.

Технические детали

Распиновка разъёма mini-jack 3.5mm на Wiren Board 5 :

  • Tip (левый аудиоканал) - питание 5В/передача IR.
  • Ring (правый аудиоканал) - прием IR
  • Sleeve (земля) - земля

Для приема ИК-сигналов испольются приемники типа TSOP1738, AX-1838HS или аналогичных. Для передачи ИК-сигналов используется ИК-светодиод, токоограничивающий резистор не обязателен (встроен в контроллер) При передаче напряжение питания будет промодулировано передаваемым сигналом и несущей. Приёмопередатчик WB-CIR-TR содержит приёмник типа TSOP и ИК-светодиод. Для питания приёмника используется паразитное питание.


Программная часть

На уровне ядра за работу с ИК на Wiren Board 5 отвечает драйвер lirc-pwm. Он предоставляет устройство /dev/lirc1.

С этим устройством взаимодействует демон lircd из состава пакета LIRC, осуществляющий декодирование последовательностей импульсов в события нажатых на пульте кнопок согласно файлам конфигурации пультов. Также этот демон способен осуществлять обратное преобразование для передачи сигналов нажатия кнопок управляемым устройствам.

Наконец, трансляцию событий от lircd в сообщения MQTT и обратно осуществляет демон wb-mqtt-lirc

Установка и настройка

Необходимые пакеты ( wb-mqtt-lirc, lirc-scripts, wb-mqtt-lirc), а так же правильный конфиг-файл /etc/lirc/hardware.conf установлены в стандартном образе, начиная с версии 201512070633.

  • Скачать или сгенерировать файл конфигурации пульта и положить его в /etc/lirc/lircd.conf.d/.

Скачивание существующего конфига пульта

root@wirenboard:~# irdb-get update
root@wirenboard:~# irdb-get find 687C
sony/RM-687C.lircd.conf
root@wirenboard:~# irdb-get download sony/RM-687C.lircd.conf
Downloaded https://sourceforge.net/p/lirc-remotes/code/ci/master/tree/remotes/sony/RM-687C.lircd.conf as RM-687C.lircd.conf
root@wirenboard:~# mv RM-687C.lircd.conf /etc/lirc/lircd.conf.d/

Создание нового конфига пульта

TODO: описать как пользоваться irrecord

После завершения конфигурации, следует перезапустить службы lirc и wb-mqtt-lirc

root@wirenboard:~# service lirc restart && service wb-mqtt-lirc restart

MQTT-интерфейс

wb-mqtt-lirc создает устройство /devices/wb-lirc/, принятые нажатия публикуются в топике /devices/wb-lirc/controls/Key в формате <название_пульта>:<название_кнопки>:<повтор>. После отпускания кнопки в этом топике публикуется сообщение с пустым телом.

Пример:

root@wirenboard:~# mosquitto_sub -v -t '/devices/wb-lirc/#'
/devices/wb-lirc/meta/name IR Remote Control
/devices/wb-lirc/controls/Key/meta/order 1
/devices/wb-lirc/controls/Key/meta/type text
/devices/wb-lirc/controls/Key Sony_RM-687C:KEY_7:0
/devices/wb-lirc/controls/Key Sony_RM-687C:KEY_7:1
/devices/wb-lirc/controls/Key Sony_RM-687C:KEY_7:2
/devices/wb-lirc/controls/Key Sony_RM-687C:KEY_7:3
/devices/wb-lirc/controls/Key (null)

Для отправки нажатия кнопки следует опубликовать сообщение в формате <название_пульта>:<название_кнопки> в топике /devices/wb-lirc/controls/Key/on

Устранение неисправностей

Не работает прием

  • Убедиться что драйвер "видит" импульсы от приемника.
    • Остановить сервис lirc (командой service lirc stop)
    • root@wirenboard:~# mode2 -d /dev/lirc1
      Должны бежать цифры при нажатии кнопок на пульте, если нет - проблема в "железе" или в несоответствии несущей пульта и приемника. Следует попробовать использовать другой приемник.
  • Убедиться что lirc может декодировать последовательности импульсов согласно конфигу пульта:
    • Запустить обратно lirc (service lirc start)
    • root@wirenboard:~# irw
      Должные бежать строчки при нажатии кнопок на пульте. Если mode2 работает, а irw - нет, то проблема с конфигом пульта. Стоит попробовать использовать другой конфиг, либо создать новый.

Не работает передача

  • Попробовать передавать обращаясь к LIRC напрямую:
root@wirenboard:~# irsend SEND_START Sony_RM-687C KEY_3
...
root@wirenboard:~# irsend SEND_STOP Sony_RM-687C KEY_3

(названия пульта и кнопки должны соответствовать используемому конфигу).

  • Убедиться что аппаратная часть работает - например, можно посмотреть на ИК-светодиод через камеру смартфона (светодиод должен мигать при передаче)