2019-02-27 10:10:09 +01:00
Remote Transmitter
==================
2018-06-13 22:38:49 +02:00
2018-11-14 22:12:27 +01:00
.. seo ::
:description: Instructions for setting up switches that send out pre-defined sequences of IR or RF signals
2018-11-19 18:32:16 +01:00
:image: remote.png
2018-11-14 22:12:27 +01:00
:keywords: Infrared, IR, RF, Remote, TX
2019-02-27 10:10:09 +01:00
.. _remote-transmitter-component:
Component/Hub
-------------
The `` remote_transmitter `` component lets you send infrared messages to control
devices in your home. First, you need to setup a global hub that specifies which pin your remote
sender is connected to. Afterwards you can create :ref:`individual
switches <remote-transmitter-switch>` that each send a pre-defined remote signal to a device.
Use-cases are for example infrared remotes or 433MHz signals.
.. note ::
This component is *much* more accurate on the ESP32, since that chipset has a dedicated
peripheral for sending exact signal sequences.
.. code-block :: yaml
# Example configuration entry
remote_transmitter:
pin: GPIO32
carrier_duty_percent: 50%
# Individual switches
switch:
- platform: remote_transmitter
name: "Panasonic TV Off"
panasonic:
address: 0x4004
command: 0x100BCBD
Configuration variables:
***** ***** ***** ***** *** *
- **pin** (**Required** , :ref: `config-pin` ): The pin to transmit the remote signal on.
- **carrier_duty_percent** (*Optional* , int): How much of the time the remote is on. For example, infrared
protocols modulate the signal using a carrier signal. Set this is `` 50% `` if you're working with IR leds and to
`` 100% `` if working with a other things like 433MHz transmitters.
- **id** (*Optional* , :ref: `config-id` ): Manually specify
the ID used for code generation. Use this if you have multiple remote transmitters.
.. note ::
See :ref: `finding_remote_codes` for a guide for setting this up.
.. _remote-transmitter-switch:
Switch
------
2018-06-13 22:38:49 +02:00
The `` remote_transmitter `` switch platform allows you to create switches
that send a pre-defined remote control sequence
2019-02-27 10:10:09 +01:00
using the :ref: `remote-transmitter-component` . Every time
2018-06-13 22:38:49 +02:00
the switch is turned on, the configured remote signal is sent.
Use cases include, but are not limited to, infrared remotes, 433MHz signals and so on.
.. figure :: images/remote_transmitter-ui.png
:align: center
:width: 80.0%
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-13 22:38:49 +02:00
# Example configuration entry
remote_transmitter:
pin: 32
# Individual switches
switch:
- platform: remote_transmitter
name: "Panasonic TV Off"
panasonic:
address: 0x4004
command: 0x100BCBD
repeat: 25
Configuration variables:
2019-02-27 10:10:09 +01:00
***** ***** ***** ***** *** *
2018-06-13 22:38:49 +02:00
- **name** (**Required** , string): The name for the switch.
- The remote code, see :ref: `remote_transmitter-codes` . Only one
of them can be specified per switch.
- **repeat** (*Optional* , int): How often the command should be sent.
- **times** (int): The number of times the code should be sent. Defaults to `` 1 `` .
- **wait_time** (:ref: `time <config-time>` ): The time to wait between repeats.
2019-02-27 10:10:09 +01:00
- **remote_transmitter_id** (*Optional* , :ref: `config-id` ): The id of the :ref: `remote-transmitter-component` .
2018-06-13 22:38:49 +02:00
Defaults to the first hub specified.
- **id** (*Optional* , :ref: `config-id` ): Manually specify the ID used for code generation.
2019-02-17 12:28:17 +01:00
- All other options from :ref: `Switch <config-switch>` .
2018-06-13 22:38:49 +02:00
2018-08-24 22:44:01 +02:00
.. note ::
For the Sonoff RF Bridge you can use `this hack <https://github.com/xoseperez/espurna/wiki/Hardware-Itead-Sonoff-RF-Bridge---Direct-Hack> `__
created by the Github user wildwiz. Then use this configuration for the remote receiver/transmitter hubs:
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-08-24 22:44:01 +02:00
remote_receiver:
pin: 4
dump: all
remote_transmitter:
pin: 5
carrier_duty_percent: 100%
2019-02-16 23:25:23 +01:00
Supporting the RF Bridge chip directly is currently only a long-term goal for ESPHome.
2018-08-24 22:44:01 +02:00
2018-06-13 22:38:49 +02:00
.. _remote_transmitter-codes:
Remote Codes
2019-02-27 10:10:09 +01:00
***** ***** **
2018-06-13 22:38:49 +02:00
Supported remote codes:
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-13 22:38:49 +02:00
2018-08-22 22:05:28 +02:00
switch:
- platform: remote_transmitter
# ... - Only one of these is allowed for one remote transmitter at a time
nec:
address: 0x4242
command: 0x8484
lg:
data: 0x01234567890ABC
nbits: 28
2018-10-13 19:41:44 +02:00
samsung:
data: 0xE0E01234
2018-08-22 22:05:28 +02:00
sony:
data: 0xABCDEF
nbits: 12
panasonic:
address: 0x4004
command: 0x1000BCD
2019-02-12 00:01:20 +01:00
jvc:
data: 0x1234
2018-08-22 22:05:28 +02:00
rc_switch_raw:
code: '001010011001111101011011'
protocol: 1
rc_switch_type_a:
group: '11001'
2018-08-27 13:21:30 +02:00
device: '01000'
2018-08-22 22:05:28 +02:00
state: True
rc_switch_type_b:
address: 4
channel: 2
state: True
rc_switch_type_c:
family: 'a'
group: 1
device: 2
state: True
rc_switch_type_d:
group: 'a'
device: 2
state: True
2019-02-16 23:25:23 +01:00
rc5:
address: 0x00
command: 0x0B
2018-08-22 22:05:28 +02:00
raw:
carrier_frequency: 35kHz
data:
- 1000
- -1000
2018-06-13 22:38:49 +02:00
Configuration variables:
- **nec** : Send a NEC IR code.
- **address** : The address of the device.
- **command** : The command to send.
- **lg** : Send an LG IR code.
- **data** : The data bytes to send.
- **nbits** : The number of bits to send, defaults to 28.
2018-10-13 19:41:44 +02:00
- **samsung** : Send an Samsung IR code.
- **data** : The data bytes to send.
2018-06-13 22:38:49 +02:00
- **sony** : Send an Sony IR code.
- **data** : The data bytes to send.
- **nbits** : The number of bits to send, defaults to 12.
- **panasonic** : Send an Panasonic IR code.
- **address** : The address of the device.
- **command** : The command to send.
2019-02-12 00:01:20 +01:00
- **jvc** : Send a JVC IR code.
- **data** : The data bytes to send.
2018-08-22 22:05:28 +02:00
- **rc_switch_raw** : Send an RCSwitch raw code.
- **code** (**Required** , string): The code to send. Must be a string of 0s and 1s.
`For example <https://github.com/sui77/rc-switch/wiki/HowTo_OperateLowCostOutlets#type-d-status> `__ `` '001010011001111101011011' `` .
- **protocol** (*Optional* , :ref: `RCSwitch protocol <rc_switch-protocol>` ): The RCSwitch protocol to use. Defaults to `` 1 `` .
- **rc_switch_type_a** : Send an RCSwitch `type A code <https://github.com/sui77/rc-switch/wiki/HowTo_OperateLowCostOutlets#type-a-10-pole-dip-switches> `__ .
- **group** (**Required** , string): The group to address, usually the state of the first 5 DIP switches.
Must be a string of 0s and 1s. For example `` '11001 `` .
- **device** (**Required** , string): The device within the group, usually the state of the last 5 DIP switches.
Must be a string of 0s and 1s. For example `` '01000 `` .
2019-02-27 18:32:47 +01:00
- **state** (**Required** , boolean): Whether to send a "turn on" or "turn off" signal when this switch
is triggered. See :ref: `remote_transmitter-on_off_template` .
2018-08-22 22:05:28 +02:00
- **protocol** (*Optional* , :ref: `RCSwitch protocol <rc_switch-protocol>` ): The RCSwitch protocol to use. Defaults to `` 1 `` .
2019-02-27 18:32:47 +01:00
- **rc_switch_type_b** : Send an RCSwitch
`type B code <https://github.com/sui77/rc-switch/wiki/HowTo_OperateLowCostOutlets#type-b-two-rotarysliding-switches> `__ .
2018-08-22 22:05:28 +02:00
- **address** (**Required** , int): The number of the first rotary switch. For example `` 4 `` .
- **channel** (**Required** , int): The number of the first rotary switch. For example `` 2 `` .
2019-02-27 18:32:47 +01:00
- **state** (**Required** , boolean): Whether to send a "turn on" or "turn off" signal when this switch
is triggered. See :ref: `remote_transmitter-on_off_template` .
2018-08-22 22:05:28 +02:00
- **protocol** (*Optional* , :ref: `RCSwitch protocol <rc_switch-protocol>` ): The RCSwitch protocol to use. Defaults to `` 1 `` .
- **rc_switch_type_c** : Send an RCSwitch `type C code <https://github.com/sui77/rc-switch/wiki/HowTo_OperateLowCostOutlets#type-c-intertechno> `__ .
- **family** (**Required** , string): The family of the device. Must be a character from `` a `` to `` p `` .
- **group** (**Required** , int): The group of the device. For example `` 4 `` .
- **address** (**Required** , int): The address of the device. For example `` 2 `` .
2019-02-27 18:32:47 +01:00
- **state** (**Required** , boolean): Whether to send a "turn on" or "turn off" signal when this switch
is triggered. See :ref: `remote_transmitter-on_off_template` .
2018-08-22 22:05:28 +02:00
- **protocol** (*Optional* , :ref: `RCSwitch protocol <rc_switch-protocol>` ): The RCSwitch protocol to use. Defaults to `` 1 `` .
- **rc_switch_type_d** : Send an RCSwitch type D code.
- **group** (**Required** , string): The group of the device. Must be a character from `` a `` to `` d `` .
- **device** (**Required** , int): The address of the device. For example `` 3 `` .
2019-02-27 18:32:47 +01:00
- **state** (**Required** , boolean): Whether to send a "turn on" or "turn off" signal when this switch
is triggered. See :ref: `remote_transmitter-on_off_template` .
2018-08-22 22:05:28 +02:00
- **protocol** (*Optional* , :ref: `RCSwitch protocol <rc_switch-protocol>` ): The RCSwitch protocol to use. Defaults to `` 1 `` .
2019-02-16 23:25:23 +01:00
- **rc5** : Send a RC5 IR code.
- **address** : The address of the device.
- **command** : The command to send.
2018-06-13 22:38:49 +02:00
- **raw** : Send an arbitrary signal.
- **carrier_frequency** : The frequency to use for the carrier. A lot
of IR sensors only respond to a very specific frequency.
- **data** : List containing integers describing the signal to send.
Each value is a time in µs declaring how long the carrier should
be switched on or off. Positive values mean ON, negative values
mean OFF.
.. _finding_remote_codes:
Finding Remote Codes
2018-08-24 22:44:01 +02:00
--------------------
2018-06-13 22:38:49 +02:00
Each remote transmitter uses a different protocol to send its information. So to replicate an infrared or 433MHz
remote you will first need to "learn" these codes. You will first need to hook up a receiver and sniff the codes
2019-02-27 10:10:09 +01:00
using the :doc: `remote receiver component </components/binary_sensor/remote_receiver>` like this:
2018-06-13 22:38:49 +02:00
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-13 22:38:49 +02:00
remote_receiver:
pin: GPIO34
# dump all signals we find
dump: all
2019-02-16 23:25:23 +01:00
And then activate the remote control you want to have in ESPHome. you will see a log output like this:
2018-06-13 22:38:49 +02:00
.. figure :: images/rf_receiver-log_raw.png
:align: center
Example log output for a 433MHz proprietary remote control.
2018-08-22 22:05:28 +02:00
Raw Remote Codes
2018-08-24 22:44:01 +02:00
***** ***** ***** *
2018-08-22 22:05:28 +02:00
2019-02-16 23:25:23 +01:00
If ESPHome has a decoder set up for the code, it will spit out the decoded code in the logs. In this case,
2018-08-22 22:05:28 +02:00
it's a proprietary protocol which would be difficult to reverse engineer. Fortunately, we can just
2018-06-13 22:38:49 +02:00
do a "replay attack" by repeating the signal we just saw for our own purposes. The output you see in above image
is encoded in microseconds: A negative value represents the output being LOW for x microseconds and a positive
value denotes the output being HIGH for the specified number of microseconds.
Now you only need to set up the remote transmitter (which well *send* the code) like this:
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-13 22:38:49 +02:00
remote_transmitter:
2019-02-27 10:10:09 +01:00
pin: GPIO23
# Set to 100% when working with RF signals, and 50% if working with IR leds
carrier_duty_percent: 100%
2018-06-13 22:38:49 +02:00
And lastly, we need to set up the switch that, when turned on, will send our pre-defined remote code:
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-06-13 22:38:49 +02:00
switch:
- platform: remote_transmitter
name: "My awesome RF switch"
raw: [4088, -1542, 1019, -510, 513, -1019, 510, -509, 511, -510, 1020,
-1020, 1022, -1019, 510, -509, 511, -510, 511, -509, 511, -510,
1020, -1019, 510, -511, 1020, -510, 512, -508, 510, -1020, 1022,
-1021, 1019, -1019, 511, -510, 510, -510, 1022, -1020, 1019,
-1020, 511, -511, 1018, -1022, 1020, -1019, 1021, -1019, 1020,
-511, 510, -1019, 1023, -1019, 1019, -510, 512, -508, 510, -511,
512, -1019, 510, -509]
Note that you don't need to include the leading `` 32519 `` here, as it denotes a final space at the end of
a transmission.
2018-08-22 22:05:28 +02:00
RCSwitch Remote Codes
2018-08-24 22:44:01 +02:00
***** ***** ***** ***** *
2018-08-22 22:05:28 +02:00
2019-02-16 23:25:23 +01:00
Starting with version 1.8.0 ESPHome can also recognize a bunch of 433MHz RF codes directly using `RCSwitch's <https://github.com/sui77/rc-switch> `__
2018-08-22 22:05:28 +02:00
remote protocol. If you have RF code dumping enabled for the receiver, you will then see log outputs like this one:
.. code ::
Received RCSwitch: protocol=1 data='0100010101'
Like before with raw codes, you can then use this code to create switches:
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-08-22 22:05:28 +02:00
switch:
- platform: remote_transmitter
name: "Living Room Lights On"
rc_switch_raw:
code: '0100010101'
protocol: 1
Alternatively, you can use the information on `this page <https://github.com/sui77/rc-switch/wiki/HowTo_OperateLowCostOutlets> `__
to manually find the RCSwitch codes without having to first find them using the remote receiver. For example, this would
2019-02-16 23:25:23 +01:00
be the ESPHome equivalent of the first Type-A switch on that site:
2018-08-22 22:05:28 +02:00
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-08-22 22:05:28 +02:00
switch:
- platform: remote_transmitter
name: "Living Room Lights On"
rc_switch_type_a:
group: '1101'
device: '0100'
state: True
.. _remote_transmitter-on_off_template:
On/Off template
---------------
Each switch of the `` remote_transmitter `` platform only sends a pre-defined remote code when switched on.
For example the RCSwitch example above always **sends the turn on** RF code to the wall plug. In some cases
you might want to have switches that can do both things, i.e. turn a light on when switched on and turn a light off
2019-02-07 13:54:45 +01:00
when switched off. To do this, use the :doc: `/components/switch/template` like this:
2018-08-22 22:05:28 +02:00
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-08-22 22:05:28 +02:00
switch:
- platform: remote_transmitter
id: living_room_lights_on
rc_switch_type_a:
group: '1101'
device: '0100'
state: True
- platform: remote_transmitter
id: living_room_lights_off
rc_switch_type_a:
group: '1101'
device: '0100'
state: False
- platform: template
name: Living Room Lights
optimistic: True
2019-02-16 23:25:23 +01:00
assumed_state: True
2018-08-22 22:05:28 +02:00
turn_on_action:
- switch.turn_on: living_room_lights_on
turn_off_action:
- switch.turn_on: living_room_lights_off
.. _rc_switch-protocol:
RCSwitch Protocol
-----------------
2019-02-16 23:25:23 +01:00
RCSwitch transmitters/receivers all have a `` protocol: `` option that can be used to tell ESPHome what timings to use
2018-08-22 22:05:28 +02:00
for the transmission. This is necessary as many remotes use different timings to encode a logic zero or one.
RCSwitch has 7 built-in protocols that cover most use cases. You can however also choose to use custom parameters
for the protocol like so
2018-11-19 18:32:16 +01:00
.. code-block :: yaml
2018-08-22 22:05:28 +02:00
# Use one of RCSwitch's pre-defined protocols (1-7)
protocol: 1
# Use a custom protocol:
protocol:
pulse_length: 175
sync: [1, 31]
zero: [1, 3]
one: [3, 1]
inverted: False
Configuration options for the custom variant:
- **pulse_length** (**Required** , int): The length of each pulse in microseconds.
- **sync** (*Optional* ): The number of on and off pulses for a sync bit. Defaults to 1 pulse on and 31 pulses off.
- **zero** (*Optional* ): The number of on and off pulses to encode a logic zero. Defaults to 1 pulse on and 3 pulses off.
- **one** (*Optional* ): The number of on and off pulses to encode a logic one. Defaults to 3 pulses on and 1 pulse off.
- **inverted** (*Optional* , boolean): Whether to treat this protocol as inverted, i.e. encode all on pulses by logic LOWs
and vice versa.
2018-06-13 22:38:49 +02:00
See Also
2018-08-24 22:44:01 +02:00
--------
2018-06-13 22:38:49 +02:00
- :doc: `index`
2019-02-27 10:10:09 +01:00
- :doc: `/components/binary_sensor/remote_receiver`
2018-08-24 22:44:01 +02:00
- `RCSwitch <https://github.com/sui77/rc-switch> `__ by `Suat Özgür <https://github.com/sui77> `__
- `IRRemoteESP8266 <https://github.com/markszabo/IRremoteESP8266/> `__ by `Mark Szabo-Simon <https://github.com/markszabo> `__
2019-02-07 13:54:45 +01:00
- :apiref: `remote/remote_transmitter.h`
- :ghedit: `Edit`
2019-03-06 11:02:03 +01:00
.. disqus ::