/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-05-17 22:49:36 UTC
  • Revision ID: tim@ed.am-20120517224936-0wgyem932dlq5bs4
various tweaks, a (failed) attempt to fix text reset bug and added TODO

Show diffs side-by-side

added added

removed removed

83
83
#include "modes/digital_clock.h"
84
84
#include "modes/test_pattern.h"
85
85
#include "modes/settings_mode.h"
 
86
#include "modes/info_mode.h"
86
87
#include "text.h"
87
88
#include "text_renderer.h"
88
89
#include "common.h"
112
113
static int _major_mode = 0;
113
114
static int _minor_mode = 0;
114
115
 
115
 
#define MAIN_MODE_IDX 1
116
 
#define SETTINGS_MODE_IDX 0
 
116
#define SETTINGS_MODE_IDX 1
 
117
#define MAIN_MODE_IDX 0
117
118
 
118
119
#define ANALOGUE_CLOCK_IDX 0
119
120
#define DIGITAL_CLOCK_IDX 1
120
 
#define TEST_PATTERN_IDX 2
 
121
#define INFO_MODE_IDX 2
 
122
#define TEST_PATTERN_IDX 3
121
123
 
122
124
//_____________________________________________________________________________
123
125
//                                                                         code
134
136
        switch( _minor_mode ) {
135
137
        case ANALOGUE_CLOCK_IDX: analogue_clock_activate(); break;
136
138
        case DIGITAL_CLOCK_IDX: digital_clock_activate(); break;
 
139
        case INFO_MODE_IDX: info_mode_activate(); break;
137
140
        }
138
141
}
139
142
 
171
174
                                switch( _minor_mode ) {
172
175
                                case ANALOGUE_CLOCK_IDX: analogue_clock_press(); break;
173
176
                                case DIGITAL_CLOCK_IDX: digital_clock_press(); break;
 
177
                                case INFO_MODE_IDX: info_mode_press(); break;
174
178
                                }
175
179
                                break;
176
180
                        case SETTINGS_MODE_IDX: settings_mode_press(); break;
181
185
                        // long press
182
186
                        switch( _major_mode ) {
183
187
                        case MAIN_MODE_IDX:
184
 
                                if( ++_minor_mode >= 3 )
 
188
                                if( ++_minor_mode >= 4 )
185
189
                                        _minor_mode = 0;
186
190
                                activate_minor_mode();
187
191
                                break;
222
226
                        switch( _minor_mode ) {
223
227
                        case ANALOGUE_CLOCK_IDX: analogue_clock_draw_reset(); break;
224
228
                        case DIGITAL_CLOCK_IDX: digital_clock_draw_reset(); break;
 
229
                        case INFO_MODE_IDX: info_mode_draw_reset(); break;
225
230
                        }
226
231
                        break;
227
232
                case SETTINGS_MODE_IDX: settings_mode_draw_reset(); break;
238
243
                case ANALOGUE_CLOCK_IDX: analogue_clock_draw( segment ); break;
239
244
                case DIGITAL_CLOCK_IDX: digital_clock_draw( segment ); break;
240
245
                case TEST_PATTERN_IDX: test_pattern_draw( segment ); break;
 
246
                case INFO_MODE_IDX: info_mode_draw( segment ); break;
241
247
                }
242
248
                break;
243
249
        case SETTINGS_MODE_IDX: settings_mode_draw( segment ); break;
244
250
        }
 
251
        Text::post_draw();
245
252
 
246
253
        // draw any text that was rendered
247
254
        TextRenderer::output_buffer();
298
305
}
299
306
 
300
307
 
301
 
// ISR to handle the pulses from the fan's tachiometer
 
308
// ISR to handle the pulses from the fan's tachometer
302
309
void fan_pulse_handler()
303
310
{
304
311
        // the fan actually sends two pulses per revolution. These pulses
318
325
// main setup
319
326
void setup()
320
327
{
321
 
        // set up an interrupt handler on pin 2 to nitice fan pulses
 
328
        // set up an interrupt handler on pin 2 to notice fan pulses
322
329
        attachInterrupt( 0, fan_pulse_handler, RISING );
323
330
        digitalWrite( 2, HIGH );
324
331