Compare commits

...

5 Commits

Author SHA1 Message Date
c0ec93c184 Add Makefile 2021-04-21 15:34:38 +02:00
5072d09682 Update drift compensation in ino version 2021-04-21 15:34:24 +02:00
72a37df703 Update timezone in wasm version 2021-04-21 15:33:59 +02:00
bf48a7765f Rename x86 version 2021-04-21 15:33:47 +02:00
858ebac086 Move ino file to own directory, minor fixes and updates, fixed scheduling 2021-04-12 22:21:04 +02:00
5 changed files with 91 additions and 15 deletions

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
klock4
!klock4/
html_out/

View File

@ -1,15 +1,20 @@
#include <FastLED.h>
#define DATA_PIN 13
#include <stdint.h>
#include <time.h>
#include <math.h>
#include <FastLED.h>
#define DATA_PIN 13
#define SLEEP_DELAY 100
#include <DeepSleepScheduler.h>
#define ROWS 10
#define COLS 11
typedef struct {uint8_t start; uint16_t len;} word_t;
#define _ALL ((word_t) {.start= 0, .len=110})
#define ES ((word_t) {.start= 0, .len=2})
#define IST ((word_t) {.start= 3, .len=3})
#define FUNF_PRE ((word_t) {.start= 7, .len=4})
@ -21,6 +26,7 @@ typedef struct {uint8_t start; uint16_t len;} word_t;
#define HALB ((word_t) {.start= 44, .len=4})
#define ELF ((word_t) {.start= 49, .len=3})
#define FUNF_UHR ((word_t) {.start= 51, .len=4})
#define EIN ((word_t) {.start= 55, .len=3})
#define EINS ((word_t) {.start= 55, .len=4})
#define ZWEI ((word_t) {.start= 62, .len=4})
#define DREI ((word_t) {.start= 66, .len=4})
@ -33,8 +39,12 @@ typedef struct {uint8_t start; uint16_t len;} word_t;
#define NEUN ((word_t) {.start=102, .len=4})
#define UHR ((word_t) {.start=107, .len=3})
#define ST ((word_t) {.start= 38, .len=2})
#define EL ((word_t) {.start= 49, .len=2})
#define LE ((word_t) {.start= 60, .len=2})
word_t HOURS[] = {
ZWOLF, EINS, ZWEI, DREI, VIER, FUNF_UHR,
ZWOLF, EIN, ZWEI, DREI, VIER, FUNF_UHR,
SECHS, SIEBEN, ACHT, NEUN, ZEHN_UHR, ELF
};
word_t PARTS[] = {
@ -77,6 +87,10 @@ void settime(time_t ts) {
unsigned int daylight_savings = 1;
unsigned int hour = (ts / (60*60) + timezone + daylight_savings) % 12;
Serial.print(hour);
Serial.print(F(":"));
Serial.println(minute);
int before = 0;
if (minute >= 25) {
@ -103,23 +117,64 @@ void settime(time_t ts) {
if (minute/5 == 5)
set(HALB); // '5 before half' requires additional set
// minute 0 -> "EIN Uhr"
// minute N -> "N vor/nach EINS"
if(hour == 1 && minute != 0)
set(EINS);
}
#define UPDATE_INTERVAL_S 5
time_t ts = 0L; // UTC
void clockUpdate() {
settime(ts);
FastLED.show();
ts += UPDATE_INTERVAL_S;
/* drift determined experimentally:
* ~3.5ms/cycle "calculation time"
* 60ms/cycle other drift (wakeup time?)
*/
#define DRIFT_MS 63
#define SCHEDULE_DELAY_MS ((1000 * UPDATE_INTERVAL_S) - DRIFT_MS)
scheduler.scheduleDelayed(clockUpdate, SCHEDULE_DELAY_MS);
}
void setup() {
Serial.begin(57600);
FastLED.addLeds<WS2812,DATA_PIN,GRB>(leds, ROWS*COLS);
FastLED.setBrightness(64);
FastLED.setBrightness(16);
scheduler.schedule(clockUpdate);
}
void loop() {
// TODO: Get actual time from somewhere
time_t ts = 1616970481; // UTC
while (1) {
settime(ts);
/*
set(ST);
set(EL);
set(LE);
FastLED.show();
delay(200);
ts += 5 * 60;
};
Serial.println(F("Please enter unix time stamp:"));
while (Serial.available() == 0);
while (Serial.available() > 0) {
ts = Serial.parseInt();
if (Serial.read() == '\n')
break;
}
*/
ts = 1618651100L;
scheduler.execute();
}

18
Makefile Normal file
View File

@ -0,0 +1,18 @@
CC = clang
LIBS = -lm
x86:
$(CC) $(LIBS) klock4_x86.c -o klock4-x86
uc:
$(CC) $(LIBS) klock4_uc.c -o klock4-uc
wasm:
mkdir -p html_out
emcc klock4_wasm.c -s WASM=1 -o html_out/klock4.html --shell-file html_template/shell_minimal.html
all: x86 uc wasm
clean:
rm -rf klock4-x86 klock4-uc html_out

View File

@ -80,7 +80,9 @@ void settime(time_t ts) {
float fminute = (float) minute + (float) second / 60;
minute = 5 * (unsigned int) roundf(fminute / 5);
unsigned int hour = (ts / (60*60) + 1) % 12;
unsigned int timezone = 1;
unsigned int daylight_savings = 1;
unsigned int hour = (ts / (60*60) + timezone + daylight_savings) % 12;
//printf("%02d:%02d\n", hour, minute);