Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
An Arduino library for GE Color Effects G-35 holiday lights.
C++ Arduino
branch: master

Fetching latest commit…

Cannot retrieve the latest commit at this time

Failed to load latest commit information.
examples New for 2012-2013 season.
images
Creepers.cpp
Creepers.h Halloween.
Cylon.cpp Refactor G35 into pure virtual class.
Cylon.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Eyes.cpp Fix copyright.
Eyes.h Fix copyright.
G35.cpp Refactor G35 into pure virtual class.
G35.h Two shades of orange in SpookySlow.
G35String.cpp A more meaningful test sequence.
G35String.h Added class documentation per spydergt1's request in issue 6.
G35StringGroup.cpp Fix bulb address calculation when there are more than 2 strings in a
G35StringGroup.h Added class documentation per spydergt1's request in issue 6.
HalloweenPrograms.cpp SpookyFlicker.
HalloweenPrograms.h SpookyFlicker.
Inchworm.cpp Refactor G35 into pure virtual class.
Inchworm.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
LICENSE New.
LightProgram.h Added class documentation per spydergt1's request in issue 6.
MEOPrograms.cpp
MEOPrograms.h Add first program from contributor MarkEMarkEMark.
Meteorite.cpp Fix warnings.
Meteorite.h
Orbit.cpp Fixed one uninitialized mem error, and one OOB error.
Orbit.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Orbiter.cpp Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Orbiter.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
PlusPrograms.cpp Fix warnings.
PlusPrograms.h Refactor StockPrograms into .cpp and .h.
ProgramRunner.h Fix switch_program_to()
Pulse.cpp
Pulse.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
PumpkinChase.cpp Add SpookySlow. PumpkinChase a little darker.
PumpkinChase.h Halloween.
README.md
Rainbow.cpp
Rainbow.h Add first program from contributor MarkEMarkEMark.
RedGreenChase.cpp Refactor G35 into pure virtual class.
RedGreenChase.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
SpookyFlicker.cpp SpookyFlicker.
SpookyFlicker.h SpookyFlicker.
SpookySlow.cpp Two shades of orange in SpookySlow.
SpookySlow.h Add SpookySlow. PumpkinChase a little darker.
Stereo.cpp Refactor G35 into pure virtual class.
Stereo.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
StockPrograms.cpp Wrap @80.
StockPrograms.h Fixed one uninitialized mem error, and one OOB error.
Twinkle.cpp Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Twinkle.h Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Worm.cpp Refactor: Split PlusPrograms.h into individual files, with .cpp/.h.
Worm.h
keywords.txt New.

README.md

Introduction

G-35 Lights, Green Read the blog post that started it all.

This library makes it easy to replace the controller in GE Color Effects Christmas lights with an Arduino, and to run much better light programs. If you can program C or Processing, it's pretty easy to make new programs, too!

See a demo. There is also a not-awful professional demo of the original, unmodified hardware.

Features

  • With your Arduino, Teensy, or pile of laundry lint that happens to contain an Atmel AVR ATmega, G35Arduino becomes a splice-in replacement for the stock G35 controller. Contains versions of the same programs that ship with the lights. Your spouse won't know the difference!

  • Also contains custom programs: Inchworm, Orbit, Cylon, Meteorite, just to name a few! Your spouse will know the difference!

  • Easy to add your own programs. If you can make it through the Arduino Blink tutorial, you can probably write your own light program!

  • Synchronizes multiple strings. Have them each run individual instances of the same light program. Have them each run different programs, but with synchronized program changes. Or combine as many strings as you want into a single mondo gigantic virtual string! (Number of physical strings is limited by the number of output pins on your microcontroller, as well as the memory requirements of the running light programs.)

  • Express your individualism! G35Arduino operates completely independently of requests from Twitter, Facebook, SMS, XBee, neighbors, and drive-thru spectators. You bought 'em, you should get to control what they do!

Requirements

  • Arduino 1.0 SDK. This code is not compatible with pre-1.0 Arduino.

  • Any of the following: an Arduino or Arduino-compatible, a Teensy with Teensyduino or else flashed with an Arduino Leonardo bootloader. Also a plain Atmel ATmega of some sort, if you know what you're doing.

  • At least one working strand of GE G-35 Color Effects Christmas lights that you are willing to slice up and solder back together again.

Installation

  1. Find your Arduino IDE's sketches directory.

  2. If there isn't already one, create a libraries directory inside the sketches directory.

  3. Unzip the project archive into libraries. It should end up looking like this: [Your Arduino sketches directory]/libraries/G35Arduino/G35.h (etc.)

  4. Restart your Arduino IDE and you should see G35Arduino among the libraries.

  5. Upload the BasicExample sketch to your Arduino. You should see the pin-13 LED flicker as the sketch tries to send data to your lights.

  6. Chop off the stock controller on your lights, being careful to note the function of the three leads from the first light (from left to right looking at the first light pointing upward, they're V+, DATA, and GND).

  7. Put V+ on the Arduino 5V pin, GND on the GND pin, and DATA on pin 13, and your lights should come back to life!

I've been happily running two strands on my house directly off the Arduino (i.e., not using the stock power transformer) with an old USB power supply rated 5V/1A from a Kodak Zi8. Your mileage may vary.

Contributing

Source-code contributions are welcome. If you think you might contribute improvements back to the project, git clone into libraries/ instead of unzipping, and to avoid going insane, check the "external editor" option in the Arduino IDE and use a text editor directly on the library source.

We try to follow Google's C++ coding standards: 2 spaces, no tabs, 80 columns, and follow the existing naming/capitalization conventions in the code.

Further Reading

Credits

Something went wrong with that request. Please try again.