Skip to content

Latest commit

 

History

History
204 lines (149 loc) · 9.25 KB

README.md

File metadata and controls

204 lines (149 loc) · 9.25 KB

nato-lights

An extensible plug-and-play Arduino library for controlling multiple Neopixel LED strips

https://fishbotwilleatyou.com/bin/images/showcase_lights.gif

About

nato-lights is an aggressively efficient library designed to help you beautify a space with thoughtful, interactive light shows displayed on long chains of LED strips that you can hang around, say, the walls of your room.

It owes its entire inspiration to Hell Lighting, but was rewritten from scratch so that we could support over 17 meters (55 feet) of lights using only a single Arduino Uno.

Concepts

  • Patterns

    nato-lights maintains from its predecessor the core concept of patterns, which are modular and intuitively-written light show designs. One pattern is active at a time, and you can switch between patterns using the "next pattern" button. During each frame of the execution loop, the active pattern is responsible for updating the global leds variable with the sequence of colors to output to the LED strips.

  • Chains

    The LED strips to controlled can be divided among up to three chains. These chains are connected in parallel to the Arduino, while the strips within each chain are connected in series. This is primarily to address dissipation issues when sending signals down a very long series of LED strips—three chains of 180 LEDs will perform a lot more reliably than a single chain of 540 LEDs.

    Patterns don't need to worry about how the LED strips are organized into chains and need only treat leds as a single long array of colors. The library will automatically direct output to the correcte chains as long as config.h is set up properly.

Installation

Hardware

This project is designed to work with a variety of hardware arrangements, depending on the dimensions of the space to be decorated and the availability of components used.

Out of the box—that is, with only changes to config.h as described in Configuration—it supports one button for toggling between patterns, up to two potentiometers for interactivity in patterns, up to three chains of light strips with as many lights as memory will allow, and as many patterns as memory will allow.

My reference design consists of the following components:

I used one potentiometer even though the library supports two out of the box.

Diagram Front Back

In addition, I 3D-printed a wall-mounted encasement for the complete control box. The SolidWorks assembly and STL files are available in the encasement directory.

Front Side

Software

  1. Install the Arduino IDE.
  2. Open nato-lights.ino in the Arduino IDE.
  3. Install the FastLED library.
  4. Connect your Arduino Uno by USB and ensure that the board is selected.
  5. Click Sketch > Upload to compile and upload the project.

If you're on Linux, you may need to add yourself to the dialout group in order to avoid a permissions error while uploading.

Configuration

Basic Configuration

If your hardware setup is reasonably similar to mine, you'll only need to modify config.h.

  • BUTTON_DEBOUNCE

    Milliseconds within which to ignore button signals.

    You only need to modify this if the "next pattern" button is having trouble detecing single presses.

  • LED_DUPLICATION

    Number of times to repeat each color in each frame of a pattern. For example, if a pattern outputs a frame with colors [A, B, C, D, E, ...], the physical LED strip will display [A, B, C, D, E, ...] with LED_DUPLICATION = 1, [A, A, B, B, C, ...] with LED_DUPLICATION = 2, [A, A, A, B, B, ...] with LED_DUPLICATION = 3, etc.

    Increase this value to visually stretch out the displayed patterns and to decrease memory usage. Decrease this value to make the displayed patterns appear more compact.

  • LED_PIN_1, LED_PIN_2, LED_PIN_3

    The PWM-capable digital pins to which the LED strip chains are connected.

  • LED_COUNT_1, LED_COUNT_2, LED_COUNT_3

    The number of colors to output to each LED strip chain. The physical number of active LEDs in each chain will then be its count multiplied by LED_DUPLICATION.

  • LED_TYPE

    The LED chipset as recognized by FastLED.

  • NEXT_BUTTON_PIN

    The digital pin to which the "next pattern" button is connected.

  • POT_1_MAX, POT_2_MAX

    The maximum output value of the potentiometers.

  • POT_1_PIN, POT_2_PIN

    The analog pins to which the potentiometers are connected.

Adding or Modifying Patterns

Adding a new pattern is easy! Take a look at how the existing patterns are defined in the patterns directory.

  1. Create patterns/pattern_name.h and patterns/pattern_name.cpp extending Pattern. The init and step methods are responsible for initializing the global leds variable and updating it for each subsequent frame, respectively.
  2. Add the line #include "src/patterns/pattern_name.h" to nato-lights.ino.

Removing Patterns

Simply remove the line #include "src/patterns/pattern_name.h" from nato-lights.ino.

Contributing

Feedback and contributions are always welcome! If you have any bug reports, feature requests, or questions, please open a GitHub issue.

To contribute, follow the instructions below to set up local development and submit a GitHub pull request. You will need to have Git installed.

  1. Create a fork of deeptoaster/nato-lights to your own account and clone it.
  2. Follow the installation instructions above to set up and compile the project in the Arduino IDE using your cloned project directory.
  3. After making your changes, commit them, push them to your fork on GitHub, and create a pull request to deeptoaster/nato-lights.