-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclock.ino
100 lines (85 loc) · 2.79 KB
/
clock.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
--------------------------------------------------------------*/
#include "U8glib.h"
U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NONE|U8G_I2C_OPT_DEV_0); // I2C / TWI
int hours = 11;
int minutes = 05;
int seconds = 0;
char *number[12]={"6","5","4","3","2","1","12","11","10","9","8","7"};
const int SCREEN_WIDTH = 128;
const int SCREEN_HEIGHT = 64;
float radius = min(SCREEN_HEIGHT, SCREEN_WIDTH)/2-1;
const int X_CENTER = SCREEN_WIDTH / 2;
const int Y_CENTER = SCREEN_HEIGHT / 2;
int x1, y1, x2, y2;
double angle;
void draw(void) {
//u8g.drawCircle(X_CENTER, Y_CENTER, radius);
u8g.drawCircle(X_CENTER, Y_CENTER, 1);
//draw minute's ticks (60 lines)
for(int j=1; j<=60; j++){
angle = j*6;
angle = angle * 0.0174533;
x1 = X_CENTER + (sin(angle) * radius);
y1 = Y_CENTER + (cos(angle) * radius);
x2 = X_CENTER + (sin(angle) * (radius));
y2 = Y_CENTER + (cos(angle) * (radius));
u8g.drawLine(x1,y1,x2,y2);
}
//draw hour's ticks (12 lines)
for(int j=0; j<12; j++){
angle = j*30;
angle = angle * 0.0174533;
x1 = X_CENTER + (sin(angle) * radius);
y1 = Y_CENTER + (cos(angle) * radius);
x2 = X_CENTER + (sin(angle) * (radius - 4));
y2 = Y_CENTER + (cos(angle) * (radius - 4));
u8g.drawLine(x1,y1,x2,y2);
//draw hour digits(12 lines)
x2 = X_CENTER + (sin(angle) * (radius - 8));
y2 = Y_CENTER + (cos(angle) * (radius - 8));
u8g.setFont(u8g_font_chikita);
u8g.drawStr(x2-2, y2+3, String(number[j]).c_str());
angle = seconds*6;
angle = angle * 0.0174533;
x2 = X_CENTER + (sin(angle) * (radius - 1));
y2 = Y_CENTER - (cos(angle) * (radius - 1));
u8g.drawLine(X_CENTER,Y_CENTER,x2,y2);
angle = minutes*6;
angle = angle * 0.0174533;
x2 = X_CENTER + (sin(angle) * (radius - 10));
y2 = Y_CENTER - (cos(angle) * (radius - 10));
u8g.drawLine(X_CENTER,Y_CENTER,x2,y2);
angle = hours*30 + ((minutes / 12) * 6);
angle = angle * 0.0174533;
x2 = X_CENTER + (sin(angle) * (radius / 2));
y2 = Y_CENTER - (cos(angle) * (radius / 2));
u8g.drawLine(X_CENTER,Y_CENTER,x2,y2);
/*
//draw sweep hand
float fraction = getCurrentTime() - floor(getCurrentTime());
angle = (fraction * 360) / 0.0174533;
x1 = X_CENTER + (sin(angle) * radius - 1);
y1 = Y_CENTER - (cos(angle) * radius - 1);
x2 = X_CENTER + (sin(angle) * (radius - 4));
y2 = Y_CENTER - (cos(angle) * (radius - 4));
u8g.drawLine(x1,y1,x2,y2);
*/
}
}
void setup(void) {
// flip screen, if required
// u8g.setRot180();
}
void loop(void) {
seconds +=1;
if(seconds==60){ seconds=seconds-60; minutes +=1;}
if(minutes==60){ minutes=0; hours +=1;}
if(hours==24){hours=1;}
//delay(800);
u8g.firstPage();
do {
draw();
} while( u8g.nextPage() );
// rebuild the picture after some delay
delay(500);
}