-
Notifications
You must be signed in to change notification settings - Fork 0
MagicHome with ESP8285
Yet another MagicHome RGB controller. I specifically had this one: https://www.aliexpress.com/item/DC5-24V-Wireless-WIFI-LED-RGB-Controller-RGBW-Controller-IR-RF-Remote-Control-IOS-Android-for/32827253255.html
Aside from it going 9-28v, there are no other external model numbers etc, however opening it up revealed a very different configuration inside, using an ESP8285 chip directly on the board.
![opened with cover in view](https://user-images.githubusercontent.com/816454/43894935-fd83a9d8-9c16-11e8-9a78-b7a058d972de.jpg)
(Right click and view the original image to see the full size image for all images below)
Looking closely you can see it's an ESP8285, on the main board, it has the part number: ZJ-WFMN-B V1.1
or ZJ-WFMN-A V1.1
![board top 1](https://user-images.githubusercontent.com/816454/43895058-6fcb4e10-9c17-11e8-8c9c-b99c57a39c55.jpg)
![board top 2](https://user-images.githubusercontent.com/816454/43895059-6ffdd7b8-9c17-11e8-994e-aeb8f65f47ef.jpg)
I found that on the back it has pads to solder to so you can flash it.
![board back](https://user-images.githubusercontent.com/816454/43895057-6f80d178-9c17-11e8-8c6f-535d31ea0603.jpg)
The IO0
port is GPIO0
that needs to be pulled to ground when powered on for flashing (as per all ESP devices). I soldered cables to each of these. Note that some are very close to other pads, so be careful. If you want to avoid soldering, also pogo pins work well with the pads.
![board back with cables](https://user-images.githubusercontent.com/816454/43895056-6f41e094-9c17-11e8-95b7-cf565967c89e.jpg)
Once flashed, I configured it as follows (using Tasmota v6.1.1):
ZJ-WFMN-B V1.1 (RGBW-Version)
Field | Value |
---|---|
Module type | 18 Generic |
D1 GPIO5 | 38 PWM2 |
D6 GPIO12 | 39 PWM3 |
D7 GPIO13 | 40 PWM4 |
D5 GPIO14 | 37 PWM1 |
ZJ-WFMN-A V1.1 (RGBW Version with RF)
Field | Value | Function |
---|---|---|
Module type | 18 Generic | Module type |
D2 GPIO4 | 51 IRRecv | IR Remote (optional, view console for debugging!) |
D1 GPIO5 | 38 PWM2 | BLUE |
D6 GPIO12 | 37 PWM1 | RED |
D7 GPIO13 | 39 PWM3 | GREEN |
D8 GPIO15 | 40 PWM4 | WHITE |
ZJ-WFMN-A V1.1 (RGB version)
Field | Value | Function |
---|---|---|
Module type | 18 Generic | Module type |
D1 GPIO5 | 37 PWM1 | RED |
D6 GPIO12 | 38 PWM2 | GREEN |
D7 GPIO13 | 39 PWM3 | BLUE |
ZJ-WFMN-A V1.1 (RGB version with RF)
Field | Value | Function |
---|---|---|
Module type | 18 Generic | Module type |
D2 GPIO4 | 51 IRRecv | IR Remote |
D1 GPIO5 | 37 PWM1 | RED |
D6 GPIO12 | 38 PWM2 | GREEN |
D7 GPIO13 | 39 PWM3 | BLUE |
With all that done, one of the critical things I needed to do so I could set the colors was to run the command to set SetOption15
to 1
. For me, this was sending the MQTT command (you will need to adjust for your config):
mosquitto_pub -t 'cmnd/rgbled/SetOption15' -m '1'
Once the above was done and the device rebooted, I could set the colors using commands such as (to turn on red and white full):
mosquitto_pub -h openhab.sf -t 'cmnd/rgbled/color' -m '#ff0000ff'
If you have a RF variant, you will want to configure the GPIOs like this:
{ "MagicHome RF", // Magic Home RF (ESP8266) - (Arilux LC10)
GPIO_USER, // GPIO00 Optional Button
GPIO_USER, // GPIO01 Serial RXD and Optional sensor
GPIO_LED1_INV, // GPIO02 Blue onboard LED (optional)
GPIO_USER, // GPIO03 Serial TXD and Optional sensor0
GPIO_ARIRFRCV, // GPIO04 RF receiver input
GPIO_PWM2, // GPIO05 RGB LED Green
0, 0, 0, 0, 0, 0, // Flash connection
GPIO_PWM3, // GPIO12 RGB LED Blue
GPIO_PWM4, // GPIO13 RGBW LED White
GPIO_PWM1, // GPIO14 RGB LED Red
GPIO_LED2_INV, // GPIO15 RF receiver control
0, 0
},
or like this:
{ "MagicHome RF", // Magic Home RF (ESP8285) - (IRrecv)
GPIO_USER, // GPIO00 Optional Button
GPIO_USER, // GPIO01 Serial RXD and Optional sensor
GPIO_LED1_INV, // GPIO02 Blue onboard LED (not soldered)
GPIO_USER, // GPIO03 Serial TXD and Optional sensor0
GPIO_IRRECV, // GPIO04 RF receiver input
GPIO_PWM1, // GPIO05 RGB LED Green
0, 0, 0, 0, 0, 0, // Flash connection
GPIO_PWM2, // GPIO12 RGB LED Blue
GPIO_PWM3, // GPIO13 RGBW LED White
0, 0, 0
},
After chosing the correct module type in your Tasmota configuration, press a key on the remote after boot for the device to learn your code.
Each rule can only be 511 characters long, some of the colors below use the built in predefined shortcut color numbers.
mosquitto_pub -t 'cmnd/RGBled/rule1' -m 'On IrReceived#Data=0x00FF906F Do Dimmer + EndOn On IrReceived#Data=0x00FF9867 Do Color2 1 EndOn On IrReceived#Data=0x00FFE817 Do HSBColor1 13 EndOn On IrReceived#Data=0x00FF02FD Do HSBColor1 23 EndOn On IrReceived#Data=0x00FF50AF Do HSBColor1 33 EndOn On IrReceived#Data=0x00FF38C7 Do HSBColor1 43 EndOn On IrReceived#Data=0x00FFB847 Do Dimmer - EndOn On IrReceived#Data=0x00FFD827 Do Color2 2 EndOn On IrReceived#Data=0x00FF48B7 Do HSBColor1 140 EndOn On IrReceived#Data=0x00FF32CD Do HSBColor1 160 EndOn'
mosquitto_pub -t 'cmnd/RGBled/rule2' -m 'Rule2 On IrReceived#Data=0x00FF7887 Do HSBColor1 180 EndOn On IrReceived#Data=0x00FF28D7 Do HSBColor1 200 EndOn On IrReceived#Data=0x00FFF807 Do Power 0 EndOn On IrReceived#Data=0x00FF8877 Do Color2 3 EndOn On IrReceived#Data=0x00FF6897 Do HSBColor1 260 EndOn On IrReceived#Data=0x00FF20DF Do HSBColor1 280 EndOn On IrReceived#Data=0x00FF708F Do HSBColor1 300 EndOn On IrReceived#Data=0x00FFF00F Do HSBColor1 320 EndOn'
mosquitto_pub -t 'cmnd/RGBled/rule3' -m 'Rule3 On IrReceived#Data=0x00FFB04F Do Power 1 EndOn On IrReceived#Data=0x00FFA857 Do Color2 12 EndOn On IrReceived#Data=0x00FFB24D Do Backlog Power 0; WakeupDuration 1; Dimmer 100; Wakeup EndOn On IrReceived#Data=0x00FF00FF Do Backlog Power 0; WakeupDuration 5; Wakeup EndOn On IrReceived#Data=0x00FF58A7 Do Backlog Scheme 2; Speed 1 EndOn On IrReceived#Data=0x00FF30CF Do Backlog Scheme 3; Speed 5 EndOn'
A Google Sheets Document to edit the desired actions and create the three needed rules is linked here.
After setting the rules you need to activate them with the following:
mosquitto_pub -t 'cmnd/RGBled/rule1' -m 'ON'
mosquitto_pub -t 'cmnd/RGBled/rule2' -m 'ON'
mosquitto_pub -t 'cmnd/RGBled/rule3' -m 'ON'
The hex codes for the "Data" value come from the data tag when looking at the JSON sent via MQTT. You can also view this data on the Tasmota console screen. From here you can program it to do what ever you want. See here for more details: https://github.com/arendst/Sonoff-Tasmota/wiki/Rules
Home
What's New
Contributing
Installation
Prerequisites
Hardware Preparation
Flashing
Initial Configuration
MQTT
Upgrading
Troubleshooting
Tutorials
FAQ
Features
Commands
Templates
Modules
Components
Rules
Smart Home Integrations
Device Configuration
Device Templates Repository
Flashing Guides
Buttons and Switches
Sensors
Lights
Displays
Useful Topics
Power Monitoring Calibration
MQTT Overview
MQTT Retained Messages
Energy Saving
Securing Your Setup
Syslog Setup
Theo's Tips
Various Tips
LEGO Nightstand Switch
For Developers
JSON Status Responses
Sensor API
Time Proportioned Output Fork
PID Control Fork