1st working version -- start with blue to reduce the needed power when starting the display.
This commit is contained in:
parent
88e480716a
commit
c3b80e668b
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
static const uint16_t PixelCount = 4*7*3+3;
|
static const uint16_t PixelCount = 4*7*3+3;
|
||||||
|
|
||||||
#define colorSaturation 63
|
#define colorSaturation 31
|
||||||
|
|
||||||
// Seven Segment Layout: 3 LEDs per segment
|
// Seven Segment Layout: 3 LEDs per segment
|
||||||
// order of segments:
|
// order of segments:
|
||||||
|
@ -34,11 +34,11 @@ static const uint8_t digitOffset[] = { 0, LedsPerDigit, 2*LedsPerDigit+Seperator
|
||||||
#define Seg_f 0x20
|
#define Seg_f 0x20
|
||||||
#define Seg_g 0x40
|
#define Seg_g 0x40
|
||||||
|
|
||||||
#define decimalPointLed (2*LedsPerDigit)
|
#define clockSeperatorLed1 (2*LedsPerDigit)
|
||||||
#define clockSeperatorLed1 (2*LedsPerDigit+1)
|
#define clockSeperatorLed2 (2*LedsPerDigit+1)
|
||||||
#define clockSeperatorLed2 (2*LedsPerDigit+2)
|
#define decimalPointLed (2*LedsPerDigit+2)
|
||||||
|
|
||||||
#define firstCharacterMapped 32u /* first char to be mapped is "space" */
|
#define firstCharacterMapped 0x20 /* first char to be mapped is "space" */
|
||||||
#define lastCharacterMapped (sizeof(charMapping) + firstCharacterMapped)
|
#define lastCharacterMapped (sizeof(charMapping) + firstCharacterMapped)
|
||||||
|
|
||||||
static const unsigned char PROGMEM charMapping[] = {
|
static const unsigned char PROGMEM charMapping[] = {
|
||||||
|
@ -54,6 +54,7 @@ static const unsigned char PROGMEM charMapping[] = {
|
||||||
/* ) */ Seg_b + Seg_c + Seg_f + Seg_g,
|
/* ) */ Seg_b + Seg_c + Seg_f + Seg_g,
|
||||||
/* * */ 0,
|
/* * */ 0,
|
||||||
/* + */ 0,
|
/* + */ 0,
|
||||||
|
/* , */ 0,
|
||||||
/* - */ Seg_d,
|
/* - */ Seg_d,
|
||||||
/* . */ 0,
|
/* . */ 0,
|
||||||
/* / */ Seg_e,
|
/* / */ Seg_e,
|
||||||
|
@ -63,7 +64,7 @@ static const unsigned char PROGMEM charMapping[] = {
|
||||||
/* 3 */ Seg_b + Seg_c + Seg_d + Seg_f + Seg_g,
|
/* 3 */ Seg_b + Seg_c + Seg_d + Seg_f + Seg_g,
|
||||||
/* 4 */ Seg_a + Seg_c + Seg_d + Seg_g,
|
/* 4 */ Seg_a + Seg_c + Seg_d + Seg_g,
|
||||||
/* 5 */ Seg_a + Seg_b + Seg_d + Seg_f + Seg_g,
|
/* 5 */ Seg_a + Seg_b + Seg_d + Seg_f + Seg_g,
|
||||||
/* 6 */ Seg_a + Seg_d + Seg_e + Seg_f + Seg_g,
|
/* 6 */ Seg_a + Seg_b + Seg_d + Seg_e + Seg_f + Seg_g,
|
||||||
/* 7 */ Seg_b + Seg_c + Seg_g,
|
/* 7 */ Seg_b + Seg_c + Seg_g,
|
||||||
/* 8 */ Seg_a + Seg_b + Seg_c + Seg_d + Seg_e + Seg_f + Seg_g,
|
/* 8 */ Seg_a + Seg_b + Seg_c + Seg_d + Seg_e + Seg_f + Seg_g,
|
||||||
/* 9 */ Seg_a + Seg_b + Seg_c + Seg_d + Seg_g,
|
/* 9 */ Seg_a + Seg_b + Seg_c + Seg_d + Seg_g,
|
||||||
|
@ -171,6 +172,11 @@ void SevenSegmentClock::displaySeperator(char seperatorCharacter) {
|
||||||
strip->setPixelColor(clockSeperatorLed1, currentColor);
|
strip->setPixelColor(clockSeperatorLed1, currentColor);
|
||||||
strip->setPixelColor(clockSeperatorLed2, currentColor);
|
strip->setPixelColor(clockSeperatorLed2, currentColor);
|
||||||
break;
|
break;
|
||||||
|
case '|':
|
||||||
|
strip->setPixelColor(decimalPointLed, currentColor);
|
||||||
|
strip->setPixelColor(clockSeperatorLed1, currentColor);
|
||||||
|
strip->setPixelColor(clockSeperatorLed2, currentColor);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
Serial.print("SevenSegmentClock::displaySeperator: Unknown character to be displayed: ");
|
Serial.print("SevenSegmentClock::displaySeperator: Unknown character to be displayed: ");
|
||||||
Serial.println(seperatorCharacter);
|
Serial.println(seperatorCharacter);
|
||||||
|
@ -192,6 +198,8 @@ void SevenSegmentClock::displayTime(int hour, int minute) {
|
||||||
displayUpdate();
|
displayUpdate();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
SevenSegmentClock::BlinkMode SevenSegmentClock::blinkMode;
|
||||||
|
|
||||||
void SevenSegmentClock::displayUpdate(void) {
|
void SevenSegmentClock::displayUpdate(void) {
|
||||||
char displayText[4];
|
char displayText[4];
|
||||||
static int lastHour=0, lastMinute=0;
|
static int lastHour=0, lastMinute=0;
|
||||||
|
@ -202,10 +210,10 @@ void SevenSegmentClock::displayUpdate(void) {
|
||||||
if (clockHour != lastHour || clockMinute != lastMinute || millis()-lastUpdate_ms > TIME_BETWEEN_DISPLAY_UPDATES_ms) {
|
if (clockHour != lastHour || clockMinute != lastMinute || millis()-lastUpdate_ms > TIME_BETWEEN_DISPLAY_UPDATES_ms) {
|
||||||
lastHour = clockHour;
|
lastHour = clockHour;
|
||||||
lastMinute = clockMinute;
|
lastMinute = clockMinute;
|
||||||
displayText[0] = (hour > 9) ? '0' + (hour/10) : ' ';
|
displayText[0] = (clockHour > 9) ? '0' + (clockHour/10) : ' ';
|
||||||
displayText[1] = '0' + hour % 10;
|
displayText[1] = '0' + clockHour % 10;
|
||||||
displayText[2] = '0' + minute / 10;
|
displayText[2] = '0' + clockMinute / 10;
|
||||||
displayText[3] = '0' + minute % 10;
|
displayText[3] = '0' + clockMinute % 10;
|
||||||
switch (blinkMode) {
|
switch (blinkMode) {
|
||||||
case NoBlinking:
|
case NoBlinking:
|
||||||
displayDigit(0, displayText[0]);
|
displayDigit(0, displayText[0]);
|
||||||
|
@ -239,7 +247,7 @@ void SevenSegmentClock::displayUpdate(void) {
|
||||||
displayDigit(2, displayText[2]);
|
displayDigit(2, displayText[2]);
|
||||||
displayDigit(3, displayText[3]);
|
displayDigit(3, displayText[3]);
|
||||||
if (currentlyBlinkOn) {
|
if (currentlyBlinkOn) {
|
||||||
displaySeperator(':');
|
displaySeperator('|');
|
||||||
} else {
|
} else {
|
||||||
displaySeperator(' ');
|
displaySeperator(' ');
|
||||||
}
|
}
|
||||||
|
@ -281,20 +289,12 @@ void SevenSegmentClock::begin(void) {
|
||||||
Serial.print("Pixels="); Serial.println(PixelCount);
|
Serial.print("Pixels="); Serial.println(PixelCount);
|
||||||
SevenSegmentClock::strip = new Adafruit_NeoPixel(PixelCount, LedDataPin, NEO_GRB + NEO_KHZ800);
|
SevenSegmentClock::strip = new Adafruit_NeoPixel(PixelCount, LedDataPin, NEO_GRB + NEO_KHZ800);
|
||||||
strip->begin();
|
strip->begin();
|
||||||
|
strip->clear();
|
||||||
|
strip->show();
|
||||||
SevenSegmentClock::red = strip->Color(colorSaturation, 0, 0);
|
SevenSegmentClock::red = strip->Color(colorSaturation, 0, 0);
|
||||||
SevenSegmentClock::green = strip->Color(0, colorSaturation, 0);
|
SevenSegmentClock::green = strip->Color(0, colorSaturation, 0);
|
||||||
SevenSegmentClock::blue = strip->Color(0, 0, colorSaturation);
|
SevenSegmentClock::blue = strip->Color(0, 0, colorSaturation);
|
||||||
SevenSegmentClock::white = strip->Color(colorSaturation, colorSaturation, colorSaturation);
|
SevenSegmentClock::white = strip->Color(colorSaturation, colorSaturation, colorSaturation);
|
||||||
SevenSegmentClock::black = strip->Color(0, 0, 0);
|
SevenSegmentClock::black = strip->Color(0, 0, 0);
|
||||||
SevenSegmentClock::currentColor = SevenSegmentClock::white;
|
SevenSegmentClock::currentColor = SevenSegmentClock::blue;
|
||||||
// strip->show();
|
|
||||||
// boot animation
|
|
||||||
uint32_t colors[] = { red, green, blue, white };
|
|
||||||
unsigned int colorIndex = 0;
|
|
||||||
for (int i=0; i<PixelCount; ++i) {
|
|
||||||
strip->setPixelColor(i, colors[colorIndex++]);
|
|
||||||
if (colorIndex > sizeof(colors)) colorIndex = 0;
|
|
||||||
}
|
|
||||||
strip->show();
|
|
||||||
delay(2000);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,9 +4,9 @@
|
||||||
#include <Adafruit_NeoPixel.h>
|
#include <Adafruit_NeoPixel.h>
|
||||||
|
|
||||||
// avoid flickering of the display:
|
// avoid flickering of the display:
|
||||||
#define TIME_BETWEEN_DISPLAY_UPDATES_ms 300
|
#define TIME_BETWEEN_DISPLAY_UPDATES_ms 100
|
||||||
#define BLINK_OFF_TIME_ms 600
|
#define BLINK_OFF_TIME_ms 200
|
||||||
#define BLINK_ON_TIME_ms 400
|
#define BLINK_ON_TIME_ms 200
|
||||||
#define defaultLedDataPin 2
|
#define defaultLedDataPin 2
|
||||||
class SevenSegmentClock {
|
class SevenSegmentClock {
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -191,7 +191,7 @@ void loop() {
|
||||||
if (minutes % 5 == 0) hours++;
|
if (minutes % 5 == 0) hours++;
|
||||||
if (hours > 99) hours = 0;
|
if (hours > 99) hours = 0;
|
||||||
sevenSegmentClock.displayTime(hours, minutes);
|
sevenSegmentClock.displayTime(hours, minutes);
|
||||||
if (hours % 4 == 0) sevenSegmentClock.setBlinkMode(SeperatorBlinking); else sevenSegmentClock.setBlinkMode(NoBlinking);
|
if (hours % 4 == 0) sevenSegmentClock.setBlinkMode(SevenSegmentClock::SeperatorBlinking); else sevenSegmentClock.setBlinkMode(SevenSegmentClock::NoBlinking);
|
||||||
}
|
}
|
||||||
sevenSegmentClock.displayUpdate();
|
sevenSegmentClock.displayUpdate();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue