Subversion Repositories Projects

Rev

Rev 489 | Rev 507 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 489 Rev 497
Line 38... Line 38...
38
uint8_t EEMEM ee_checkbyte1 = CHECKBYTE1;
38
uint8_t EEMEM ee_checkbyte1 = CHECKBYTE1;
39
uint8_t EEMEM ee_checkbyte2 = CHECKBYTE2;
39
uint8_t EEMEM ee_checkbyte2 = CHECKBYTE2;
40
uint16_t EEMEM ee_cal_ampere = 512;
40
uint16_t EEMEM ee_cal_ampere = 512;
41
uint8_t EEMEM ee_sensor = 50;
41
uint8_t EEMEM ee_sensor = 50;
42
uint8_t EEMEM ee_COSD_FLAGS;
42
uint8_t EEMEM ee_COSD_FLAGS;
-
 
43
uint8_t EEMEM ee_COSD_DISPLAYMODE = 0;
Line 43... Line 44...
43
 
44
 
44
// store init strings in progmem
45
// store init strings in progmem
45
const char init_0[] PROGMEM = "C-OSD Initialisation";
46
const char init_0[] PROGMEM = "C-OSD Initialisation";
46
const char init_1[] PROGMEM = "FC only Mode";
47
const char init_1[] PROGMEM = "FC only Mode";
Line 66... Line 67...
66
const char menu_item3[] PROGMEM = "Big Vario bar";
67
const char menu_item3[] PROGMEM = "Big Vario bar";
67
const char menu_item4[] PROGMEM = "Statistics";
68
const char menu_item4[] PROGMEM = "Statistics";
68
const char menu_item5[] PROGMEM = "Warnings"; // TODO: do it!
69
const char menu_item5[] PROGMEM = "Warnings"; // TODO: do it!
69
const char menu_item6[] PROGMEM = "Reset uptime";
70
const char menu_item6[] PROGMEM = "Reset uptime";
70
const char menu_item7[] PROGMEM = "Request OSD-data";
71
const char menu_item7[] PROGMEM = "Request OSD-data";
71
const char menu_item8[] PROGMEM = "Disable Debug-data";
72
const char menu_item8[] PROGMEM = "Display Mode";
72
const char menu_item9[] PROGMEM = "Save config";
73
const char menu_item9[] PROGMEM = "Save config";
73
const char menu_item10[] PROGMEM = "EXIT";
74
const char menu_item10[] PROGMEM = "EXIT";
74
const char* menu[] = {menu_item0, menu_item1, menu_item2, menu_item3, menu_item4,
75
const char* menu[] = {menu_item0, menu_item1, menu_item2, menu_item3, menu_item4,
75
        menu_item5, menu_item6, menu_item7, menu_item8, menu_item9, menu_item10};
76
        menu_item5, menu_item6, menu_item7, menu_item8, menu_item9, menu_item10};
Line -... Line 77...
-
 
77
 
-
 
78
const displaymode_t * mode;
76
 
79
 
77
/**
80
/**
78
 * read data saved in eeprom, print out message if <verbose> is set
81
 * read data saved in eeprom, print out message if <verbose> is set
79
 */
82
 */
80
void get_eeprom(uint8_t verbose) {
83
void get_eeprom(uint8_t verbose) {
81
        if (eeprom_read_byte(&ee_checkbyte1) == CHECKBYTE1 && eeprom_read_byte(&ee_checkbyte2) == CHECKBYTE2) {
84
        if (eeprom_read_byte(&ee_checkbyte1) == CHECKBYTE1 && eeprom_read_byte(&ee_checkbyte2) == CHECKBYTE2) {
82
                if (verbose) write_ascii_string_pgm(2, 9, ee_msg[0]); // Loading data
85
                if (verbose) write_ascii_string_pgm(2, 9, ee_msg[0]); // Loading data
-
 
86
                COSD_FLAGS = eeprom_read_byte(&ee_COSD_FLAGS);
-
 
87
                COSD_DISPLAYMODE = eeprom_read_byte(&ee_COSD_DISPLAYMODE);
83
                COSD_FLAGS = eeprom_read_byte(&ee_COSD_FLAGS);
88
                //if (verbose) write_ndigit_number_u(23, 11, COSD_DISPLAYMODE, 10, 0);
84
        } else {
89
        } else {
85
                if (verbose) write_ascii_string_pgm(2, 9, ee_msg[1]); // No data found
90
                if (verbose) write_ascii_string_pgm(2, 9, ee_msg[1]); // No data found
86
        }
91
        }
Line 91... Line 96...
91
 */
96
 */
92
void save_eeprom() {
97
void save_eeprom() {
93
        eeprom_write_byte(&ee_checkbyte1, CHECKBYTE1);
98
        eeprom_write_byte(&ee_checkbyte1, CHECKBYTE1);
94
        eeprom_write_byte(&ee_checkbyte2, CHECKBYTE2);
99
        eeprom_write_byte(&ee_checkbyte2, CHECKBYTE2);
95
        eeprom_write_byte(&ee_COSD_FLAGS, COSD_FLAGS);
100
        eeprom_write_byte(&ee_COSD_FLAGS, COSD_FLAGS);
-
 
101
        eeprom_write_byte(&ee_COSD_DISPLAYMODE, COSD_DISPLAYMODE);
96
}
102
}
Line 97... Line 103...
97
 
103
 
98
/**
104
/**
99
 * auto config some stuff on startup, currently only battery cells
105
 * auto config some stuff on startup, currently only battery cells
Line 140... Line 146...
140
                write_ascii_string_pgm(23, 2, VM_NTSC);
146
                write_ascii_string_pgm(23, 2, VM_NTSC);
141
        } else {
147
        } else {
142
                write_ascii_string_pgm(23, 2, VM_PAL);
148
                write_ascii_string_pgm(23, 2, VM_PAL);
143
        }
149
        }
Line -... Line 150...
-
 
150
 
-
 
151
 
-
 
152
        #if FCONLY
-
 
153
        COSD_DISPLAYMODE %= (sizeof(fcdisplaymodes) / sizeof(displaymode_t));
-
 
154
        mode = fcdisplaymodes;
-
 
155
        mode += COSD_DISPLAYMODE;
-
 
156
        osd_fcmode = (int(*)(void)) pgm_read_word(&mode->dfun);
-
 
157
        #else
-
 
158
        COSD_DISPLAYMODE %= (sizeof(ncdisplaymodes) / sizeof(displaymode_t));
-
 
159
        mode = ncdisplaymodes;
-
 
160
        mode += COSD_DISPLAYMODE;
-
 
161
        osd_ncmode = (int(*)(void)) pgm_read_word(&mode->dfun);
-
 
162
        #endif
144
 
163
 
145
    _delay_ms(200);
164
    _delay_ms(200);
146
    clear();
165
    clear();
147
    // update flags to paint display again because of clear
166
    // update flags to paint display again because of clear
148
    COSD_FLAGS2 &= ~COSD_ICONS_WRITTEN;
167
    COSD_FLAGS2 &= ~COSD_ICONS_WRITTEN;
Line 190... Line 209...
190
    if (COSD_FLAGS & COSD_FLAG_WARNINGS) {
209
    if (COSD_FLAGS & COSD_FLAG_WARNINGS) {
191
        write_ascii_string_pgm(23, 7, ON);
210
        write_ascii_string_pgm(23, 7, ON);
192
    } else {
211
    } else {
193
        write_ascii_string_pgm(23, 7, OFF);
212
        write_ascii_string_pgm(23, 7, OFF);
194
    }
213
    }
-
 
214
        //write_ndigit_number_u(23, 10, COSD_DISPLAYMODE, 10, 0);
-
 
215
        write_ascii_string_pgm(18, 10, (const char *) (pgm_read_word(&(mode->desc))));
-
 
216
       
195
}
217
}
Line 196... Line 218...
196
 
218
 
197
/**
219
/**
198
 * some sort of clicking response in the menu
220
 * some sort of clicking response in the menu
Line 293... Line 315...
293
                    // and disable debug...
315
                    // and disable debug...
294
                    usart1_request_mk_data(0, 'd', 0);
316
                    usart1_request_mk_data(0, 'd', 0);
295
#endif
317
#endif
296
                    config_menu_doclick(chosen, menu);
318
                    config_menu_doclick(chosen, menu);
297
                    break;
319
                    break;
298
                case 8: // disable debug data
320
                case 8: // change mode
-
 
321
                                        #if FCONLY
-
 
322
                                        COSD_DISPLAYMODE = (COSD_DISPLAYMODE + 1) % (sizeof(fcdisplaymodes) / sizeof(displaymode_t));
-
 
323
                                        mode = fcdisplaymodes;
-
 
324
                                        mode += COSD_DISPLAYMODE;
299
                    // disable sending of debug data
325
                                        osd_fcmode = (int(*)(void)) pgm_read_word(&mode->dfun);
-
 
326
                                        #else
300
                    // may result in smoother ddata display
327
                                        COSD_DISPLAYMODE = (COSD_DISPLAYMODE + 1) % (sizeof(ncdisplaymodes) / sizeof(displaymode_t));
-
 
328
                                        mode = ncdisplaymodes;
-
 
329
                                        mode += COSD_DISPLAYMODE;
301
                    usart1_request_mk_data(0, 'd', 0);
330
                                        osd_ncmode = (int(*)(void)) pgm_read_word(&mode->dfun);
-
 
331
                                        #endif
302
                    config_menu_doclick(chosen, menu);
332
                                        config_menu_drawings(chosen);
303
                    break;
333
                    break;
304
                case 9: // save
334
                case 9: // save
305
                    save_eeprom();
335
                    save_eeprom();
306
                    config_menu_doclick(chosen, menu);
336
                    config_menu_doclick(chosen, menu);
307
                    break;
337
                    break;