Skip to content

Add own functionality

Def3nder edited this page Jan 8, 2020 · 18 revisions

This page is intended for those wishing to modify the WLED code to add their own functionality.

Basics

Programming is done in the Arduino IDE. There is a special file, wled06_usermod.ino, to write your own code. (however, if you think your code may be relevant to many users, feel free to code it in directly and open a pull request)

This file has three empty methods:

  • userBeginPreConnection() is called after loading settings but before connecting to WiFi. Use it to load custom settings or to specify own server pages with the server.on() method.
  • userBegin() is the main initialization. Use it to start own interfaces (IR, UDP ports, Websockets, GPIOs,...).
  • userLoop() is called by the main loop() function.

Modify WLED values

If you know what you're doing, you may choose to change the value of any global variable declared in wled00.ino. However, for basic color and brightness changes, these are the most important:

Variable Name Type Purpose
bri byte (0-255) Master Brightness (0 is off, 255 is maximum)
col[0] byte (0-255) Red color value
col[1] byte (0-255) Green color value
col[2] byte (0-255) Blue color value
col[3] byte (0-255) White color value

After updating the color, you must call the colorUpdated(int) method. If you want to send a notification with the new color to other ESPs, use colorUpdated(1), otherwise colorUpdated(5).

Timing

If you'd just like a simple modification that requires timing (like sending a request every 2 seconds), please never use the delay() function in your userLoop()! It will block everything else and WLED will become unresponsive and effects won't work! Instead, try this instead:

long lastTime = 0;
int delayMs = 2000; //we want to do something every 2 seconds

void userLoop()
{
  if (millis()-lastTime > delayMs)
  {
    lastTime = millis();
    //do something you want to do every 2 seconds
  }
}

Internal Segments API

You can use Segments from your code to set different parts of the strip to different colors or effects.
This can be very useful for highly customized installations, clocks, ...

To set a segment, use strip.setSegment(id, start, stop);, where id is the segment ID, start is the first LED of the segment and stop is the LED after the last one in the segment.

To edit the configuration of a segment, use:

WS2812FX::Segment& seg = strip.getSegment(id);
//set color (i=0 is primary, i=1 secondary i=2 tertiary)
seg.colors[i] = ((myWhite << 24) | ((myRed&0xFF) << 16) | ((myGreen&0xFF) << 8) | ((myBlue&0xFF)));
//set effect config
seg.mode = myFxI;
seg.speed = mySpeed;
seg.intensity = myIntensity;
seg.palette = myPaletteId;

Keep in mind that this will not cause interface updates as of 0.8.6. For that, you still need to use 'colorUpdated(1)'

Create custom effects

It is possible to create your own effects and add them to the FX library. The relevant files for that are FX.cpp and FX.h.

Here is a step-by-step guide on how to make your effect:

  1. Take a look at some of the effects in FX.cpp to see how they are implemented!

  2. TBD

If you programmed a nice effect you want to share, submit a pull request!

Clone this wiki locally