| @@ -1,4 +1,5 @@ | ||||
| # Usermod Animated Staircase | ||||
|  | ||||
| This usermod makes your staircase look cool by illuminating it with an animation. It uses | ||||
| PIR or ultrasonic sensors at the top and bottom of your stairs to: | ||||
|  | ||||
| @@ -11,11 +12,13 @@ The Animated Staircase can be controlled by the WLED API. Change settings such a | ||||
| speed, on/off time and distance by sending an HTTP request, see below. | ||||
|  | ||||
| ## WLED integration | ||||
|  | ||||
| To include this usermod in your WLED setup, you have to be able to [compile WLED from source](https://kno.wled.ge/advanced/compiling-wled/). | ||||
|  | ||||
| Before compiling, you have to make the following modifications: | ||||
|  | ||||
| Edit your environment in `platformio_override.ini` | ||||
|  | ||||
| 1. Open `platformio_override.ini` | ||||
| 2. add `Animated_Staircase` to the `custom_usermods` line for your environment | ||||
|  | ||||
| @@ -25,10 +28,10 @@ If you use PIR sensor enter -1 for echo pin. | ||||
| Maximum distance for ultrasonic sensor can be configured as the time needed for an echo (see below). | ||||
|  | ||||
| ## Hardware installation | ||||
|  | ||||
| 1. Attach the LED strip to each step of the stairs. | ||||
| 2. Connect the ESP8266 pin D4 or ESP32 pin D2 to the first LED data pin at the bottom step. | ||||
| 3. Connect the data-out pin at the end of each strip per step to the data-in pin on the  | ||||
|    next step, creating one large virtual LED strip. | ||||
| 3. Connect the data-out pin at the end of each strip per step to the data-in pin on the next step, creating one large virtual LED strip. | ||||
| 4. Mount sensors of choice at the bottom and top of the stairs and connect them to the ESP. | ||||
| 5. To make sure all LEDs get enough power and have your staircase lighted evenly, power each | ||||
|    step from one side, using at least AWG14 or 2.5mm^2 cable. Don't connect them serial as you | ||||
| @@ -37,20 +40,19 @@ Maximum distance for ultrasonic sensor can be configured as the time needed for | ||||
| You _may_ need to use 10k pull-down resistors on the selected PIR pins, depending on the sensor. | ||||
|  | ||||
| ## WLED configuration | ||||
| 1. In the WLED UI, configure a segment for each step. The lowest step of the stairs is the  | ||||
|    lowest segment id.  | ||||
|  | ||||
| 1. In the WLED UI, configure a segment for each step. The lowest step of the stairs is the lowest segment id. | ||||
| 2. Save your segments into a preset. | ||||
| 3. Ideally, add the preset in the config > LED setup menu to the "apply  | ||||
|    preset **n** at boot" setting. | ||||
| 3. Ideally, add the preset in the config > LED setup menu to the "apply preset **n** at boot" setting. | ||||
|  | ||||
| ## Changing behavior through API | ||||
|  | ||||
| The Staircase settings can be changed through the WLED JSON api. | ||||
|  | ||||
| **NOTE:** We are using [curl](https://curl.se/) to send HTTP POSTs to the WLED API. | ||||
| If you're using Windows and want to use the curl commands, replace the `\` with a `^` | ||||
| or remove them and put everything on one line. | ||||
|  | ||||
|  | ||||
| | Setting          | Description                                                   | Default | | ||||
| |------------------|---------------------------------------------------------------|---------| | ||||
| | enabled          | Enable or disable the usermod                                 | true    | | ||||
| @@ -74,6 +76,7 @@ The staircase settings and sensor states are inside the WLED "state" element: | ||||
| ``` | ||||
|  | ||||
| ### Enable/disable the usermod | ||||
|  | ||||
| By disabling the usermod you will be able to keep the LED's on, independent from the sensor | ||||
| activity. This enables you to play with the lights without the usermod switching them on or off. | ||||
|  | ||||
| @@ -90,6 +93,7 @@ To enable the usermod again, use `"enabled":true`. | ||||
| Alternatively you can use _Usermod_ Settings page where you can change other parameters as well. | ||||
|  | ||||
| ### Changing animation parameters and detection range of the ultrasonic HC-SR04 sensor | ||||
|  | ||||
| Using _Usermod_ Settings page you can define different usermod parameters, including sensor pins, delay between segment activation etc. | ||||
|  | ||||
| When an ultrasonic sensor is enabled you can enter maximum detection distance in centimeters separately for top and bottom sensors. | ||||
| @@ -99,6 +103,7 @@ distances creates delays in the WLED software, _might_ introduce timing hiccups | ||||
| a less responsive web interface. It is therefore advised to keep the detection distance as short as possible. | ||||
|  | ||||
| ### Animation triggering through the API | ||||
|  | ||||
| In addition to activation by one of the stair sensors, you can also trigger the animation manually | ||||
| via the API. To simulate triggering the bottom sensor, use: | ||||
|  | ||||
| @@ -115,15 +120,19 @@ curl -X POST -H "Content-Type: application/json" \ | ||||
|      -d '{"staircase":{"top-sensor":true}}' \ | ||||
|      xxx.xxx.xxx.xxx/json/state | ||||
| ``` | ||||
|  | ||||
| **MQTT** | ||||
| You can publish a message with either `up` or `down` on topic `/swipe` to trigger animation. | ||||
| You can also use `on` or `off` for enabling or disabling the usermod. | ||||
|  | ||||
| Have fun with this usermod.<br/> | ||||
| www.rolfje.com | ||||
| Have fun with this usermod | ||||
|  | ||||
| `www.rolfje.com` | ||||
|  | ||||
| Modifications @blazoncek | ||||
|  | ||||
| ## Change log | ||||
|  | ||||
| 2021-04 | ||||
| * Adaptation for runtime configuration. | ||||
|  | ||||
| - Adaptation for runtime configuration. | ||||
|   | ||||
| @@ -4,6 +4,7 @@ This usermod will read from an ambient light sensor like the BH1750. | ||||
| The luminance is displayed in both the Info section of the web UI, as well as published to the `/luminance` MQTT topic if enabled. | ||||
|  | ||||
| ## Dependencies | ||||
|  | ||||
| - Libraries | ||||
|   - `claws/BH1750 @^1.2.0` | ||||
| - Data is published over MQTT - make sure you've enabled the MQTT sync interface. | ||||
| @@ -13,23 +14,30 @@ The luminance is displayed in both the Info section of the web UI, as well as pu | ||||
| To enable, compile with `BH1750` in `custom_usermods` (e.g. in `platformio_override.ini`) | ||||
|  | ||||
| ### Configuration Options | ||||
|  | ||||
| The following settings can be set at compile-time but are configurable on the usermod menu (except First Measurement time): | ||||
| *   `USERMOD_BH1750_MAX_MEASUREMENT_INTERVAL` - the max number of milliseconds between measurements, defaults to 10000ms | ||||
| *   `USERMOD_BH1750_MIN_MEASUREMENT_INTERVAL` - the min number of milliseconds between measurements, defaults to 500ms | ||||
| *   `USERMOD_BH1750_OFFSET_VALUE` - the offset value to report on, defaults to 1 | ||||
| *   `USERMOD_BH1750_FIRST_MEASUREMENT_AT` - the number of milliseconds after boot to take first measurement, defaults to 10000 ms | ||||
|  | ||||
| - `USERMOD_BH1750_MAX_MEASUREMENT_INTERVAL` - the max number of milliseconds between measurements, defaults to 10000ms | ||||
| - `USERMOD_BH1750_MIN_MEASUREMENT_INTERVAL` - the min number of milliseconds between measurements, defaults to 500ms | ||||
| - `USERMOD_BH1750_OFFSET_VALUE` - the offset value to report on, defaults to 1 | ||||
| - `USERMOD_BH1750_FIRST_MEASUREMENT_AT` - the number of milliseconds after boot to take first measurement, defaults to 10000 ms | ||||
|  | ||||
| In addition, the Usermod screen allows you to: | ||||
|  | ||||
| - enable/disable the usermod | ||||
| - Enable Home Assistant Discovery of usermod | ||||
| - Configure the SCL/SDA pins | ||||
|  | ||||
| ## API | ||||
|  | ||||
| The following method is available to interact with the usermod from other code modules: | ||||
|  | ||||
| - `getIlluminance` read the brightness from the sensor | ||||
|  | ||||
| ## Change Log | ||||
|  | ||||
| Jul 2022 | ||||
|  | ||||
| - Added Home Assistant Discovery | ||||
| - Implemented PinManager to register pins | ||||
| - Made pins configurable in usermod menu | ||||
|   | ||||
| @@ -25,7 +25,7 @@ You can also use usermod's off timer instead of sensor's. In such case rotate th | ||||
|  | ||||
| **NOTE:** Usermod has been included in master branch of WLED so it can be compiled in directly just by defining `-D USERMOD_PIRSWITCH` and optionally `-D PIR_SENSOR_PIN=16` to override default pin. You can also change the default off time by adding `-D PIR_SENSOR_OFF_SEC=30`. | ||||
|  | ||||
| ## API to enable/disable the PIR sensor from outside. For example from another usermod: | ||||
| ## API to enable/disable the PIR sensor from outside. For example from another usermod | ||||
|  | ||||
| To query or change the PIR sensor state the methods `bool PIRsensorEnabled()` and `void EnablePIRsensor(bool enable)` are available. | ||||
|  | ||||
| @@ -33,15 +33,16 @@ When the PIR sensor state changes an MQTT message is broadcasted with topic `wle | ||||
| Usermod can also be configured to send just the MQTT message but not change WLED state using settings page as well as responding to motion only at night | ||||
| (assuming NTP and latitude/longitude are set to determine sunrise/sunset times). | ||||
|  | ||||
| ### There are two options to get access to the usermod instance: | ||||
| ### There are two options to get access to the usermod instance | ||||
|  | ||||
| 1. Include `usermod_PIR_sensor_switch.h` **before** you include other usermods in `usermods_list.cpp' | ||||
| _1._ Include `usermod_PIR_sensor_switch.h` **before** you include other usermods in `usermods_list.cpp' | ||||
|  | ||||
| or | ||||
|  | ||||
| 2. Use `#include "usermod_PIR_sensor_switch.h"` at the top of the `usermod.h` where you need it. | ||||
| _2._ Use `#include "usermod_PIR_sensor_switch.h"` at the top of the `usermod.h` where you need it. | ||||
|  | ||||
| **Example usermod.h :** | ||||
|  | ||||
| ```cpp | ||||
| #include "wled.h" | ||||
|  | ||||
| @@ -79,25 +80,30 @@ Usermod can be configured via the Usermods settings page. | ||||
| * `override` - override PIR input when WLED state is changed using UI | ||||
| * `domoticz-idx` - Domoticz virtual switch ID (used with MQTT `domoticz/in`) | ||||
|  | ||||
|  | ||||
| Have fun - @gegu & @blazoncek | ||||
|  | ||||
| ## Change log | ||||
|  | ||||
| 2021-04 | ||||
|  | ||||
| * Adaptation for runtime configuration. | ||||
|  | ||||
| 2021-11 | ||||
|  | ||||
| * Added information about dynamic configuration options | ||||
| * Added option to temporary enable/disable usermod from WLED UI (Info dialog) | ||||
|  | ||||
| 2022-11 | ||||
|  | ||||
| * Added compile time option for off timer. | ||||
| * Added Home Assistant autodiscovery MQTT broadcast. | ||||
| * Updated info on compiling. | ||||
|  | ||||
| 2023-?? | ||||
|  | ||||
| * Override option | ||||
| * Domoticz virtual switch ID (used with MQTT `domoticz/in`) | ||||
|  | ||||
| 2024-02 | ||||
|  | ||||
| * Added compile time option to expand number of PIR sensors (they are logically ORed) `-D PIR_SENSOR_MAX_SENSORS=3` | ||||
| @@ -40,6 +40,9 @@ If the fan speed is unlocked, it will revert to temperature controlled speed on | ||||
| ## Change Log | ||||
|  | ||||
| 2021-10 | ||||
|  | ||||
| * First public release | ||||
|  | ||||
| 2022-05 | ||||
|  | ||||
| * Added JSON API call to allow changing of speed | ||||
|   | ||||
| @@ -36,18 +36,22 @@ All parameters can be configured at runtime via the Usermods settings page, incl | ||||
| ## Change Log | ||||
|  | ||||
| 2020-09-12 | ||||
|  | ||||
| * Changed to use async non-blocking implementation | ||||
| * Do not report erroneous low temperatures to MQTT | ||||
| * Disable plugin if temperature sensor not detected | ||||
| * Report the number of seconds until the first read in the info screen instead of sensor error | ||||
|  | ||||
| 2021-04 | ||||
|  | ||||
| * Adaptation for runtime configuration. | ||||
|  | ||||
| 2023-05 | ||||
|  | ||||
| * Rewrite to conform to newer recommendations. | ||||
| * Recommended @blazoncek fork of OneWire for ESP32 to avoid Sensor error | ||||
|  | ||||
| 2024-09 | ||||
|  | ||||
| * Update OneWire to version 2.3.8, which includes stickbreaker's and garyd9's ESP32 fixes: | ||||
|   blazoncek's fork is no longer needed | ||||
| @@ -8,15 +8,17 @@ Does audio processing and provides data structure that specially written effects | ||||
| **does not** provide effects or draw anything to an LED strip/matrix. | ||||
|  | ||||
| ## Additional Documentation | ||||
|  | ||||
| This usermod is an evolution of [SR-WLED](https://github.com/atuline/WLED), and a lot of documentation and information can be found in the [SR-WLED wiki](https://github.com/atuline/WLED/wiki): | ||||
|  | ||||
| * [getting started with audio](https://github.com/atuline/WLED/wiki/First-Time-Setup#sound) | ||||
| * [Sound settings](https://github.com/atuline/WLED/wiki/Sound-Settings) - similar to options on the usemod settings page in WLED. | ||||
| * [Digital Audio](https://github.com/atuline/WLED/wiki/Digital-Microphone-Hookup) | ||||
| * [Analog Audio](https://github.com/atuline/WLED/wiki/Analog-Audio-Input-Options) | ||||
| * [UDP Sound sync](https://github.com/atuline/WLED/wiki/UDP-Sound-Sync) | ||||
|  | ||||
|  | ||||
| ## Supported MCUs | ||||
|  | ||||
| This audioreactive usermod works best on "classic ESP32" (dual core), and on ESP32-S3 which also has dual core and hardware floating point support. | ||||
|  | ||||
| It will compile successfully for ESP32-S2 and ESP32-C3, however might not work well, as other WLED functions will become slow. Audio processing requires a lot of computing power, which can be problematic on smaller MCUs like -S2 and -C3. | ||||
| @@ -25,6 +27,7 @@ Analog audio is only possible on "classic" ESP32, but not on other MCUs like ESP | ||||
|  | ||||
| Currently ESP8266 is not supported, due to low speed and small RAM of this chip. | ||||
| There are however plans to create a lightweight audioreactive for the 8266, with reduced features. | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| Add 'ADS1115_v2' to `custom_usermods` in your platformio environment. | ||||
| @@ -35,29 +38,31 @@ All parameters are runtime configurable. Some may require a hard reset after cha | ||||
|  | ||||
| If you want to define default GPIOs during compile time, use the following (default values in parentheses): | ||||
|  | ||||
| - `-D SR_DMTYPE=x` : defines digital microphone type: 0=analog, 1=generic I2S (default), 2=ES7243 I2S, 3=SPH0645 I2S, 4=generic I2S with master clock, 5=PDM I2S | ||||
| - `-D AUDIOPIN=x`  : GPIO for analog microphone/AUX-in (36) | ||||
| - `-D I2S_SDPIN=x` : GPIO for SD pin on digital microphone (32) | ||||
| - `-D I2S_WSPIN=x` : GPIO for WS pin on digital microphone (15) | ||||
| - `-D I2S_CKPIN=x` : GPIO for SCK pin on digital microphone (14) | ||||
| - `-D MCLK_PIN=x`  : GPIO for master clock pin on digital Line-In boards (-1) | ||||
| - `-D ES7243_SDAPIN` : GPIO for I2C SDA pin on ES7243 microphone (-1) | ||||
| - `-D ES7243_SCLPIN` : GPIO for I2C SCL pin on ES7243 microphone (-1) | ||||
| * `-D SR_DMTYPE=x` : defines digital microphone type: 0=analog, 1=generic I2S (default), 2=ES7243 I2S, 3=SPH0645 I2S, 4=generic I2S with master clock, 5=PDM I2S | ||||
| * `-D AUDIOPIN=x`  : GPIO for analog microphone/AUX-in (36) | ||||
| * `-D I2S_SDPIN=x` : GPIO for SD pin on digital microphone (32) | ||||
| * `-D I2S_WSPIN=x` : GPIO for WS pin on digital microphone (15) | ||||
| * `-D I2S_CKPIN=x` : GPIO for SCK pin on digital microphone (14) | ||||
| * `-D MCLK_PIN=x`  : GPIO for master clock pin on digital Line-In boards (-1) | ||||
| * `-D ES7243_SDAPIN` : GPIO for I2C SDA pin on ES7243 microphone (-1) | ||||
| * `-D ES7243_SCLPIN` : GPIO for I2C SCL pin on ES7243 microphone (-1) | ||||
|  | ||||
| Other options: | ||||
|  | ||||
| - `-D UM_AUDIOREACTIVE_ENABLE` : makes usermod default enabled (not the same as include into build option!) | ||||
| - `-D UM_AUDIOREACTIVE_DYNAMICS_LIMITER_OFF` : disables rise/fall limiter default | ||||
| * `-D UM_AUDIOREACTIVE_ENABLE` : makes usermod default enabled (not the same as include into build option!) | ||||
| * `-D UM_AUDIOREACTIVE_DYNAMICS_LIMITER_OFF` : disables rise/fall limiter default | ||||
|  | ||||
| **NOTE** I2S is used for analog audio sampling. Hence, the analog *buttons* (i.e. potentiometers) are disabled when running this usermod with an analog microphone. | ||||
|  | ||||
| ### Advanced Compile-Time Options | ||||
|  | ||||
| You can use the following additional flags in your `build_flags` | ||||
|  | ||||
| * `-D SR_SQUELCH=x`  : Default "squelch" setting (10) | ||||
| * `-D SR_GAIN=x`     : Default "gain" setting (60) | ||||
| * `-D I2S_USE_RIGHT_CHANNEL`: Use RIGHT instead of LEFT channel (not recommended unless you strictly need this). | ||||
| * `-D I2S_USE_16BIT_SAMPLES`: Use 16bit instead of 32bit for internal sample buffers. Reduces sampling quality, but frees some RAM ressources (not recommended unless you absolutely need this). | ||||
| * `-D I2S_GRAB_ADC1_COMPLETELY`: Experimental: continuously sample analog ADC microphone. Only effective on ESP32. WARNING this _will_ cause conflicts(lock-up) with any analogRead() call. | ||||
| * `-D I2S_GRAB_ADC1_COMPLETELY`: Experimental: continuously sample analog ADC microphone. Only effective on ESP32. WARNING this *will* cause conflicts(lock-up) with any analogRead() call. | ||||
| * `-D MIC_LOGGER`     : (debugging) Logs samples from the microphone to serial USB. Use with serial plotter (Arduino IDE) | ||||
| * `-D SR_DEBUG`       : (debugging) Additional error diagnostics and debug info on serial USB. | ||||
|  | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| ### Shift Light for Project Cars | ||||
| # Shift Light for Project Cars | ||||
|  | ||||
| Turn your WLED lights into a rev light and shift indicator for Project Cars. | ||||
| It's easy to use. | ||||
|  | ||||
| 1. Make sure your WLED device and your PC/console are on the same network and can talk to each other | ||||
| _1._ Make sure your WLED device and your PC/console are on the same network and can talk to each other | ||||
|  | ||||
| 2. Go to the gameplay settings menu in PCARS and enable UDP. There are 9 numbers you can choose from. This is the refresh rate. The lower the number, the better. However, you might run into problems at faster rates. | ||||
| _2._ Go to the gameplay settings menu in PCARS and enable UDP. There are 9 numbers you can choose from. This is the refresh rate. The lower the number, the better. However, you might run into problems at faster rates. | ||||
|  | ||||
| | Number | Updates/Second | | ||||
| | ------ | -------------- | | ||||
| @@ -19,5 +19,5 @@ It's easy to use. | ||||
| | 8      | 05             | | ||||
| | 9      | 1              | | ||||
|  | ||||
| 3. Once you enter a race, WLED should automatically shift to PCARS mode. | ||||
| 4. Done. | ||||
| _3._ Once you enter a race, WLED should automatically shift to PCARS mode. | ||||
| _4._ Done. | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| ### Usermods | ||||
| # Usermods | ||||
|  | ||||
| This folder serves as a repository for usermods (custom `usermod.cpp` files)! | ||||
|  | ||||
| @@ -6,11 +6,11 @@ If you have created a usermod you believe is useful (for example to support a pa | ||||
|  | ||||
| In order for other people to be able to have fun with your usermod, please keep these points in mind: | ||||
|  | ||||
| -   Create a folder in this folder with a descriptive name (for example `usermod_ds18b20_temp_sensor_mqtt`)   | ||||
| -   Include your custom files  | ||||
| -   If your usermod requires changes to other WLED files, please write a `readme.md` outlining the steps one needs to take   | ||||
| -   Create a pull request!   | ||||
| -   If your feature is useful for the majority of WLED users, I will consider adding it to the base code!   | ||||
| * Create a folder in this folder with a descriptive name (for example `usermod_ds18b20_temp_sensor_mqtt`)   | ||||
| * Include your custom files  | ||||
| * If your usermod requires changes to other WLED files, please write a `readme.md` outlining the steps one needs to take   | ||||
| * Create a pull request!   | ||||
| * If your feature is useful for the majority of WLED users, I will consider adding it to the base code!   | ||||
|  | ||||
| While I do my best to not break too much, keep in mind that as WLED is updated, usermods might break.   | ||||
| I am not actively maintaining any usermod in this directory, that is your responsibility as the creator of the usermod. | ||||
|   | ||||
| @@ -1,35 +1,43 @@ | ||||
| # SHT | ||||
|  | ||||
| Usermod to support various SHT i2c sensors like the SHT30, SHT31, SHT35 and SHT85 | ||||
|  | ||||
| ## Requirements | ||||
| * "SHT85" by Rob Tillaart, v0.2 or higher: https://github.com/RobTillaart/SHT85 | ||||
|  | ||||
| * "SHT85" by Rob Tillaart, v0.2 or higher: <https://github.com/RobTillaart/SHT85> | ||||
|  | ||||
| ## Usermod installation | ||||
|  | ||||
| Simply copy the below block (build task) to your `platformio_override.ini` and compile WLED using this new build task. Or use an existing one, add the custom_usermod `sht`. | ||||
|  | ||||
| ESP32: | ||||
| ``` | ||||
|  | ||||
| ```ini | ||||
| [env:custom_esp32dev_usermod_sht] | ||||
| extends = env:esp32dev | ||||
| custom_usermods = ${env:esp32dev.custom_usermods} sht | ||||
| ``` | ||||
|  | ||||
| ESP8266: | ||||
| ``` | ||||
|  | ||||
| ```ini | ||||
| [env:custom_d1_mini_usermod_sht] | ||||
| extends = env:d1_mini | ||||
| custom_usermods = ${env:d1_mini.custom_usermods} sht | ||||
| ``` | ||||
|  | ||||
| ## MQTT Discovery for Home Assistant | ||||
|  | ||||
| If you're using Home Assistant and want to have the temperature and humidity available as entities in HA, you can tick the "Add-To-Home-Assistant-MQTT-Discovery" option in the usermod settings. If you have an MQTT broker configured under "Sync Settings" and it is connected, the mod will publish the auto discovery message to your broker and HA will instantly find it and create an entity each for the temperature and humidity. | ||||
|  | ||||
| ### Publishing readings via MQTT | ||||
|  | ||||
| Regardless of having MQTT discovery ticked or not, the mod will always report temperature and humidity to the WLED MQTT topic of that instance, if you have a broker configured and it's connected. | ||||
|  | ||||
| ## Configuration | ||||
|  | ||||
| Navigate to the "Config" and then to the "Usermods" section. If you compiled WLED with `-D USERMOD_SHT`, you will see the config for it there: | ||||
|  | ||||
| * SHT-Type: | ||||
|   * What it does: Select the SHT sensor type you want to use | ||||
|   * Possible values: SHT30, SHT31, SHT35, SHT85 | ||||
| @@ -44,8 +52,11 @@ Navigate to the "Config" and then to the "Usermods" section. If you compiled WLE | ||||
|   * Default: Disabled | ||||
|  | ||||
| ## Change log | ||||
|  | ||||
| 2022-12 | ||||
|  | ||||
| * First implementation. | ||||
|  | ||||
| ## Credits | ||||
| ezcGman | Andy: Find me on the Intermit.Tech (QuinLED) Discord server: https://discord.gg/WdbAauG | ||||
|  | ||||
| ezcGman | Andy: Find me on the Intermit.Tech (QuinLED) Discord server: <https://discord.gg/WdbAauG> | ||||
|   | ||||
| @@ -5,7 +5,7 @@ The `usermod_v2_HttpPullLightControl` is a custom user module for WLED that enab | ||||
| ## Features | ||||
|  | ||||
| * Configure the URL endpoint (only support HTTP for now, no HTTPS) and polling interval via the WLED user interface. | ||||
| * All options from the JSON API are supported (since v0.0.3). See: https://kno.wled.ge/interfaces/json-api/  | ||||
| * All options from the JSON API are supported (since v0.0.3). See: [https://kno.wled.ge/interfaces/json-api/](https://kno.wled.ge/interfaces/json-api/) | ||||
| * The ability to control the brightness of all lights and the state (on/off) and color of individual lights remotely. | ||||
| * Start or stop an effect and when you run the same effect when its's already running, it won't restart. | ||||
| * The ability to control all these settings per segment. | ||||
| @@ -13,13 +13,15 @@ The `usermod_v2_HttpPullLightControl` is a custom user module for WLED that enab | ||||
| * Unique ID generation based on the device's MAC address and a configurable salt value, appended to the request URL for identification. | ||||
|  | ||||
| ## Configuration | ||||
|  | ||||
| * Enable the `usermod_v2_HttpPullLightControl` via the WLED user interface. | ||||
| * Specify the URL endpoint and polling interval. | ||||
|  | ||||
| ## JSON Format and examples | ||||
|  | ||||
| * The module sends a GET request to the configured URL, appending a unique identifier as a query parameter: `https://www.example.com/mycustompage.php?id=xxxxxxxx` where xxxxxxx is a 40 character long SHA1 hash of the MAC address combined with a given salt. | ||||
|  | ||||
| * Response Format (since v0.0.3) it is eactly the same as the WLED JSON API, see: https://kno.wled.ge/interfaces/json-api/ | ||||
| * Response Format (since v0.0.3) it is eactly the same as the WLED JSON API, see: [https://kno.wled.ge/interfaces/json-api/](https://kno.wled.ge/interfaces/json-api/) | ||||
| After getting the URL (it can be a static file like static.json or a mylogic.php which gives a dynamic response), the response is read and parsed to WLED. | ||||
|  | ||||
| * An example of a response to set the individual lights: 0 to RED, 12 to Green and 14 to BLUE. Remember that is will SET lights, you might want to set all the others to black. | ||||
| @@ -58,6 +60,8 @@ After getting the URL (it can be a static file like static.json or a mylogic.php | ||||
| }` | ||||
|  | ||||
| * Or use the following example to start an effect, but first we UNFREEZE (frz=false) the segment because it was frozen by individual light control in the previous examples (28=Chase effect, Speed=180m Intensity=128). The three color slots are the slots you see under the color wheel and used by the effect. RED, Black, White in this case. | ||||
|  | ||||
| ```json | ||||
| `{ | ||||
|   "seg": | ||||
|     { | ||||
| @@ -72,34 +76,35 @@ After getting the URL (it can be a static file like static.json or a mylogic.php | ||||
|       ] | ||||
|     } | ||||
| }` | ||||
|  | ||||
| ``` | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| 1. Add `usermod_v2_HttpPullLightControl` to your WLED project following the instructions provided in the WLED documentation. | ||||
| 2. Compile by setting the build_flag: -D USERMOD_HTTP_PULL_LIGHT_CONTROL and upload to your ESP32/ESP8266! | ||||
| 3. There are several compile options which you can put in your platformio.ini or platformio_override.ini: | ||||
| - -DUSERMOD_HTTP_PULL_LIGHT_CONTROL   ;To Enable the usermod | ||||
| - -DHTTP_PULL_LIGHT_CONTROL_URL="\"http://mydomain.com/json-response.php\""   ; The URL which will be requested all the time to set the lights/effects | ||||
| -  -DHTTP_PULL_LIGHT_CONTROL_SALT="\"my_very-S3cret_C0de\""  ; A secret SALT which will help by making the ID more safe | ||||
| -  -DHTTP_PULL_LIGHT_CONTROL_INTERVAL=30 ; The interval at which the URL is requested in seconds | ||||
| -  -DHTTP_PULL_LIGHT_CONTROL_HIDE_SALT ; Do you want to Hide the SALT in the User Interface? If yes, Set this flag. Note that the salt can now only be set via the above -DHTTP_PULL_LIGHT_CONTROL_SALT= setting | ||||
|  | ||||
| -  -DWLED_AP_SSID="\"Christmas Card\"" ; These flags are not just for my Usermod but you probably want to set them | ||||
| -  -DWLED_AP_PASS="\"christmas\"" | ||||
| -  -DWLED_OTA_PASS="\"otapw-secret\"" | ||||
| -  -DMDNS_NAME="\"christmascard\"" | ||||
| -  -DSERVERNAME="\"CHRISTMASCARD\"" | ||||
| -  -D ABL_MILLIAMPS_DEFAULT=450 | ||||
| -  -D DEFAULT_LED_COUNT=60 ; For a LED Ring of 60 LEDs | ||||
| -  -D BTNPIN=41  ; The M5Stack Atom S3 Lite has a button on GPIO41 | ||||
| -  -D DATA_PINS=2 ; The M5Stack Atom S3 Lite has a Grove connector on the front, we use this GPIO2 | ||||
| -  -D STATUSLED=35 ; The M5Stack Atom S3 Lite has a Multi-Color LED on GPIO35, although I didnt managed to control it | ||||
| -  -D IRPIN=4  ; The M5Stack Atom S3 Lite has a IR LED on GPIO4 | ||||
| * -DUSERMOD_HTTP_PULL_LIGHT_CONTROL   ;To Enable the usermod | ||||
| * -DHTTP_PULL_LIGHT_CONTROL_URL="\"`http://mydomain.com/json-response.php`\""   ; The URL which will be requested all the time to set the lights/effects | ||||
| * -DHTTP_PULL_LIGHT_CONTROL_SALT="\"my_very-S3cret_C0de\""  ; A secret SALT which will help by making the ID more safe | ||||
| * -DHTTP_PULL_LIGHT_CONTROL_INTERVAL=30 ; The interval at which the URL is requested in seconds | ||||
| * -DHTTP_PULL_LIGHT_CONTROL_HIDE_SALT ; Do you want to Hide the SALT in the User Interface? If yes, Set this flag. Note that the salt can now only be set via the above -DHTTP_PULL_LIGHT_CONTROL_SALT= setting | ||||
|  | ||||
| -  -D DEBUG=1  ; Set these DEBUG flags ONLY if you want to debug and read out Serial (using Visual Studio Code - Serial Monitor) | ||||
| -  -DDEBUG_LEVEL=5 | ||||
| -  -DWLED_DEBUG | ||||
| * -DWLED_AP_SSID="\"Christmas Card\"" ; These flags are not just for my Usermod but you probably want to set them | ||||
| * -DWLED_AP_PASS="\"christmas\"" | ||||
| * -DWLED_OTA_PASS="\"otapw-secret\"" | ||||
| * -DMDNS_NAME="\"christmascard\"" | ||||
| * -DSERVERNAME="\"CHRISTMASCARD\"" | ||||
| * -D ABL_MILLIAMPS_DEFAULT=450 | ||||
| * -D DEFAULT_LED_COUNT=60 ; For a LED Ring of 60 LEDs | ||||
| * -D BTNPIN=41  ; The M5Stack Atom S3 Lite has a button on GPIO41 | ||||
| * -D DATA_PINS=2 ; The M5Stack Atom S3 Lite has a Grove connector on the front, we use this GPIO2 | ||||
| * -D STATUSLED=35 ; The M5Stack Atom S3 Lite has a Multi-Color LED on GPIO35, although I didnt managed to control it | ||||
| * -D IRPIN=4  ; The M5Stack Atom S3 Lite has a IR LED on GPIO4 | ||||
|  | ||||
| * -D DEBUG=1  ; Set these DEBUG flags ONLY if you want to debug and read out Serial (using Visual Studio Code - Serial Monitor) | ||||
| * -DDEBUG_LEVEL=5 | ||||
| * -DWLED_DEBUG | ||||
|  | ||||
| ## Use Case: Interactive Christmas Cards | ||||
|  | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
|  | ||||
| v2 Usermod to automatically save settings | ||||
| to preset number AUTOSAVE_PRESET_NUM after a change to any of: | ||||
|  | ||||
| * brightness | ||||
| * effect speed | ||||
| * effect intensity | ||||
| @@ -50,6 +51,9 @@ Note: the Four Line Display usermod requires the libraries `U8g2` and `Wire`. | ||||
| ## Change Log | ||||
|  | ||||
| 2021-02 | ||||
|  | ||||
| * First public release | ||||
|  | ||||
| 2021-04 | ||||
|  | ||||
| * Adaptation for runtime configuration. | ||||
|   | ||||
| @@ -10,8 +10,8 @@ define `USERMOD_BRIGHTNESS_FOLLOW_SUN` e.g. `#define USERMOD_BRIGHTNESS_FOLLOW_S | ||||
|  | ||||
| or add `-D USERMOD_BRIGHTNESS_FOLLOW_SUN` to `build_flags` in platformio_override.ini | ||||
|  | ||||
|  | ||||
| ### Options | ||||
|  | ||||
| Open Usermod Settings in WLED to change settings: | ||||
|  | ||||
| `Enable` - When checked `Enable`, turn on the `Brightness Follow Sun` Usermod, which will automatically turn on the lights, adjust the brightness, and turn off the lights. If you need to completely turn off the lights, please unchecked `Enable`. | ||||
| @@ -24,12 +24,12 @@ Open Usermod Settings in WLED to change settings: | ||||
|  | ||||
| `Relax Hour` - The unit is in hours, with an effective range of 0-6. According to the settings, maintain the lowest brightness for 0-6 hours before sunrise and after sunset. | ||||
|  | ||||
|  | ||||
| ### PlatformIO requirements | ||||
|  | ||||
| No special requirements. | ||||
|  | ||||
| ## Change Log | ||||
| ### Change Log | ||||
|  | ||||
| 2025-01-02 | ||||
|  | ||||
| * init | ||||
|   | ||||
| @@ -5,6 +5,7 @@ This usermod could be used in compination with `usermod_v2_rotary_encoder_ui_ALT | ||||
| ## Functionalities | ||||
|  | ||||
| Press the encoder to cycle through the options: | ||||
|  | ||||
| * Brightness | ||||
| * Speed | ||||
| * Intensity | ||||
| @@ -53,7 +54,6 @@ These options are configurable in Config > Usermods | ||||
| * `showSeconds` - Show seconds on the clock display | ||||
| * `i2c-freq-kHz` - I2C clock frequency in kHz (may help reduce dropped frames, range: 400-3400) | ||||
|  | ||||
|  | ||||
| ### PlatformIO requirements | ||||
|  | ||||
| Note: the Four Line Display usermod requires the libraries `U8g2` and `Wire`. | ||||
| @@ -61,4 +61,5 @@ Note: the Four Line Display usermod requires the libraries `U8g2` and `Wire`. | ||||
| ## Change Log | ||||
|  | ||||
| 2021-10 | ||||
|  | ||||
| * First public release | ||||
|   | ||||
| @@ -5,6 +5,7 @@ This usermod supports the UI of the `usermod_v2_rotary_encoder_ui_ALT`. | ||||
| ## Functionalities | ||||
|  | ||||
| Press the encoder to cycle through the options: | ||||
|  | ||||
| * Brightness | ||||
| * Speed | ||||
| * Intensity | ||||
| @@ -39,4 +40,5 @@ No special requirements. | ||||
| ## Change Log | ||||
|  | ||||
| 2021-10 | ||||
|  | ||||
| * First public release | ||||
|   | ||||
| @@ -8,7 +8,8 @@ active: enable/disable usermod | ||||
| diplayItIs: enable/disable display of "Es ist" on the clock | ||||
| ledOffset: number of LEDs before the wordclock LEDs | ||||
|  | ||||
| ### Update for alternative wiring pattern | ||||
| ## Update for alternative wiring pattern | ||||
|  | ||||
| Based on this fantastic work I added an alternative wiring pattern. | ||||
| The original used a long wire to connect DO to DI, from one line to the next line. | ||||
|  | ||||
| @@ -17,7 +18,6 @@ With this method, every other line was inverted and showed the wrong letter. | ||||
|  | ||||
| I added a switch in usermod called "meander wiring?" to enable/disable the alternate wiring pattern. | ||||
|  | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| Copy and update the example `platformio_override.ini.sample` | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 netmindz
					netmindz