forked from sowbug/G35Arduino
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathG35String.h
82 lines (68 loc) · 2.88 KB
/
G35String.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
G35: An Arduino library for GE Color Effects G-35 holiday lights.
Copyright © 2011 The G35 Authors. Use, modification, and distribution are
subject to the BSD license as described in the accompanying LICENSE file.
Original version by Paul Martis (http://www.digitalmisery.com). See
README for complete attributions.
*/
#ifndef INCLUDE_G35_STRING_H
#define INCLUDE_G35_STRING_H
#include <G35.h>
// A G35String knows how to talk to a real GE Color Effects light string.
// In particular, it implements the set_color() method of the G35 interface.
//
// These strings need enumerate() to be called before anything else, so that
// each bulb has an individual address. In many cases, your lights will work
// as expected even if you forget to call enumerate(), because most programs
// happen to do the same thing as enumerate() -- namely, they send commands
// to all bulbs starting with bulb #0 and ending with bulb #N-1. If your
// light programs look right but fractured, it's because you forgot to call
// enumerate().
class G35String : public G35 {
public:
// |pin|: the Arduino pin driving this string's data line.
// |light_count|: the number of visible, physical bulbs on the string.
// |physical_light_count|: the number of physical bulbs on the string.
// |bulb_zero|: the index of the first bulb (almost always zero).
// |is_forward|: true if the closest bulb to the plug has the lowest index.
G35String();
G35String(uint8_t pin, uint8_t light_count, uint8_t physical_light_count,
uint8_t bulb_zero, bool is_forward);
G35String(uint8_t pin, uint8_t light_count);
void set_pin(uint8_t pin);
void set_light_count(uint8_t light_count);
void set_physical_light_count(uint8_t physical_light_count);
void set_bulb_zero(uint8_t bulb_zero);
void set_forward(bool forward);
// Implementation of G35 interface.
virtual uint16_t get_light_count() { return light_count_; }
void set_color(uint8_t led, uint8_t intensity, color_t color);
// Initialize lights by giving them each an address.
void enumerate();
void enumerate(bool forward = true, uint8_t intensity = MAX_INTENSITY, color_t color = COLOR_RED, uint8_t light_count = 255);
// Displays known-good patterns. Useful to prevent insanity during hardware
// debugging.
void do_test_patterns();
protected:
virtual uint8_t get_broadcast_bulb() { return BROADCAST_BULB; }
private:
uint8_t pin_;
uint8_t physical_light_count_;
uint8_t bulb_zero_;
bool is_forward_;
enum {
MAX_INTENSITY = 0xcc,
BROADCAST_BULB = 63,
};
// Initialize lights by giving them each an address. enumerate_forward()
// numbers the bulb closest to the controller 0, and enumerate_reverse()
// numbers the farthest bulb 0.
void enumerate_forward();
void enumerate_reverse();
// Low-level one-wire protocol commands
void begin();
void one();
void zero();
void end();
};
#endif // INCLUDE_G35_STRING_H