This provides an interface between a physical fan remote (like one of these) and a Home Assistant installation. This implementation uses ESPHome to enable the communication from an ESP8266 device. For this project, I'm using the NodeMCU development board but any development board utilizing the ESP8266 or the ESP32 should work (probably with some modifications).
Currently, the hardware setup is lackluster. I will improve it if anyone asks for improvements.
- Extract the daughter board and antenna from a fan receiver (I used this one but most should work).
- Connect the antenna directly to the daughter board.
- Connect the
V
andG
labelled pins to the3.3v
andGND
pins of the development board, respectively. - Connect the center data pin of the daughter board to a digital input pin of the development board. I used pin
5
. Change the#define RECEIVER_PIN 5
line if you use another pin. - Set up the software!
- Follow the Home Assistant Getting Started tutorial to get that setup.
- Follow the ESPHome tutorial for Home Assistant to get ESPHome hooked up. I recommend installing the SSH & Web Terminal and File editor add-ons from the add-on store as well to make your life easier.
- After setting that up, create a node according to the ESPHome tutorial. Then copy the contents of
fan_remote_receiver.yaml
into the generated config file. Be sure not to override youresphome.name
,esphome.platform
, andesphome.board
if it differs from theyaml
provided. Copyfan_receiver.h
to theconfig/esphome/
directory. This can be done easily using the File editor add-on mentioned before. - In ESPHome, generate the binary file by clicking on the three dots to the right of the node card, clicking Compile, and then cicking Download Binary. I recommend using the ESPHome Flasher for the very first upload to your board. After that, you can use ESPHome's Upload functionality to update the board OTA. Pretty cool!
- Once uploaded, the board will automatically connect to the Home Assistant installation and you should see the buttons in the Overview tab of Home Assistant.
The remote I used for this had the DIP switches in the 1100
position. That means, the switches labeled 1
and 2
were in the ON
position and the switches labeled 3
and 4
were in the OFF
position. If you can use that combination as well, the included fan_receiver.h
file will work for you as is.
If you want to use any code other than 1100
, then after uploading the software to the board, open up the LOGS
on the ESPHome panel. Once the log viewer opens up, press any button on your remote and it will show Value: XXX
where XXX
is the number you need to note down for the pressed button. Then, modify the lines show below in fan_receiver.h
to include the correct corresponding codes.
void setup() override {
remote = new HT12E(RECEIVER_PIN);
mappings[0] = new Mapping(fan_light_button, "light_dimmer", 510);
mappings[1] = new Mapping(fan_low_button, "fan-low", 503);
mappings[2] = new Mapping(fan_med_button, "fan-med", 495);
mappings[3] = new Mapping(fan_high_button, "fan-hig", 479);
mappings[4] = new Mapping(fan_off_button, "fan-off", 509);
}
This would not have been possible were it not for the HT12E library created by user neuron_upheaval on the Arduino forums. Link to the post here.
Feel free to submit a pull request!