-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrpm-meter-neopixel.ino
192 lines (172 loc) · 5.7 KB
/
rpm-meter-neopixel.ino
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
#include <Adafruit_NeoPixel.h>
#define PIN 12 //LED Data Pin
#define NUMPIXELS 20 //number of leds connected
#define BRIGHTNESS 10
Adafruit_NeoPixel pixels = Adafruit_NeoPixel(NUMPIXELS, PIN, NEO_GRB + NEO_KHZ800);
//Calculate the frequency of the tacho signal you are using and adjust the following values accordingly
//example: for a standard tacho signal on a 4 cylinder engine the frequeny is equal to the RPM divided by 30
const unsigned int onFrequency = 5; //startup sequence, value represents engine speed higher than cranking and lower than idle
const unsigned int minFrequency = 10; // minimum frequency to begin turning on LEDs
const unsigned int maxFrequency = 20; // maximum frequency in normal range, after this value shift flash will occur
const unsigned int shiftFrequency = 30; // frequency range from max to shift when shifting should happen, after this value overrev flash will occur
//Set the color for each LED in the neo pixel strip
//Colors are set using an RGB value ranging from (0,0,0) to (255,255,255)
const uint32_t tachColor[NUMPIXELS] = {
Adafruit_NeoPixel::Color(0, 120, 0),//green
Adafruit_NeoPixel::Color(0, 120, 0),//green
Adafruit_NeoPixel::Color(60, 60, 0),//orange
Adafruit_NeoPixel::Color(60, 60, 0),//orange
Adafruit_NeoPixel::Color(60, 60, 0),//orange
Adafruit_NeoPixel::Color(120, 0, 0),//red
Adafruit_NeoPixel::Color(120, 0, 0),//red
Adafruit_NeoPixel::Color(0, 0, 120),//blue
};
//Set the frequency when each LED should turn on
//First LED turns on at minFrequency
const unsigned int lightShiftFreq[NUMPIXELS] = {
minFrequency,
11,
12,
13,
14,
15,
16,
20
};
bool hasStartupSequenceRun = false; // only run startup sequence one time
const byte tachPin = 5;
int drive[] = {
11,
12,
13,
14,
15,
16,
17,
18,
19,
15,
13,
12,
11,11,11,
13,15,16,
25,25,25,25,25,25,25,25,25,25,25,25,25,25,25,25,
12,13,14,14,14,14,14,14,14,14,14,
11,11,11,
13,15,16,
11,11,11,
13,15,16,
35,35,35,35,35,35,35,35,35,35,35,25,25,25,25,25,
12,13,14,14,14,14,14,14,14,14,14
};
int arr_size = sizeof(drive) / sizeof(drive[0]);
int count = 0;
bool start = true;
unsigned int igfreq; //be long!
void setup() {
pixels.begin(); // This initializes the NeoPixel library.
pixels.setBrightness(15);
}
void loop() {
float ighigh, iglow;
unsigned long igcal1, igcal2;
//measure period of tach signal
/*ighigh = pulseIn(tachPin, HIGH);
iglow = pulseIn(tachPin, LOW);
igcal1 = 1000 / ((ighigh / 1000) + (iglow / 1000));
//do it again
ighigh = pulseIn(tachPin, HIGH);
iglow = pulseIn(tachPin, LOW);
igcal2 = 1000 / ((ighigh / 1000) + (iglow / 1000));*/
Serial.println("start loop");
if (start == true) {
for (int s = 0; s < arr_size; s++) {
if ((count < arr_size)&&(s != arr_size)) {
igfreq = drive[s];
Serial.println("iter: " + String(s) + " igfreq: " + String(igfreq));
if (hasStartupSequenceRun == false) {
/*
//if (igfreq > onFrequency) {
// Run start sequence
// LEDs will light up, flash and light out upon starting the engine.
for (int i = 0; i < NUMPIXELS; ++i) {
pixels.setPixelColor(i, tachColor[i]);
pixels.show();
delay(50);
}
for (int a = 0; a < 10; a++) {
pixels.fill(pixels.Color(0, 0, 120));
pixels.show();
delay(20);
pixels.fill(pixels.Color(0, 0, 0));
pixels.show();
delay(20);
}
for (int i = 0; i < NUMPIXELS; ++i) {
pixels.setPixelColor(i, tachColor[i]);
pixels.show();
}
for (int i = NUMPIXELS - 1; i >= 0; --i) {
pixels.setPixelColor(i, pixels.Color(0, 0, 0));
pixels.show();
delay(50);
}
hasStartupSequenceRun = true;
pixels.fill(pixels.Color(0, 0, 0));
pixels.show();
}
if (igfreq < onFrequency) {
// Resets hasStartupSequenceRun to false if engine stops but Arduino remains powered,
// Startupsequence will rerun upon restarting the engine
hasStartupSequenceRun = false;
}
*/
if (igfreq < maxFrequency) {
// Normal operating range
for (int i = 0; i < NUMPIXELS; ++i) {
if (igfreq > lightShiftFreq[i]) {
pixels.setPixelColor(i, tachColor[i]);
}
else {
pixels.setPixelColor(i, pixels.Color(0, 0, 0));
}
}
pixels.show();
}
else if (igfreq >= maxFrequency && igfreq < shiftFrequency) {
// Shift flash
// Default color=blue
// To change shift flash color, edit RGB value in following line
pixels.fill(pixels.Color(0, 0, 120));
pixels.show();
delay(20);
pixels.fill(pixels.Color(0, 0, 0));
pixels.show();
delay(20);
}
else if (igfreq >= shiftFrequency) {
// Overrev flash
// Default color=red
// To change overrev flash color, edit RGB value in following line
pixels.fill(pixels.Color(120, 0, 0));
pixels.show();
delay(20);
pixels.fill(pixels.Color(0, 0, 0));
pixels.show();
delay(20);
}
}
delay(100);
}
else {
start = false;
igfreq = 0;
Serial.println("break");
break;
}
count++;
}
}
pixels.fill(pixels.Color(0, 0, 0));
pixels.show();
}