/elec/propeller-clock

To get this branch, use:
bzr branch http://bzr.ed.am/elec/propeller-clock

« back to all changes in this revision

Viewing changes to src/modes/analogue_clock_mode.cc

  • Committer: Tim Marston
  • Date: 2012-05-23 23:02:50 UTC
  • Revision ID: tim@ed.am-20120523230250-3pls2u6zt3av0uam
fixed text glitch; extended all modes; added screen flip super-long press;
added button unpress debounde; moved interim button press ignoration to
settings mode; fixed left-over led issue; finished for demo!

Show diffs side-by-side

added added

removed removed

22
22
 */
23
23
#include "analogue_clock_mode.h"
24
24
#include "config.h"
 
25
#include "Arduino.h"
25
26
#include "time.h"
26
 
#include <cstdlib>
27
 
 
28
 
 
29
 
AnalogueClockMode::AnalogueClockMode()
30
 
    :
31
 
    MinorMode( 2 )
32
 
{
33
 
}
 
27
#include "common.h"
 
28
#include "text.h"
34
29
 
35
30
 
36
31
void AnalogueClockMode::draw( int segment )
37
32
{
38
 
/*
39
 
        int second = segment / NUM_SECOND_SEGMENTS;
40
 
        int second_segment = segment % NUM_SECOND_SEGMENTS;
41
 
 
42
 
        // what needs to be drawn?
43
 
        bool draw_tick = ( !second_segment && second % 5 == 0 && second ) ||
44
 
                ( second == 0 && second_segment == 1 ) ||
45
 
                ( second == 59 && second_segment == NUM_SECOND_SEGMENTS - 1 );
46
 
        bool draw_second = !second_segment && second == time.get_seconds();
47
 
        bool draw_minute = !second_segment && second == time.get_minutes();
48
 
        bool draw_hour = segment == time.get_hours() * 5 * NUM_SECOND_SEGMENTS +
49
 
                ( 5 * NUM_SECOND_SEGMENTS * time.get_minutes() / 60 );
50
 
*/
51
 
        
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
 
        bool draw_hour_side = 1 >=
56
 
                ( std::abs( _hour_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
57
 
                
58
 
//              ( segment == ( _hour_segment + 1 ) % NUM_SEGMENTS ) ||
59
 
//              ( segment == ( _hour_segment + NUM_SEGMENTS - 1 ) % NUM_SEGMENTS );
 
36
        bool draw_hour_side = 2 >=
 
37
                ( abs( _hour_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
60
38
        bool draw_minute = segment == _minute_segment;
 
39
        bool draw_minute_side = 1 >=
 
40
                ( abs( _minute_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
 
41
 
61
42
        bool draw_second = segment == _second_segment;
62
43
 
63
44
        // set the LEDs
64
 
        led_on( 9, get_flavour() == 0 );
65
 
        led_on( 8, draw_tick || draw_second );
66
 
        for( int a = 6; a <= 7; a++ )
67
 
                led_on( a, draw_minute || draw_second );
68
 
        led_on( 5, draw_minute || draw_second || draw_hour );
69
 
        for( int a = 0; a <= 4; a++ )
70
 
                led_on( a, draw_minute || draw_second || draw_hour || draw_hour_side );
 
45
        switch( _flavour )
 
46
        {
 
47
        case 0:
 
48
                led( 9, true );
 
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 );
 
57
                break;
 
58
        case 1:
 
59
                led( 9, draw_tick );
 
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 );
 
68
                break;
 
69
        case 2:
 
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 );
 
79
                break;
 
80
        case 3:
 
81
                led( 9, segment <= ( _second_segment +
 
82
                                NUM_SECOND_SEGMENTS * _subsecond_segment / NUM_SEGMENTS ) );
 
83
                led( 8, draw_tick );
 
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 );
 
90
                break;
 
91
        }
71
92
}
72
93
 
73
94
 
74
95
void AnalogueClockMode::draw_reset()
75
96
{
76
 
        Time &time = Time::get_instance();
 
97
        int old_second_segment = _second_segment;
77
98
 
78
99
        // calculate hand locations
79
 
        _hour_segment = ( time.get_hours() % 12 ) * 5 * NUM_SECOND_SEGMENTS +
80
 
                ( 5 * NUM_SECOND_SEGMENTS * time.get_minutes() / 60 );
81
 
        _minute_segment = time.get_minutes() * NUM_SECOND_SEGMENTS +
82
 
                ( NUM_SECOND_SEGMENTS * time.get_seconds() / 60 );
83
 
        _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;
 
105
 
 
106
        // calculate the subsecond segment
 
107
        if( old_second_segment != _second_segment ) {
 
108
                _second_millis = millis();
 
109
                _subsecond_segment = 0;
 
110
        }
 
111
        else {
 
112
                unsigned long elapsed = ::millis() - _second_millis;
 
113
                _subsecond_segment = elapsed * NUM_SEGMENTS / 1000;
 
114
        }
 
115
}
 
116
 
 
117
 
 
118
void AnalogueClockMode::activate()
 
119
{
 
120
        _flavour = 0;
 
121
        _second_millis = ::millis();
 
122
 
 
123
        Text::reset();
 
124
}
 
125
 
 
126
 
 
127
void AnalogueClockMode::press()
 
128
{
 
129
        if( ++_flavour >= 4 )
 
130
                _flavour = 0;
84
131
}