/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/propeller-clock.cc

  • Committer: Tim Marston
  • Date: 2012-03-21 20:35:28 UTC
  • Revision ID: tim@ed.am-20120321203528-wfhpych1tub75rgj
fixed bug initialising text services on mode activation

Show diffs side-by-side

added added

removed removed

Lines of Context:
79
79
#include "button.h"
80
80
#include "time.h"
81
81
#include "Arduino.h"
82
 
#include "modes/analogue_clock.h"
83
 
#include "modes/digital_clock.h"
84
 
#include "modes/test_pattern.h"
85
 
#include "modes/settings_mode.h"
86
 
#include "modes/info_mode.h"
 
82
#include "analogue_clock.h"
 
83
#include "digital_clock.h"
 
84
#include "test_pattern.h"
 
85
#include "settings_mode.h"
87
86
#include "text.h"
88
87
#include "text_renderer.h"
89
88
#include "common.h"
113
112
static int _major_mode = 0;
114
113
static int _minor_mode = 0;
115
114
 
116
 
#define SETTINGS_MODE_IDX 1
117
 
#define MAIN_MODE_IDX 0
 
115
#define MAIN_MODE_IDX 1
 
116
#define SETTINGS_MODE_IDX 0
118
117
 
119
118
#define ANALOGUE_CLOCK_IDX 0
120
119
#define DIGITAL_CLOCK_IDX 1
121
 
#define INFO_MODE_IDX 2
122
 
#define TEST_PATTERN_IDX 3
 
120
#define TEST_PATTERN_IDX 2
123
121
 
124
122
//_____________________________________________________________________________
125
123
//                                                                         code
136
134
        switch( _minor_mode ) {
137
135
        case ANALOGUE_CLOCK_IDX: analogue_clock_activate(); break;
138
136
        case DIGITAL_CLOCK_IDX: digital_clock_activate(); break;
139
 
        case INFO_MODE_IDX: info_mode_activate(); break;
140
137
        }
141
138
}
142
139
 
148
145
        Text::reset();
149
146
        leds_off();
150
147
 
151
 
        // reset buttons
152
 
        _button.set_press_mode( _major_mode != SETTINGS_MODE_IDX );
153
 
 
154
148
        // give the mode a chance to init
155
149
        switch( _major_mode ) {
156
150
        case MAIN_MODE_IDX: activate_minor_mode(); break;
174
168
                                switch( _minor_mode ) {
175
169
                                case ANALOGUE_CLOCK_IDX: analogue_clock_press(); break;
176
170
                                case DIGITAL_CLOCK_IDX: digital_clock_press(); break;
177
 
                                case INFO_MODE_IDX: info_mode_press(); break;
178
171
                                }
179
172
                                break;
180
173
                        case SETTINGS_MODE_IDX: settings_mode_press(); break;
185
178
                        // long press
186
179
                        switch( _major_mode ) {
187
180
                        case MAIN_MODE_IDX:
188
 
                                if( ++_minor_mode >= 4 )
 
181
                                if( ++_minor_mode >= 3 )
189
182
                                        _minor_mode = 0;
190
183
                                activate_minor_mode();
191
184
                                break;
226
219
                        switch( _minor_mode ) {
227
220
                        case ANALOGUE_CLOCK_IDX: analogue_clock_draw_reset(); break;
228
221
                        case DIGITAL_CLOCK_IDX: digital_clock_draw_reset(); break;
229
 
                        case INFO_MODE_IDX: info_mode_draw_reset(); break;
230
222
                        }
231
223
                        break;
232
224
                case SETTINGS_MODE_IDX: settings_mode_draw_reset(); break;
243
235
                case ANALOGUE_CLOCK_IDX: analogue_clock_draw( segment ); break;
244
236
                case DIGITAL_CLOCK_IDX: digital_clock_draw( segment ); break;
245
237
                case TEST_PATTERN_IDX: test_pattern_draw( segment ); break;
246
 
                case INFO_MODE_IDX: info_mode_draw( segment ); break;
247
238
                }
248
239
                break;
249
240
        case SETTINGS_MODE_IDX: settings_mode_draw( segment ); break;
250
241
        }
251
 
        Text::post_draw();
252
242
 
253
243
        // draw any text that was rendered
254
244
        TextRenderer::output_buffer();
305
295
}
306
296
 
307
297
 
308
 
// ISR to handle the pulses from the fan's tachometer
 
298
// ISR to handle the pulses from the fan's tachiometer
309
299
void fan_pulse_handler()
310
300
{
311
301
        // the fan actually sends two pulses per revolution. These pulses
325
315
// main setup
326
316
void setup()
327
317
{
328
 
        // set up an interrupt handler on pin 2 to notice fan pulses
 
318
        // set up an interrupt handler on pin 2 to nitice fan pulses
329
319
        attachInterrupt( 0, fan_pulse_handler, RISING );
330
320
        digitalWrite( 2, HIGH );
331
321
  
342
332
        // initialise RTC
343
333
        Time::init();
344
334
 
345
 
        // init text renderer
346
 
        TextRenderer::init();
347
 
 
348
335
        // activate the minor mode
349
336
        activate_major_mode();
350
337
}