Skip to content

Latest commit

 

History

History
300 lines (214 loc) · 16.1 KB

README.md

File metadata and controls

300 lines (214 loc) · 16.1 KB

artlight

This repository supports similar applications that artfully animate light.

Currently, there is a cornhole, wall clock, nixie tube clock and golden clock application supported by this repository.

Golden clock (LED sunflower): https://youtu.be/tHdfZooGRxo

Nixie tube clock: https://youtu.be/5ZdNDDC60QM

Wall clock: https://youtu.be/0ISKXnE9frU

Parts

Golden Clock Parts

Nixie Tube Clock Parts

Optional off-board ambient light sensor for automatic dimming

Optional on-board motion sensor plugin module for automatic on/off control

Optional base (something is required)

Cornhole and Wall Clock Parts

Cornhole and Wall Clock Common Parts

Wall Clock Specific Parts

Additional parts for the clock application are

Cornhole Specific Parts

Additional parts for the cornhole application are

Construction

The PCB components were soldered on their respective boards. When Huzzah32 is powered by USB cable, the 5V power jumper must first be removed.

Golden Clock Construction

LED PCB design files and TinyPICO IO PCB design files

Solder LEDs and connectors to LED PCB. Solder TinyPICO and connectors to TinyPICO IO PCB. Build wire harness as necessary for mounting.

Nixie Tube Clock Construction

PCB design files

For structural integrity, use a thick (>= 2.0mm) PCB. Order PCB with a solder paste stencil. Use the stencil to distribute solder paste for all components under the nixie tubes and solder them with a hot air gun. Solder all other components individually, as appropriate. Press in pin sockets and solder from the bottom. Mount nixie tubes and place PCB on acrylic pedestals.

WARNING: The nixie tubes run at 170 volts. To reduce exposure, do not plug in until tubes are mounted and PCB is placed on acrylic pedestals.

Wall Clock Construction

PCB design (artlight.*) files with boards for mounting LED strips on rays

The microprocessor board is mounted on the back of the art with its luminosity sensor peeking through a hole drilled in the center. Power is routed and split between the microprocessor and 12 o'clock ray boards. SPI signals used to animate the individually addressable LEDs are cabled from the microprocessor board to the 12 o'clock board.

LED strips are mounted to the back of the wall art. To reduce wiring complexity, the 12 rays are supported by PCBs. 12 o'clock is different so there is a special board for it. Each ray is cut to length, an LED strip is cut to match, mounted with tape and soldered at the ends with LEDs advancing toward the center. The ray boards are then mounted to the back of the art using more of the same tape. Small strips are cut to bridge the arcs between ray bases, taped and soldered in place with LEDs advancing clockwise (from front!). Starting at 12 o'clock, strips are cut and joined together with wire to skirt the perimeter of the art (clockwise, from front). Only clock and data signals need to tunnel under the rays as 5V and GND can be tapped from the LED strip edges of adjacent rays.

Cornhole Construction

PCB design (artlight.cornhole.*) files

The power bank is mounted with strong magnets under the board so that it might easily be unplugged, removed, charged, replaced and plugged back in. Power from it may be switched on and off (with the on/off switch). Switched power is split between the microprocessor board, the ring LED strip and the high side of the RGB LEDs in all the switches.

The R, G and B LEDs in the switches are separtely pulse-width-modulated (PWM) to mix the preferred color of each. PWM switching is controlled indirectly through transistor circuits wired to the low side of the RGB LEDs of each switch. The momentary switch outputs (closed to ground) are wired to the microprocessor board inputs dedicated for them.

Vibration sensors are strategically placed (for best performance) under the board. The vibration sensor part may be changed to affect its sensitivity. Their shared (parallel) output (closed to ground) is wired to the microprocessor board input dedicated for them.

IR break beam sensors are mounted across the cornhole ring for the best coverage (2 orthogonal pairs seems adequate). Their shared (parallel) output (closed to ground) is wired to the microprocessor board input dedicated for them.

The LEDs that come with the cornhole LED ring are replaced with a clockwise (from the top) strip of 80 individually addressable LEDs. Their control lines are wired to the microprocessor board output dedicated for them. The ring is mounted under the board. For best results, the material above the LED ring should be transparent (for example, an acrylic ring) so that the lights under the board can be seen from above.

Use

Applications must be provisioned on a Wi-Fi LAN. Until this is done, they will offer their own Wi-Fi access point where they can be configured securely by a web browser (https://192.168.4.1). The SSID and password for Wi-Fi access must be entered. Optionally, an mDNS hostname may be given.

The reach of your Wi-Fi LAN may need to be increased to reach these devices. This is best done by repositioning the devices and/or Wi-Fi access points. If necessary, deploy a Wi-Fi range extender.

Once provisioned, preferences may be set for each application by pointing a web browser to the device (http://<device>/). If supported, the mDNS hostname may be used to resolve the device address; otherwise, the leased IP address will have to be resolved (perhaps manually) depending on the capabilities of the LAN's DHCP/DNS services.

The preferences page may be filled using "factory" default values or with the current values. Changes to most will take effect immediately. If not, then they will take effect when the form is submitted.

Preferences may be used to customize the presentation. Brightness parameters may be set which may include use of the luminosity sensor. The mDNS hostname of the board may be changed. Parameters may be set in order to accurately present time in the given time zone. Over-the-air software updates may also be performed.

Golden Clock Use

It's "golden" because the LED layout that produces the spirals is based on the golden ratio.

In clock mode, the length, width, curl, shape and color of each hand may be customized. During the first minute of each hour, the minute and second hands are suppressed and the hour hand is etched into a matching randomized swirling pattern.

In swirl mode, the randomized swirling pattern cycles through six different minute-long phases, each aligned to a particular set of spirals.

The number of spirals in each set are Fibonacci numbers (13, 21, 34, 55, 89, 144). The lower the number, the tighter (curlier) the spirals in the set. Of all the Fibonacci numbers, these ones resolve best on a layout with this number of LEDs. By default, the sets with 21, 55 and 144 spirals are used to resolve the hour, minute and second hands because they all curve the same way and most all are sufficient to resolve the units of their measure. Unfortunately, 55 is not quite enough resolution for 60 minutes but it looks better than the spiral set of 89 because that curves the other way. In any case, you can choose what you like.

A high quality power supply is required to power both the microcontroller and the LEDs. It may be necessary to use separate power supplies for these. If so, they must tolerate having their grounds tied together.

Nixie Tube Clock Use

The bottom dot of the colon pulses at 30 beats per minute (a second on and a second off). The top dot of the colon pulses at 31 beats per minute. This results in pulsing dots that are in phase at the beginning of the minute. They separate more as mid-minute is approached and come back together again as the next minute is approached. Thus the colon is a very crude seconds display.

Dimming controls should be slid all the way to the left to disable dimming; otherwise, dimming will start to occur as it gets dark. The further to the right the dimming control is set, the more dimming will be done. When slid all the way to the right, the controlled element will dim to black when the room is black.

In an effort to combat nixie tube cathode poisoning the clock will not display minutes during the first minute of every hour. Instead, the normal minutes-places will cycle through digits that are not normally used there. For hours less than 10, the tens-of-hours place will similarly cycle. The display can also be temporarily put in a Clean mode (or other modes) until expectations are met.

Wall Clock Use

There are no additional preferences for the clock application.

The clock will present time by animating hour, minute and second indicators using the LEDs mounted to the back of the art. Hour and minute indicators will animate up and down the rays and across the inner arcs that connect them. The second indicator will sweep across the perimeter.

Cornhole Use

The cornhole "preferences" page may be used to keep score. In fact, unless explicitly accessed through a URL with a preferences path (http://<device>/preferences), scoring is the only thing allowed.

Changing most preferences (including scoring) will be shared between boards that have been configured to use the same network port number. For this to work effectively, only the two boards used in a cornhole game should share the same port number and each must be reachable from the other on the same network.

A preference may be used to control what the ring LED strip indicates:

  • The score of each team
  • The time
  • Various animations

Regardless of what the ring indicates:

A short press of a momentary switch will increment the score of the associated team. A long press of a momentary switch will decrement the score of the associated team while held. While decrementing, if the other switch is down too then the score is reset to 0 (hold both to reset both to 0).

Vibration from the board will cause a short "lightning strike" animation to be presented over the existing ring indication. A break in the ring's IR beam sensors will cause a short "fireworks" animation to be presented over the existing ring indication.

Software Build, Deploy and Monitor

These projects were built on a Fedora Linux platform. Your mileage may vary elsewhere.

Get artlight source code with its dependencies

git clone http://github.com/rtyle/artlight.git
cd artlight
git submodule update --init --recursive
(cd esp-idf; git apply ../time.c.patch)

Create certificates

Install tools required by esp-idf in esp-idf-tools.

IDF_TOOLS_PATH=esp-idf-tools esp-idf/install.sh

(Re)establish build environment.

. esp-idf-export.sh

Select application (choose one).

application=clock
application=cornhole
application=golden
application=nixie

Build application.

(cd project; ArtlightApplication=$application idf.py fullclean reconfigure build)

Grant user access to USB serial devices then relogin to get access.

sudo usermod -a -G dialout $USER

Identify serial port to connected device. For example,

port=/dev/ttyUSB0

Prepare connected device and deploy application.

(cd project; idf.py -p $port erase_flash erase_otadata)
(cd project; idf.py -p $port flash)

Monitor serial output from device.

(cd project; idf.py -p $port monitor)