/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/analogue_clock_mode.cc

  • Committer: edam
  • Date: 2012-02-25 14:54:33 UTC
  • Revision ID: edam@waxworlds.org-20120225145433-kih8qs45x05cum46
removed Bounce library and updated/fixed new code

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"
26
25
#include "time.h"
27
 
#include "common.h"
28
 
#include "text.h"
 
26
#include <cstdlib>
 
27
 
 
28
 
 
29
AnalogueClockMode::AnalogueClockMode()
 
30
    :
 
31
    MinorMode( 2 )
 
32
{
 
33
}
29
34
 
30
35
 
31
36
void AnalogueClockMode::draw( int segment )
32
37
{
 
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
        
33
52
        bool draw_tick = segment && ( segment % ( NUM_SECOND_SEGMENTS * 5 ) == 0 ||
34
53
                segment == 1 || segment == NUM_SEGMENTS - 1 );
35
54
        bool draw_hour = segment == _hour_segment;
36
 
        bool draw_hour_side = 2 >=
37
 
                ( abs( _hour_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
 
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 );
38
60
        bool draw_minute = segment == _minute_segment;
39
 
        bool draw_minute_side = 1 >=
40
 
                ( abs( _minute_segment - segment ) + NUM_SEGMENTS ) % NUM_SEGMENTS;
41
 
 
42
61
        bool draw_second = segment == _second_segment;
43
62
 
44
63
        // set the LEDs
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
 
        }
 
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 );
92
71
}
93
72
 
94
73
 
95
74
void AnalogueClockMode::draw_reset()
96
75
{
97
 
        int old_second_segment = _second_segment;
 
76
        Time &time = Time::get_instance();
98
77
 
99
78
        // calculate hand locations
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;
 
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;
131
84
}