/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 21:24:17 UTC
  • Revision ID: tim@ed.am-20120321212417-dnba5l1oheddeyxw
fixed time centring and display in settings mode

Show diffs side-by-side

added added

removed removed

82
82
#include "analogue_clock.h"
83
83
#include "digital_clock.h"
84
84
#include "test_pattern.h"
 
85
#include "settings_mode.h"
 
86
#include "text.h"
 
87
#include "text_renderer.h"
 
88
#include "common.h"
85
89
 
86
90
//_____________________________________________________________________________
87
91
//                                                                         data
108
112
static int _major_mode = 0;
109
113
static int _minor_mode = 0;
110
114
 
111
 
#define MAIN_MODE_IDX 0
 
115
#define MAIN_MODE_IDX 1
 
116
#define SETTINGS_MODE_IDX 0
112
117
 
113
118
#define ANALOGUE_CLOCK_IDX 0
114
119
#define DIGITAL_CLOCK_IDX 1
121
126
// activate the current minor mode
122
127
void activate_minor_mode()
123
128
{
 
129
        // reset text
 
130
        Text::reset();
 
131
        leds_off();
 
132
 
 
133
        // give the mode a chance to init
124
134
        switch( _minor_mode ) {
125
135
        case ANALOGUE_CLOCK_IDX: analogue_clock_activate(); break;
126
136
        case DIGITAL_CLOCK_IDX: digital_clock_activate(); break;
127
137
        }
128
138
}
129
139
 
 
140
 
 
141
// activate major mode
 
142
void activate_major_mode()
 
143
{
 
144
        // reset text
 
145
        Text::reset();
 
146
        leds_off();
 
147
 
 
148
        // give the mode a chance to init
 
149
        switch( _major_mode ) {
 
150
        case MAIN_MODE_IDX: activate_minor_mode(); break;
 
151
        case SETTINGS_MODE_IDX: settings_mode_activate(); break;
 
152
        }
 
153
}
 
154
 
 
155
 
130
156
// perform button events
131
157
void do_button_events()
132
158
{
144
170
                                case DIGITAL_CLOCK_IDX: digital_clock_press(); break;
145
171
                                }
146
172
                                break;
 
173
                        case SETTINGS_MODE_IDX: settings_mode_press(); break;
147
174
                        }
148
175
                        break;
149
176
 
153
180
                        case MAIN_MODE_IDX:
154
181
                                if( ++_minor_mode >= 3 )
155
182
                                        _minor_mode = 0;
156
 
                                switch( _minor_mode ) {
157
 
                                case DIGITAL_CLOCK_IDX: digital_clock_activate(); break;
158
 
                                }
 
183
                                activate_minor_mode();
159
184
                                break;
 
185
                        case SETTINGS_MODE_IDX: settings_mode_long_press(); break;
160
186
                        }
161
187
                        break;
162
188
 
163
189
                case 3:
164
190
                        // looooong press (change major mode)
165
 
                        if( ++_major_mode > 0 )
 
191
                        if( ++_major_mode > 1 )
166
192
                                _major_mode = 0;
167
 
                        switch( _major_mode ) {
168
 
                        case MAIN_MODE_IDX: _minor_mode = 0; break;
169
 
                        }
170
 
                        activate_minor_mode();
 
193
                        activate_major_mode();
171
194
                        break;
172
195
                }
173
196
        }
186
209
        if( reset ) segment = NUM_SEGMENTS - 1 - CLOCK_SHIFT;
187
210
#endif
188
211
 
 
212
        // reset the text renderer
 
213
        TextRenderer::reset_buffer();
 
214
 
189
215
        // frame reset
190
216
        if( reset ) {
191
217
                switch( _major_mode ) {
195
221
                        case DIGITAL_CLOCK_IDX: digital_clock_draw_reset(); break;
196
222
                        }
197
223
                        break;
 
224
                case SETTINGS_MODE_IDX: settings_mode_draw_reset(); break;
198
225
                }
 
226
 
 
227
                // tell the text services we're starting a new frame
 
228
                Text::draw_reset();
199
229
        }
200
230
 
201
231
        // draw
207
237
                case TEST_PATTERN_IDX: test_pattern_draw( segment ); break;
208
238
                }
209
239
                break;
 
240
        case SETTINGS_MODE_IDX: settings_mode_draw( segment ); break;
210
241
        }
211
242
 
 
243
        // draw any text that was rendered
 
244
        TextRenderer::output_buffer();
 
245
 
212
246
#if CLOCK_FORWARD
213
247
        if( ++segment >= NUM_SEGMENTS ) segment = 0;
214
248
#else
299
333
        Time::init();
300
334
 
301
335
        // activate the minor mode
302
 
        switch( _major_mode ) {
303
 
        case MAIN_MODE_IDX: activate_minor_mode(); break;
304
 
        }
 
336
        activate_major_mode();
305
337
}
306
338
 
307
339