20
20
* You should have received a copy of the GNU Lesser General Public License
21
21
* along with this program. If not, see <http://www.gnu.org/licenses/>.
23
#include "analogue_clock.h"
23
#include "analogue_clock_mode.h"
24
24
#include "config.h"
25
25
#include "Arduino.h"
27
27
#include "common.h"
30
// the segment that the hour hand should be at
31
static int _hour_segment;
33
// the segment that the minute hand should be at
34
static int _minute_segment;
36
// the segment that the second hand should be at
37
static int _second_segment;
43
void analogue_clock_press()
50
void analogue_clock_draw( int segment )
31
void AnalogueClockMode::draw( int segment )
52
33
bool draw_tick = segment && ( segment % ( NUM_SECOND_SEGMENTS * 5 ) == 0 ||
53
34
segment == 1 || segment == NUM_SEGMENTS - 1 );
54
35
bool draw_hour = segment == _hour_segment;
55
36
bool draw_hour_side = 2 >=
56
37
( abs( _hour_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
58
// ( segment == ( _hour_segment + 1 ) % NUM_SEGMENTS ) ||
59
// ( segment == ( _hour_segment + NUM_SEGMENTS - 1 ) % NUM_SEGMENTS );
60
38
bool draw_minute = segment == _minute_segment;
61
39
bool draw_minute_side = 1 >=
62
40
( abs( _minute_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
64
42
bool draw_second = segment == _second_segment;
67
led( 9, _flavour == 0 );
68
led( 8, draw_tick || draw_second );
69
led( 7, draw_minute || draw_second );
70
led( 6, draw_minute || draw_minute_side || draw_second );
71
led( 5, draw_minute || draw_minute_side ||
72
draw_second || draw_hour );
73
for( int a = 0; a <= 4; a++ )
74
led( a, draw_minute || draw_minute_side ||
75
draw_second || draw_hour || draw_hour_side );
49
led( 8, draw_tick || draw_second );
50
led( 7, draw_minute || draw_second );
51
led( 6, draw_minute || draw_minute_side || draw_second );
52
led( 5, draw_minute || draw_minute_side ||
53
draw_second || draw_hour );
54
for( int a = 0; a <= 4; a++ )
55
led( a, draw_minute || draw_minute_side ||
56
draw_second || draw_hour || draw_hour_side );
60
led( 8, draw_second );
61
led( 7, draw_minute || draw_second );
62
led( 6, draw_minute || draw_minute_side || draw_second );
63
led( 5, draw_minute || draw_minute_side ||
64
draw_second || draw_hour );
65
for( int a = 0; a <= 4; a++ )
66
led( a, draw_minute || draw_minute_side ||
67
draw_second || draw_hour || draw_hour_side );
70
led( 9, segment <= _subsecond_segment );
71
led( 8, draw_tick || draw_second );
72
led( 7, draw_minute || draw_second );
73
led( 6, draw_minute || draw_minute_side || draw_second );
74
led( 5, draw_minute || draw_minute_side ||
75
draw_second || draw_hour );
76
for( int a = 0; a <= 4; a++ )
77
led( a, draw_minute || draw_minute_side ||
78
draw_second || draw_hour || draw_hour_side );
81
led( 9, segment <= ( _second_segment +
82
NUM_SECOND_SEGMENTS * _subsecond_segment / NUM_SEGMENTS ) );
84
led( 7, draw_minute );
85
led( 6, draw_minute || draw_minute_side );
86
led( 5, draw_minute || draw_minute_side || draw_hour );
87
for( int a = 0; a <= 4; a++ )
88
led( a, draw_minute || draw_minute_side ||
89
draw_hour || draw_hour_side );
79
void analogue_clock_draw_reset()
95
void AnalogueClockMode::draw_reset()
81
Time &time = Time::get_instance();
97
int old_second_segment = _second_segment;
83
99
// calculate hand locations
84
_hour_segment = ( time.get_hours() % 12 ) * 5 * NUM_SECOND_SEGMENTS +
85
( 5 * NUM_SECOND_SEGMENTS * time.get_minutes() / 60 );
86
_minute_segment = time.get_minutes() * NUM_SECOND_SEGMENTS +
87
( NUM_SECOND_SEGMENTS * time.get_seconds() / 60 );
88
_second_segment = time.get_seconds() * NUM_SECOND_SEGMENTS;
100
_hour_segment = ( Time::get_hours() % 12 ) * 5 * NUM_SECOND_SEGMENTS +
101
( 5 * NUM_SECOND_SEGMENTS * Time::get_minutes() / 60 );
102
_minute_segment = Time::get_minutes() * NUM_SECOND_SEGMENTS +
103
( NUM_SECOND_SEGMENTS * Time::get_seconds() / 60 );
104
_second_segment = Time::get_seconds() * NUM_SECOND_SEGMENTS;
106
// calculate the subsecond segment
107
if( old_second_segment != _second_segment ) {
108
_second_millis = millis();
109
_subsecond_segment = 0;
112
unsigned long elapsed = ::millis() - _second_millis;
113
_subsecond_segment = elapsed * NUM_SEGMENTS / 1000;
118
void AnalogueClockMode::activate()
121
_second_millis = ::millis();
127
void AnalogueClockMode::press()
129
if( ++_flavour >= 4 )