As a lighting technician, I often find myself having to run cables across walkways, to moving props or simply to places that are awkward to run a wire. Wouldn't it be nice to have a wireless solution? While there are many commercial units available using various protocols, they are either expensive or unreliable.

My Solution for Wireless DMX

When I first saw the cheap ESP8266 modules a year ago, I decided that I'd try to build a cheap DIY Artnet to DMX node. This Instructable will walk you through building your own.

New: v1.2.0 Available

If you have already followed this Instructable, head to step 10 for details of the latest stable version: v1.2.0. Note that this Instructable assumes you are using v1.0.5 as it was the current version at time of writing.

v2.0.0 beta Available

If you are looking for the latest and greatest firmware, head to step 11 for details on v2.0.0 which is currently in development. Code is available on my Github and I've written a new Instructable here explaining how to set the device to output to ws2812 pixels using Jinx


The ESP8266 is a super cheap but powerful WiFi chip designed to bring IOT to hobbyists. It has a fast processor, more RAM and flash memory than most Arduinos and a (small) selection of GPIOs that support a few different protocols. It is available in a variety of formats and I prefer the ESP8266 07 model as it has an external antenna. The ESP8266 is also compatible with the Arduino IDE: https://github.com/esp8266/Arduino and I use this as it's very familiar and thus easy.

Artnet and DMX

Artnet is a protocol that allows DMX to be sent over a standard IP network. This protocol is supported by pretty much every modern lighting console or software (paid and free). Read more here.

DMX is the industry standard protocol for controlling professional show and DJ lighting - it is based on the RS485 protocol. Each DMX universe can have up to 512 channels and each channel has a value from 0 - 255. Read more here.


Pro lighting (moving props, trade shows, across walkways....), DJ Lighting, christmas lighting.... Pretty much anywhere that you wish to minimize wiring, this unit will come in handy.

Step 1: ​Parts Required

ESP8266 - I used the 07 model but they're all pretty similar

PSU - I used a small USB power brick

Resistors - 2x 1K, 3x 390, 1x 750

Caps - I used 4x 100nF even though the schematic has 5. C1 isn't needed.

3.3V Reg - Can't remember what I used here - any 3.3V regulator will do. The ESP8266 needs 3.3V but doesn't use a huge amount of it.

Max485 - These chips produce the DMX output (they can also do input). We need 2 - one for each universe. They are 5V chips but seem to take the ESPs 3.3V logic without any issues. There is a 3.3V version available but I had these on hand and it works...

XLR sockets - I used 3 pin but the standard states 5 pin. You could use a single 5 pin for both outputs as Avolites loves to do. I use 3 pin as I have mainly cheap chinese lights with 3 pin, they are stocked more readily and they are a bit sturdier.

LEDs - I have 2 small blue LEDs, one for each DMX universe to show activity. They are optional but recommended.

Power Lead - I used an IEC inlet. They're readily available and allow the lead to be disconnected for easier storage.

Perf board, hookup wire, headers, project box, screws, glue.

Step 2: Schematic and Construction

I started with a bread board. If you plan to make modifications to my schematic, I'd recommend you do the same. I haven't included a photo as I forgot to take one and my breadboards are in use for a new project I'm working on. Check out my ESP8266 Breadboard Instructable for details on making the ESP8266 breadboard friendly and then hook up your components according to the schematic.

On your perf board, layout your components in a way that makes sense for the required wiring and that will fit in your case. I wanted the final unit to be as small as possible - this meant I did this step in conjunction with the case layout (next step) in order to make sure it all fits.

In the image, you can see 3x 4pin headers. The 2 at the top are DMX outputs and the 1 at the bottom is power and LED connections. The 2pin black header in the middle is the RX/TX for programming the ESP8266. Note that the RX pin has a voltage divider (R5 & R6). This is because I use a 5V programmer (my Arduino Mega) and so I need to drop it to 3.3V so the ESP isn't fried. These resistors can be deleted if you have a 3.3V programmer.

I neglected to include reset or program buttons to save space and I didn't have any on hand. For reset, I simply cycle the power. To enable programming, I put a small loop of wire on the reset pin. I connect an alligator clip to the wire loop and then ground it to the DMX header's GND pin. Although this is a pain, I included OTA updates in software so it's only for the first flashing.

I have also chosen not to isolate the DMX lines because I was feeling lazy :) I also wanted to save on board space and keep the cost down (DC-DC converters are expensive). I would recommend optical and electronic isolation. I did this in my DMX LED strips Instructable and the same process would work here - just reverse the optoisolators as we're outputting here as opposed to input. You will need a DC-DC and an opto on each DMX output.

Step 3: Case Construction

I designed the case in conjunction with the circuit board in the previous step to ensure everything fit but used the minimum space.

I wanted all connectors on one side as it looks nicer and makes cable management easier. Because of this, the connectors were the very first thing I did. I drilled holes for the 2x XLRs, 2x LEDs and the antenna. I used a knife to cut the IEC hole. I stupidly used a female IEC connector when cutting the hole. It has a larger size than the male - hence all the hot glue around the IEC.

Once the holes are cut, I cut the pins shorter on the USB PSU to make it fit in the case. I drilled holes in the plug pins and attached wires - brown is live and blue is neutral (NZ/Australian standards).

Wire connectors to the XLRs (the blue cables).

Wire LEDs and power to a 4pin connector. This is all the black cables in the photos. I used an old USB cable for power. You can find schematics on Google but I used a multimeter to check the 5V and GND wires. Check the LED polarity - the cathode (short pin) connects to GND and the anode (long pin) connects to pin 2 or 3 of our connector. Some heat shrink will make everything look pretty and stop shorts.

Screw in the XLRs, clip/glue in the IEC, screw in your antenna, and hot glue the LEDs into their holes.

Slide the circuit board into place. I drilled a single hole through the case and the board for an M4 screw and nut. You could glue it if you prefer. This ensures it wont move around.

Finally insert the USB connector into the PSU. I put some hot glue on it to ensure it stays in place. Plug in your 3 headers and antenna.

Now it's time to flash our firmware....

Step 4: Flash Firmware

Connect Programmer

Connect your USB -> Serial adaptor. I use my Arduino Mega... on the Mega, simply short Reset to GND and connect megaTX -> espTX, megaRX -> espRX, megaGND -> espGND. Ensure you have a 3.3V serial - if it's 5V (as with the Mega) then use a voltage divider as shown on the schematic wiring page.

Hold the flashing pin 0 to GND - I use alligator clips as explained on the construction page.

Connect power (or press reset). Your device should now be in flash mode.

Get Files Needed

I use the Arduino IDE with the Arduino core for ESP8266 for coding and flashing the firmware. Install everything according to the instructions on their git.

Download my espDMX library to your Arduino IDE library folder. I wrote this library to output 2 universes of DMX using interrupts to ensure precise timing. The DMX output has a refresh rate of approximately 44Hz - the maximum you can get with a full 512 channels. When looking at the output with an oscilloscope, it is picture perfect on both outputs. I used the timings from Ujjal's DMX512 Pages. The library is heavily based on the hardware serial library from the core files linked above. The hardware serial library was a bit bloated for this purpose and didn't utilize hardware interrupts - hence why I modified it to suit. In the future, I may enable receiving DMX but I doubt it - I see no use case for this.

Download my esp8266_artnetnode_dmx code to your projects folder. You can use the bin file provided and flash OTA for the latest updates. OTA updates means no compiling of code is required. More on OTA later.

This Instructable is based on version v1.0.5 but I'd recommend using the current latest release. See the last step more info.

Flash Firmware

Open ESP8266_ArtNetNode_DMX.ino in the Arduino IDE.

In the Tools menu, choose Generic ESP8266 Module.

Set the settings according to the image above. Note that the flash size needs to be set according to the size of your chip. Use the CheckFlashConfig example (under File > Examples > ESP8266 in Arduino IDE) to check your chip size. The first number is the total flash chip size. The SPIFFS number is how much to assign to the file system - we don't use the file system so it doesn't matter what this number is. If your flash size is smaller than 1M then I'd recommend making the SPIFFS smaller to allow more space for our program.

Select your USB -> Serial programmer under Port.

Click the upload arrow. If the library and core files are correctly installed, it should compile and flash without too much fuss.


Most of the settings are done via the web browser. I'll go over this in the next step.

The LED pins are set in firmware. They default to pins 12 & 13 but you can change them if you want.


There are 2 define statements commented out at the top of ESP8266_ArtNetNode_DMX.ino

Uncomment #define VERBOSE to have the device spit out information about what is happening at any given time via serial0 (the serial port you have already connected via USB -> serial above). This will disable one of your DMX outputs and display wifi passwords in plain text so make sure it's disabled before deployment!

Uncomment #define LOAD_DEFAULTS to clear any settings and reload factory defaults. Make sure you comment this line out and reflash or you cant change any settings - each time the device starts, it'll clear them all.

Step 5: Settings

Connect to WiFi Hotspot

When you first start the device, It will attempt to connect to the WiFi network defaultSSID (which I doubt exists). If it can't connect within 30 seconds, it will start a hotspot. The hotspot is nodeName_XXXX (nodeName by default is artNetNode and XXXX is a random number). Connect to this hotspot using the password artNodeXXXX (XXXX is the number from the hotspot SSID).

Settings Web Page

Point your browser of choice to the settings page. If you connect via the hotspot, the address of the web page will be (or on older versions) but if the ESP has connected to your WiFi then use it's IP address (look at your router if it's DHCP assigned or use a static address you've assigned).

At the top of this page, you will see the MAC address. Use this to allow your device on a MAC filtered network (this is highly recommended).

Next is the Node Name. Change this to anything (less than 30 characters) to make the device easy to identify in your lighting software. It will also change the WiFi hotspot name - password stays the same however.

Next is your WiFi settings. Enter the SSID and password of your show network.

Hotspot timeout is the delay before the hotspot is started (when the WiFi network wont connect). The hotspot only starts when the device is power cycled, not if the WiFi connection drops after being connected.

Now for the Artnet settings. Subnet is your Artnet subnet, not to be confused with your network subnet. Set the required universe addresses - these can be the same if you want both outputs to be the same.

IP Settings allows you to see the current IP settings (DHCP by default). You can set static addresses if you wish. Artnet networks should run in the or ranges but will work on others.

Certain settings can be saved and will take immediate effect such as changing the Artnet settings. Other settings need a reset (IP and nodeName). Use the buttons provided to do this.

Firmware Update

The last item on this page is the firmware info and update box. This allows you to easily see which firmware version the unit is running and upload a new version via WiFi. Uploading new firmware will terminate all DMX output and stop responding to artnet until complete. Occasionally it fails so check the expected firmware version is displayed after an OTA update.

In order to produce the OTA binary, select Export compiled Binary from the Sketch menu of the Arduino IDE. This will create a .bin file in your project directory.

OTA Fails

If you find the OTA constantly fails, the WiFi wont connect or the hotspot wont start, check the Flash Size setting in the Tools menu. If this doesn't match your chips flash size, it causes weird issues. Use the CheckFlashConfig example (under File > Examples > ESP8266 in Arduino IDE) to check you are using the correct settings.

Step 6: Let There Be Light!

By now, your device should be connected to your show WiFi network and you should be able to connect to the settings page. Now to setup the lighting console/software...

First, ensure your console is connected to the network with an IP in the same subnet range as your artnet devices. This should be the or ranges.

All lighting software is different in the specifics of how these settings are implemented but all follow the same basic principles... Set a certain universe of data to be output to a certain artnet port (set by the subnet and universe). This data can be multicast (sent to every device on the network) or unicast (sent to a specific device). I recommend using unicast as it has less network overheads so should perform better. Our espArtnetNode will receive either provided the subnet and universe settings match. It responds to ArtPoll requests so it should show up correctly in your lighting software of choice.

Jands Vista Setup

I use Jands Vista as my console of choice so I'll show screenshots of the process and explain where the settings are. You can download and try Vista for free (Mac and PC) - but it will do random blackouts if you don't purchase a channel dongle.

I'm assuming you have some lights patched already - I'm not going to cover this as Jands has a bunch of great tutorials on this and other basics available on their YouTube channel.

On the Vista, goto your Patch view and select Connect Universes in the top right of the screen. There will be a list of available outputs for any consoles or wings that are detected.

Your espArtnetNode should also be listed with 2 available ports. Assign which universe of data you want to send to each of the ports. This will setup a unicast artnet connection. As soon as this is done, the activity LEDs on your espArtnetNode should start flashing to indicate that DMX is being output.

You could also select Add Network Connection on the bottom left of the Connect Universe dialog. This will allow you to add an artnet broadcast port. Use the subnet and universe setting from your device. Now assign the data universe to the broadcast port. This will establish an artnet broadcast. Any devices on the network can be set to receive this subnet and universe of artnet data.

Plug It In

I'm pretty sure you've already figured this out.... Plug the DMX outputs into your light(s) of choice and take it for a spin. I'd highly recommend these awesome RGB LED strip controllers that I designed a couple of years ago. #shamelessPlug

Step 7: LED Status

This is an overview of what the 2 status LEDs do.

On power up, both LEDs will light to indicate the device has started. They will stay fully lit while the node attempts to connect the WiFi.

Once the hotspot timeout is reached (30 second default), the LEDs will alternate about twice per second. This will continue until a client connects to the hotspot. If a client connects, they both turn off. If no client connects within a minute, the device resets and it all starts again.

Once a WiFi network has been connected to, both LEDs will turn off until artnet data arrives.

When data starts arriving, the device buffers it. Once the first artnet packet is received, the device will start outputting DMX and the LED will flicker to indicate activity. A healthy artnet stream will have a constant flicker. Each output is handled separately.

A slow flash (about once per second) indicates that no new data is being received. This could indicate that the network has dropped, the console has stopped sending data, or simply that there isn't any new data. The device will output at least one full DMX universe each second to ensure devices remain stable and any new devices connected to the DMX chain will get the data needed.

Step 8: Troubleshooting

I have run into very few issues. If you find any, please let me know.

WiFi Wont Connect

The ESP8266 is 2.4Ghz B,G,N capable. I found it didn't like one network I tried it on but as that was so long ago, I can't remember specifics.

Triple check SSID and password. I plan to add a plain view switch for password entry to a future release.

Check your MAC is on the allowed list for your network.

Ensure the flash size is correct in Arduino IDE when compiling/flashing the firmware. See the flash firmware step for more details and the fix.

Hotspot Not Starting

Check your hotspot timeout setting (30 seconds by default). If it's really high, your hotspot could take hours to start.

Check the device isn't connecting to a WiFi network. If the WiFi set on the settings page is available, it will connect to this before starting the hotspot.

Ensure the flash size is correct in Arduino IDE when compiling/flashing the firmware. See the flash firmware step for more details and the fix.

OTA Not Working

Ensure the flash size is correct in Arduino IDE when compiling/flashing the firmware. See the flash firmware step for more details and the fix.

No DMX Output

DMX is only output when connected to WiFi and valid artnet packets are received. Once this happens, it will output at least 1 full DMX universe each second of the last received data.

Check your lighting console and artnet node have matching artnet settings. Also check the network settings to ensure they can talk to each other. Also check that you have a licence for the software that allows it to output data. Jands Vista will do random blackouts if you don't purchase enough channels.

If the LEDs show activity but there's no DMX output, check your Max485 chips have power and are wired correctly. Also check that the LED and DMX output match (i.e LED_A represents DMX_A, not DMX_B). It's easy to poke the LEDs into the wrong hole.

Step 9: Ideas for the Future

Web Settings

DONE - I plan to add a plain view switch for password entry to a future release.

I am also looking into using AJAX and JSON to save settings rather than submitting the entire page.

Stand Alone

DONE - I plan to add a stand alone mode where Artnet can be received by the device's hotspot. At present, setting the correct IP subnet is proving to be a challenge.

LCD Menu

I am currently developing an LCD menu for this device. It will consist of a small 128x64 LCD and either 2 or 3 buttons. The menu will allow local setting changes and display critical info locally, without the use of a laptop or phone.

The main issue I am having at present is debouncing the buttons. It is very difficult to do this in code as I want to maintain the precise DMX timing I currently have - receiving artnet packets and DMX output is the priority. When I get a bit more time, I will be looking into hardware debouncing. I am thinking of using a small AVR running a loop with software debouncing and then sending button states to the ESP - this is simple and I have heaps of small AVRs on hand. I could also use the AVR to run the LCD, taking the load off the ESP.

Store Scenes

With the large amount of flash storage available, I was thinking that storing scenes on the ESP would be a great idea. This would allow simple scenes or chases to be run without a lighting console being present. This would tie in with the LCD menu, allowing selection of scenes from the menu or web interface.

One DMX universe is 512 bytes so 2 universes would take 1K. I guess I could store 500+ scenes on the 1M flash available to me and more with the 4M versions of the ESP8266. This would allow some cool chases to be recorded.

DMX is 44Hz so 44K space would be needed per second. This would mean you could fit a chase about 11.5s long. You could also record every second or third packet to allow for longer chases.

Captive Portal

I plan to add captive portal code to the hotspot shortly. This will mean that you don't need to enter an IP address - you'll be automatically sent to the settings page when the hotspot starts. Obviously this wouldn't work when connected to a WiFi network as the ESP8266 wouldn't be the DHCP server.

Step 10: V1.1.x & V1.2.0 Update

Please note that I haven't fully tested this code and it may be buggy. Please give me feedback on your experience with the code and any suggestions.

How to Update

This version uses a slightly modified version of lwIP. If you wish to modify/compile/upload this using the Arduino IDE, see the details at the bottom of this page.

The easy option is to download v1.1.0.bin from my gitHub, head to your device's web settings page and do a firmware update from v1.0.5

New Features for v1.1.1

I finally found a bit of time to implement some of my ideas from the previous step. In addition to these changes, I have made a few tweaks behind the scenes. Check out my gitHub for details.

New Features for v1.2.0

After much fiddling around, I've finally managed to implement storing and recalling DMX scenes. This is achieved by saving all Artnet data into files using the SPIFFS system and is accessed via the web GUI.

Simply set a static look via your lighting console, goto the Stored Scenes page on the web GUI, type a name for the scene and click Save. You can then recall the scene, overwrite it with new values or delete it. This page will also show you the source of the DMX output, either Artnet or one of your scenes.

Depending on the channel count, you should be able to store about 200 scenes on a 1M ESP8266 with 256K SPIFFS partition. The web GUI will show you how much space is used.

Packet forwarding in hotspot mode allows you to set up once device in hotspot mode and have other nodes connect to it. This allows you to use multiple nodes without a separate WiFi AP/router.

Stand alone mode is toggled on using a check box on the web UI. It will only run a hot spot, allowing you to instantly connect to the device without waiting for it to attempt a WiFi connection. In this mode, you can send artnet directly to the device without the need for a wifi AP.

Updated web GUI adds the option for the stand alone mode. It also has a toggle to view the wifi password to make entering a new password less error prone. The help info is now hidden by default and can be toggled using question mark images.

Better IP settings in hotspot which are more in line with the artnet specs. By default, the device now has the IP of when in hotspot or stand alone mode. You can also change the IPs to static when in stand alone mode.

Compile & Upload in Arduino IDE

Before you open your IDE, we need to modify one file. Goto the folder that your ESP core files are installed in and find these files:


On my Mac, they're in ~/Library/Arduino15/packages/esp8266/hardware/esp8266/2.3.0-rc2/

Modify it according to this Pull Request and this Pull Request. Hopefully my commit will be merged into the lwIP master shortly and released in the next core files release.

Now open your Arduino IDE. In the Tools menu, select the board as Core Development Module. Set all your settings for flash size and speeds as we did in step 4. Make sure you select lwIP Variant: "Open Source (gcc)". This option will compile lwIP from source (which we modified above).

You should now be able to flash everything as normal.

I look forward to hearing feedback and suggestions on this new build.

Step 11: ArtNetNode V2

I have been hard at work on the newest version of this project. Check it out on my Github and the new Instructable here detailing how to setup ws2812 pixel mapping using Jinx.

What's New?

New libraries:

The new firmware has been re-done from the ground up. I wrote an all new ArtNet library which incorporates almost all of the ArtNet v4 features including address & port changes. The new library also allows for easy addition of an infinite number of ports - subject to memory usage.

In addition to the ArtNet library, I also re-wrote the espDMX library to add RDM support for both outputs of the ESP8266. This was very tricky due to the fact that the esp8266 only has one RX pin. This library automatically keeps track of the devices connected and notifies ArtNet clients of any changes (via the ArtNet library).

ArtNet v4

I've tried to fully comply to the ArtNet v4 spec where ever possible. This includes merging data in HTP or LTP from up to 2 IPs per universe and also obeying Merge Cancel requests. Status messages are also sent with artPollReply messages so that controllers can get some feedback and see the current state of the outputs.

sACN Support

I've had a lot of requests for sACN support. It is now available in beta5d.


I've now added DMX input support. You can only have one input but the second port can be either DMX out or WS2812 control. RDM wont work on the second port when using DMX in as there is only the 1 RX port on the ESP8266.

RDM Support:

RDM builds on top of DMX and works along side it using the same equipment. It stands for Remote Device Management and allows you to monitor & change device settings without having to physically interact with the device. This is great on large rigs or when a fixture is in an awkward spot as you can change the address or check a sensor remotely.


WS2812(b) Support:

Addressable LEDs are great with many uses. With the latest firmware, you can control up to 1360 pixels (680 per output) using the same base hardware. The outputs are "hot swappable" meaning you can instantly change from DMX/RDM to WS2812 and you can even have one output of each if you desire.

Pixel FX:

I've made a basic FX engine, allowing you to control up to 1360 pixels using only 12 DMX channels.

Better & Faster Web UI:

The Web UI is now much richer for a better experience with style sheets designed for easier use on mobile, tablet and desktop screens. It also utilizes AJAX with JSON for all requests. This makes it a lot faster with less network & hardware resources used.

Coming Soon

Stored Scenes:

This is quite popular in my v1.2.0 firmware and will be coming to v2 shortly. It will be much improved allowing for chases, storing of Pixel FX and selection using the hardware button.

Support for non-WS2812 Pixels:

This may or may not happen. WS2812(b) is the most common tape. If you'd like this feature, consider making a donation and sending me a message so I can buy some for testing.

Latest Updates

The source code of my new firmware is now up for anyone wanting to try it. It will work with the hardware in this Instructable or you can make a few minor modifications to add RDM support. Schematics are on my Github.

Be sure that you read the readme as you need to ensure you flash the correct bin.

Working through this and I can communicate to the ESP through Arduino IDE just fine. <br>Now I'm to the main code and am getting an error while compiling ... wifiStart not declared in the scope. But the ESP8266wifi.h library checks out just fine.<br>Thoughts?
I have also tried downloading the ESP Arduino libraries locally vs using the boards manager. IDE recognized what I did and used them, but still no joy.<br>WifiStart<br>WebStart<br>ArtStart<br>Portsetup<br><br>All not declared in the setup.
It seems that the other ino's haven't been properly included. They should appear as tabs across the top of the Arduino IDE when opened.<br><br>Check here for the fix: https://github.com/mtongnz/ESP8266_ArtNetNode_v2/issues/58
It works! Thank you!<br>
Not sure this matters... But line 138 looks like a bunch of text on top of each other. I've tried to copy and paste it out of the git website... But the IDE does not look nice like the GIT web page does.
It was suggested on the Esp8266 forum page that the start functions.ino file needs to be included.... But how? <br>Turn it into a library and call it out?
Seems this problem also extends to the previous version.
Ok. I was able to compile and load the code by copy n pasting the other .ino files into the main code. <br>I was also able to log in... Only after reading your new ws2812 write up and seeing that the password is no longer artNodexxxx (said number).<br><br>Ok so I believe I have a hot spot and a node connecting to the hot spot successfully.<br>I've gone through all the settings and I had assumed I could hard wire in DMX to the RX port of the hot spot, but in the setup it mentions ports being disabled in hot spot mode.<br>Are these intended to be receivers only?<br>I'm running Freestyler on my laptop, so do I need to run a wifi hub there?<br><br>Thanks
Please help....<br>I'm running Freestyler DMX and am using an N150 Netgear router. <br>I believe I have the settings correct, but I would very much like help setting this up.<br>I have a scope on the output and when I activate Freestyler the blue light on the ESP8266 comes on and there is data out, but it is not in DMX form. <br>Please send me a pm so that we may connect through Facebook messenger or something.
<p>See my reply above - it may help.</p><p>I've also responded to your post on esp8266.com - we can talk there to resolve this so this page doesn't get too many comments until we can fix this :)</p>
<p>The hotspot is intended only for changing settings. As such, all output is disabled. If you wish to use the device in hotspot mode (ie. without a wifi AP) then you need to activate the &quot;Stand Alone Mode&quot; which is in the WiFi Settings page</p>
<p>I've written a new Instructable detailing the v2 firmware controlling ws2812 led strips using Jinx. Check it out here: https://www.instructables.com/id/Artnet-LED-Pixels-With-ESP8266/</p>
I'm having a few issues getting the V2 version to connect to the wifi. Can you check out the video at https://youtu.be/NHo0Y3wpVdc to see what I'm doing wrong?<br><br>
<p>So I got it to connect, but what settings do I use in Jinx?</p>
<p>Check out my new Instructable here: https://www.instructables.com/id/Artnet-LED-Pixels-With-ESP8266/</p>
<p>In Jinx, you'll need to set the IP that data is sent to - looks like in your case. Then setup ports to match your ESP settings for net, subnet and uni. Then in Jinx, go in and patch the LEDs using the layout that the LEDs are physically in - this bit is a bit fiddly and Jinx doesn't make it very easy.</p><p>Now select the start output option in Jinx and it should all work.</p>
<p>Hi and thanks for a beautifully clever yet inexpensive project!</p><p>I'm considering assembling 12 similar circuits based on either the Huzzah ESP8266 or ESP32 for an upcoming live performance. Each receiver would drive 256 LEDs for a total a 3,072 simultaneous channels spanning 12 universes. Judging from my preliminary tests each universe uses approximately 200kbps regardless of the number of channels used in it so I believe my final setup would require 2.4mbps.</p><p>A few questions:</p><p>- Do you think it is realistic to expect reliable performance with 12 receivers on a dedicated wireless network in a an urban area?</p><p>- I've noted occasional hiccups when playing around in the web interface while ArtNet is being transmitted. Would deactivating the second unused port on each ESP accomplish anything?</p><p>- Have you progressed in porting over to the ESP32?</p><p>- I'm considering implementing an additional DMX record/playback feature to your existing work. Similar to your planned &quot;scene&quot; feature but dynamic instead of static. This would require only one or two trigger channels per device to start/stop the playback. I believe in this way a single broadcast universe could control many devices without hogging any additional bandwidth. There are obvious memory and sync+timing issues to address first though.</p><p>Again, many thanks!</p>
<p>I have been looking over the code and would like to incorporate a DMX activated relay. <br><br>Could you please point me in the right direction? <br>GPI04 is still open... maybe there is a way to incorporate a FET on that output?<br><br>My end goal is to mod my smoke machines and make them wireless. So that I may control them with the rest of my DMX equipment. </p>
<p>Hi mate, is there any way in the software to set up a 17 x 17 WS2812b matrix?</p>
<p>For example http://www.live-leds.de/ http://www.madrix.com/ http://www.solderlab.de/index.php/software/glediator</p>
<p>Hi Diana, thanks for your reply. I was initially more interested in the inbuilt effects engine, but since you brought it up, is Glediator fine over WiFi and if so, how many universes? I know Madrix will do what I eventually want to do but it's crazy expensive for the 20 odd universes I need.</p>
<p>It's not an option in my pixelFX. It could probably be added.</p><p>I use Jinx to control my 500ish LEDs - it's a bit basic but it's free and great for testing. It seems to work fine over WiFi.</p>
<p>Wonderful project! Works with all software that supports ARTNet. Checked on Android 2.2! (:, WindowsPhone (Lumia 920), MacOS 10.9, Windows 8 x64. We are looking forward to implementing the hardware button and saving it for offline work.Video work with the connected LED tape WS2812b.</p><p>https://youtu.be/hRhs1Qvl8Rs</p>
<p>Looks good! I'm glad that it's all working for you. Unfortunately I'm pretty short on time at the moment so the hardware button and scene storage might take a while to implement :(</p><p>I've released the source code so hopefully someone can help out with the last few bits that need finishing</p>
<p>This may go along with the previous question... Why the additional resistor network on the DMX out of the MAX485 chip?<br> It wasn't on your version one schematic. I have also made a USB to DMX converter with the MAX485 chip and have not had to use pull up resistors. <br>Were you getting a lot of DMX line noise?</p>
<p>This is needed on receivers more than on transmitters. With RDM, we act as a receiver also so need the resistors. My design is based on one by Matt Hertel and he explains it here: <a href="http://www.mathertel.de/Arduino/DMXShield.aspx" rel="nofollow">http://www.mathertel.de/Arduino/DMXShield.aspx</a></p><p>While it'll probably work without it, I find it's best to follow standards as much as possible :)</p>
Perfect! Thank you!
<p>Hi MTONGNZ</p><p>I have flashed my ESP01 with &quot;espArtnetNode_2.0.0_b5d_ESP01&quot; firmware and it is running fine. but i am having trouble understanding where to connect the max485 chip pins for the DMX Output. The unit will only be used as a output for 1 universe.</p><p>Regards </p><p>Claude</p>
<p>Here's the schematic: <a href="https://github.com/mtongnz/ESP8266_ArtNetNode_v2/blob/master/schematics/node_dmx_and_pix_v2.png" rel="nofollow">https://github.com/mtongnz/ESP8266_ArtNetNode_v2/b...</a></p><p>If you only need one port, just don't connect the other.</p>
<p>V2 source code is now on my Github. Check it out</p>
<p>Hello, and thanks for this instructable! This project has been many firsts for me...basic electronics, soldering, perfboards, etc. I've been learning a lot and really enjoying it! I've been working with my first build (ESP32 with v1.2.0) in my club and it works pretty well except for intermittent resets. At any given moment all of my fixtures will act like I just disconnected the DMX cable then after a few seconds go back to business as usual. It appears the ESP32 is resetting and I'm not sure why. I have read about a watchdog timer...could this be my problem? Also, I only used 4 caps leaving out C1 so maybe I have a stability issue? Any advice would be greatly appreciated. Thanks!</p>
<p>The code is for the ESP8266, not ESP32 - there are a few minor differences and device specific code that would need to be changed. I'd say that is your issue</p>
<p>My apologies I was incorrect. I have no idea why I said ESP32 in my original post...I actually used an ESP8266-12e. Since my original post I added C1, but I'm still getting random intermittent resets.</p>
<p>according to adafruit (huzzah uses esp12e) the most common reason the board restarts is a non reliable 5V supply(3.3V if you arent using huzzah), when you added C1 it stabalized the source some idk if this is it but maybe something to look into. let me know if you get it working.</p><p>maybe a higher value C1 that holds more charge? will stabalize it better.</p><p><a href="https://learn.adafruit.com/adafruit-huzzah-esp8266-breakout/faq" rel="nofollow">https://learn.adafruit.com/adafruit-huzzah-esp8266...</a></p>
<p>Hello, and thank you very much for this great instructable, I&acute;m going to make this project and was wondering if I could use 2 pix outputs using ESP01 with v2, using TX with output 1 and GPIO02 with output 2, not using LEDS, RDM or DMX IN functions. Using &quot;The node_dmx_and_pix schematic is recommended as it allows for DMX with RDM &amp; also ws2812(b) strips by using the convert_max485_to_pix&quot; will allow what I&acute;m asking for? Thank you again for the support.</p>
<p>Not at present but I plan to do a WS2812 only version of the code that will do this.</p>
<p>Why show me dmxworkshop three times the same node?</p>
<p>I don't know. dmxWorkshop has a few weird issues. It does this to me also but I've used wire shark to see the network traffic and it all seems fine. This is a dmxWorkshop issue as opposed to my issue I believe.</p>
<p>Hi, very nice Project. But compile with arduino don&acute;t work with core development module. (make: *** [build/user_config.h] Error 1). What can i do?</p>
<p>I'm not sure what would cause this as there are so many variables.</p><p>I'd suggest trying to compile and flash a simple blink sketch first to check that your IDE is setup correctly. Also check you're using the latest version of the ESP8266 Core</p>
<p>All other sketches work. Only with your changes in Step 10 <em>(...select the board as Core Development Module. Set all your settings for flash size and speeds as we did in step 4. Make sure you select lwIP Variant: &quot;Open Source (gcc)&quot;.) shows the error.</em></p>
<p>I have build a smaller node with on universe. The Problem is to compile and upload with arduino.(see last post) And if i flash it without arduino the node lose all few minutes the Connection. And i can&acute;t see the node in dmxworkshop.</p><p>If i have a little bit more Money next time i will be donate your Project.</p><p>(sorry for my bad english)</p>
<p>That looks really cool.</p><p>I've answered your query below but I'm not sure how to fix it.</p>
<p>Hi mate, I'm wondering if in the latest version the NodeMCU can act as the RDM device, or does it just pass any RDM data on? The reason i ask is I have about 20 RGB floods that I've put nodeMCU's in and it would be nice for the desk to know to only send each light the channels it needs.</p>
<p>My code only implements the RDM discovery. All other RDM data is simply passed through the device. This could be added but would be a bit of an undertaking.</p>
<p>Hello, and so after a month, I installed everything in a case of aluminum and laid out a printed circuit board. I attach the files, all of a sudden, who wants to repeat. Thank you again for your work. I sent you some money for beer. It's good that I waited for the second version. It has a lot of new and interesting. It's a pity the LEDs do not show the indication of the input data on ports A and B, as it was in the first version, this is not enough. Work with ws2812 tried on several programs, I noticed that sometimes it can slow down the output of data. It would be interesting to look at the source code, which changed in comparison with the first part. Well, except for those nodes where the support WS2812, RDM, and DMX input is enabled naturally. I also create DMX devices, but I do 8-bit AVR.</p>
<p>That looks really good. I'm glad it seems to be working for you. Thanks for the donation - it's much appreciated.</p><p>Unfortunately I've been flat out with a new job for the past 3 weeks so this project has been very slow going. I will be releasing the source in the next couple of days for contributors to give me feedback on so keep an eye on your inbox.</p>
Question/Problem. Somewhat new to the ESP 8266. <br><br>I've tried both 1.2.0 and 2.0.0, with triple checking everything, but the DMX rate seems to be stuck at about 3HZ. Any ideas what this could be? Changing channels, number of channels, type of fixture and using adifferent ESP's has not helped. Thank you.<br>
Problem solved. For anyone else with similar issues, I was connected to a network that has approximately 40 active clients. and my QOS was giving artnet least priority. Hope this helps someone in the future.

About This Instructable



More by mtongnz:Artnet LED Pixels With ESP8266 ESP8266 Artnet to DMX ESP8266 Breadboard 
Add instructable to: