Mercurial > public > ostc4
annotate Discovery/Src/tMenuEdit.c @ 956:083afabc6578 Evo_2_23
Bugfix UART sensor MUX channel selection after sleep:
In case only one UART sensor is connected to the MUX, to a channel other than 0 then the sensor operation could fail in case the initial mux address selection was not successfull. To fix this problem the MUX address is selected again in case a timeout occures during sensor setup.
author | Ideenmodellierer |
---|---|
date | Mon, 06 Jan 2025 17:55:34 +0100 |
parents | e9c37071933b |
children |
rev | line source |
---|---|
38 | 1 /////////////////////////////////////////////////////////////////////////////// |
2 /// -*- coding: UTF-8 -*- | |
3 /// | |
4 /// \file Discovery/Src/tMenuEdit.c | |
5 /// \brief Main Template file for Menu Setting Modifications | |
6 /// \author heinrichs weikamp gmbh | |
7 /// \date 04-July-2014 | |
8 /// | |
9 /// \details | |
10 /// | |
11 /// $Id$ | |
12 /////////////////////////////////////////////////////////////////////////////// | |
13 /// \par Copyright (c) 2014-2018 Heinrichs Weikamp gmbh | |
14 /// | |
15 /// This program is free software: you can redistribute it and/or modify | |
16 /// it under the terms of the GNU General Public License as published by | |
17 /// the Free Software Foundation, either version 3 of the License, or | |
18 /// (at your option) any later version. | |
19 /// | |
20 /// This program is distributed in the hope that it will be useful, | |
21 /// but WITHOUT ANY WARRANTY; without even the implied warranty of | |
22 /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
23 /// GNU General Public License for more details. | |
24 /// | |
25 /// You should have received a copy of the GNU General Public License | |
26 /// along with this program. If not, see <http://www.gnu.org/licenses/>. | |
27 ////////////////////////////////////////////////////////////////////////////// | |
28 | |
29 /* Includes ------------------------------------------------------------------*/ | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
30 #include <stdlib.h> |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
31 |
38 | 32 #include "tMenuEdit.h" |
33 | |
34 #include "externLogbookFlash.h" | |
35 #include "gfx_fonts.h" | |
36 #include "tHome.h" | |
37 #include "tInfoCompass.h" | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
38 #include "tInfoSensor.h" |
845 | 39 #include "tInfoPreDive.h" |
38 | 40 #include "tMenuEditHardware.h" |
41 #include "tMenuEditPlanner.h" | |
42 #include "tMenuEditSystem.h" | |
43 #include "tMenuEditXtra.h" | |
508 | 44 #include "tMenuEditCustom.h" |
38 | 45 |
46 /* Private types -------------------------------------------------------------*/ | |
47 #define TEXTSIZE 16 | |
48 | |
49 typedef struct | |
50 { | |
51 uint32_t pEventFunction; | |
52 uint32_t callerID; | |
53 } SEventHandler; | |
54 | |
55 typedef struct | |
56 { | |
57 uint32_t pEventFunction; | |
58 uint8_t functionParameter; | |
59 uint8_t line; | |
60 } SBackMenuHandler; | |
61 | |
62 typedef struct | |
63 { | |
64 char orgText[32]; | |
65 char newText[32]; | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
66 uint32_t input[4]; |
38 | 67 uint16_t coord[3]; |
68 int8_t begin[4], size[4]; | |
69 tFont *fontUsed; | |
70 uint32_t callerID; | |
71 uint8_t maintype; | |
72 uint8_t subtype; | |
73 } SEditIdent; | |
74 | |
75 typedef enum | |
76 { | |
77 FIELD_NUMBERS = 0, | |
78 FIELD_BUTTON, | |
79 FIELD_SELECT, | |
80 FIELD_SYMBOL, | |
81 FIELD_TOGGLE, | |
82 FIELD_ON_OFF, | |
83 FIELD_UDIGIT, | |
84 FIELD_2DIGIT, | |
85 FIELD_3DIGIT, | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
86 FIELD_SDIGIT, |
38 | 87 FIELD_FLOAT, |
88 FIELD_END | |
89 } SField; | |
90 | |
91 /* Private variables ---------------------------------------------------------*/ | |
92 GFX_DrawCfgScreen tMEscreen; | |
93 GFX_DrawCfgScreen tMEcursor; | |
94 GFX_DrawCfgScreen tMEcursorNew; | |
95 | |
508 | 96 static uint32_t menuID; |
97 static uint8_t menuColor; | |
38 | 98 |
508 | 99 static int8_t id = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
100 static int8_t actualId = 0; |
508 | 101 static int8_t idLast = -1; |
102 static SEditIdent ident[10]; | |
103 static int8_t tME_stop = 0; | |
38 | 104 |
508 | 105 static int8_t evid = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
106 static int8_t actualevid = 0; |
508 | 107 static int8_t evidLast = -1; |
108 static SEventHandler event[10]; | |
38 | 109 |
508 | 110 static SBackMenuHandler backmenu; |
38 | 111 |
508 | 112 static int8_t block = 0; |
113 static int8_t subBlockPosition = 0; | |
38 | 114 |
508 | 115 static _Bool EnterPressedBeforeButtonAction = 0; |
116 static _Bool EnterPressed = 0; | |
38 | 117 |
508 | 118 static _Bool WriteSettings = 0; |
38 | 119 |
120 /* Private function prototypes -----------------------------------------------*/ | |
854 | 121 static void create_newText_for_Id(int8_t localId); |
122 void clean_content_of_Id(int8_t localId); | |
123 static void write_content_of_Id(int8_t localId); | |
124 | |
38 | 125 void draw_tMEdesign(void); |
126 void set_cursorNew(uint8_t forThisIdentID); | |
127 void startMenuEditFieldSelect(void); | |
128 void create_newText_for_actual_Id(void); | |
129 void write_content_of_actual_Id(void); | |
130 void clean_content_of_actual_Id(void); | |
131 void write_content_without_Id(void); | |
132 | |
133 void nextMenuEditFieldDigit(void); | |
134 void upMenuEditFieldDigit(void); | |
135 void downMenuEditFieldDigit(void); | |
136 | |
137 void draw_tMEcursorNewDesign(void); | |
138 | |
139 uint8_t split_Content_to_Digit_helper(uint8_t inContentAscii, uint8_t *outDigit100, uint8_t *outDigit10, uint8_t *outDigit1); | |
140 | |
141 /* Exported functions --------------------------------------------------------*/ | |
142 | |
143 void tMenuEdit_init(void) | |
144 { | |
145 tMEcursor.FBStartAdress = getFrame(7); | |
146 tMEcursor.ImageHeight = 480; | |
147 tMEcursor.ImageWidth = 800; | |
148 tMEcursor.LayerIndex = 0; | |
149 | |
150 GFX_fill_buffer(tMEcursor.FBStartAdress, 0xFF, CLUT_MenuEditCursor); | |
151 | |
152 tMEcursorNew.FBStartAdress = getFrame(8); | |
153 tMEcursorNew.ImageHeight = 390; | |
154 tMEcursorNew.ImageWidth = 800; | |
155 tMEcursorNew.LayerIndex = 0; | |
156 | |
157 draw_tMEcursorNewDesign(); | |
158 } | |
159 | |
160 void stop_cursor_fields(void) | |
161 { | |
162 tME_stop = 1; | |
163 } | |
164 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
165 void resetMenuContentStructure() |
38 | 166 { |
167 id = 0; | |
168 idLast = -1; | |
169 evid = 0; | |
170 evidLast = -1; | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
171 } |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
172 |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
173 void resetMenuEdit(uint8_t color) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
174 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
175 id = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
176 actualId = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
177 idLast = -1; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
178 evid = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
179 actualevid = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
180 evidLast = -1; |
38 | 181 tME_stop = 0; |
182 EnterPressed = 0; | |
183 EnterPressedBeforeButtonAction = 0; | |
184 | |
185 setBackMenu(0,0,0); | |
186 | |
187 releaseFrame(9,tMEscreen.FBStartAdress); | |
188 | |
189 tMEscreen.FBStartAdress = getFrame(9); | |
190 tMEscreen.ImageHeight = 480; | |
191 tMEscreen.ImageWidth = 800; | |
192 tMEscreen.LayerIndex = 1; | |
193 | |
194 /* | |
195 write_content_simple(&tMEscreen, 0, 38, 0, &Awe48,"x",CLUT_ButtonSymbols); | |
196 write_content_simple(&tMEscreen, 800-46, 800, 0, &Awe48,"u",CLUT_ButtonSymbols); | |
197 write_content_simple(&tMEscreen, 0, 45, 480-45, &Awe48,"d",CLUT_ButtonSymbols); | |
198 write_content_simple(&tMEscreen, 800-48, 800, 480-45, &Awe48,"e",CLUT_ButtonSymbols); | |
199 */ | |
200 menuID = get_globalState(); | |
201 | |
202 menuColor = color; | |
203 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
204 /* set cursor to first line */ |
38 | 205 uint8_t line = 1; |
206 GFX_SetFrameTop(tMEscreen.FBStartAdress); | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
207 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
208 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
209 GFX_SetFrameBottom((tMEcursorNew.FBStartAdress) + 65*2*(line - 1), 0, 25, 800, 390); |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
210 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
211 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
212 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
213 GFX_SetFrameBottom((tMEcursorNew.FBStartAdress)+ (390 - 65 *(line)) *2, 0, 480-390-25, 800, 390); |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
214 } |
38 | 215 } |
216 | |
217 | |
218 void tMenuEdit_refresh_live_content(void) | |
219 { | |
508 | 220 uint32_t globState = get_globalState(); |
221 void (*refreshFct)() = NULL; | |
38 | 222 |
508 | 223 |
224 switch(globState) | |
225 { | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
226 case (StMHARD3_O2_Sensor1): |
562
ec76fa85009e
Added ADC sensor interface to O2 sensore menu structure:
Ideenmodellierer
parents:
552
diff
changeset
|
227 case (StMHARD3_O2_Sensor1 & MaskFieldDigit): |
584 | 228 case (StMHARD3_O2_Calibrate): |
734
190e5814b2f5
Removed interface selection from sensor menu:
Ideenmodellierer
parents:
718
diff
changeset
|
229 case (StMHARD3_Sensor_Detect): |
190e5814b2f5
Removed interface selection from sensor menu:
Ideenmodellierer
parents:
718
diff
changeset
|
230 case (StMHARD3_Sensor_Info): refreshFct = refresh_O2Sensors; |
508 | 231 break; |
854 | 232 case (StMHARD2_Compass & MaskFieldDigit): |
774
6169309d6eb9
more menu items for the compass menu: Delete bearing, and reset to land based bearing. I have also re-enabled the real time bearing display in the menu - makes it easier to set the correct bearing. (mikeller)
heinrichsweikamp
parents:
734
diff
changeset
|
233 refreshFct = refresh_CompassEdit; |
6169309d6eb9
more menu items for the compass menu: Delete bearing, and reset to land based bearing. I have also re-enabled the real time bearing display in the menu - makes it easier to set the correct bearing. (mikeller)
heinrichsweikamp
parents:
734
diff
changeset
|
234 break; |
6169309d6eb9
more menu items for the compass menu: Delete bearing, and reset to land based bearing. I have also re-enabled the real time bearing display in the menu - makes it easier to set the correct bearing. (mikeller)
heinrichsweikamp
parents:
734
diff
changeset
|
235 case (StMXTRA_CompassHeading & MaskFieldDigit): |
6169309d6eb9
more menu items for the compass menu: Delete bearing, and reset to land based bearing. I have also re-enabled the real time bearing display in the menu - makes it easier to set the correct bearing. (mikeller)
heinrichsweikamp
parents:
734
diff
changeset
|
236 refreshFct = refresh_CompassHeading; |
6169309d6eb9
more menu items for the compass menu: Delete bearing, and reset to land based bearing. I have also re-enabled the real time bearing display in the menu - makes it easier to set the correct bearing. (mikeller)
heinrichsweikamp
parents:
734
diff
changeset
|
237 break; |
520 | 238 case (StMSYS4_Info & MaskFieldDigit): refreshFct = &refresh_InformationPage; |
508 | 239 break; |
240 case (StMPLAN5_ExitResult & MaskFieldDigit): refreshFct = refresh_PlanResult; | |
241 break; | |
242 case (StMHARD5_Button1 & MaskFieldDigit): // will not be executed in EditFieldMode as global state is different | |
243 refreshFct = refresh_ButtonValuesFromPIC; | |
244 break; | |
949 | 245 case StMSYS1_DateTime: refreshFct = refresh_DateTime; |
246 break; | |
508 | 247 case (StMSYS3_Units & MaskFieldDigit): refreshFct = refresh_Design; |
248 break; | |
520 | 249 case (StMCustom1_CViewTimeout & MaskFieldDigit):refreshFct = refresh_Customviews; |
508 | 250 break; |
531 | 251 case (StMCustom4_CViewSelection1 & MaskFieldDigit): |
252 case (StMCustom3_CViewSelection1 & MaskFieldDigit): | |
521
e221cf762f45
Move Bigfont and motion Ctrl selection menu out of custom view submenu:
Ideenmodellierer
parents:
520
diff
changeset
|
253 case StMCustom3_CViewSelection2: |
e221cf762f45
Move Bigfont and motion Ctrl selection menu out of custom view submenu:
Ideenmodellierer
parents:
520
diff
changeset
|
254 case StMCustom3_CViewSelection3: |
e221cf762f45
Move Bigfont and motion Ctrl selection menu out of custom view submenu:
Ideenmodellierer
parents:
520
diff
changeset
|
255 case StMCustom3_CViewSelection4: |
e221cf762f45
Move Bigfont and motion Ctrl selection menu out of custom view submenu:
Ideenmodellierer
parents:
520
diff
changeset
|
256 case StMCustom3_CViewSelection5: |
531 | 257 case StMCustom3_CViewSelection6: refreshFct = CustomviewDivemode_refresh; |
508 | 258 break; |
951 | 259 #ifdef ENABLE_MOTION_CONTROL |
604
fb5bb04ad914
Merged menu items of viewport and motion control:
Ideenmodellierer
parents:
584
diff
changeset
|
260 case (StMCustom5_CViewPortCalib & MaskFieldDigit): |
fb5bb04ad914
Merged menu items of viewport and motion control:
Ideenmodellierer
parents:
584
diff
changeset
|
261 case StMCustom5_CViewPortLayout: |
fb5bb04ad914
Merged menu items of viewport and motion control:
Ideenmodellierer
parents:
584
diff
changeset
|
262 case StMCustom5_CViewPortAmbient: refreshFct = refresh_ViewPort; |
552
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
263 break; |
951 | 264 #endif |
508 | 265 default: /* no menu has been updated */ |
266 break; | |
267 } | |
268 | |
269 if(refreshFct != NULL) | |
270 { | |
271 uint32_t rememberPage = tMEscreen.FBStartAdress; | |
272 tMEscreen.FBStartAdress = getFrame(9); | |
273 | |
274 refreshFct(); | |
275 | |
276 GFX_SetFrameTop(tMEscreen.FBStartAdress); | |
277 releaseFrame(9,rememberPage); | |
278 } | |
38 | 279 } |
280 | |
281 void tMenuEdit_writeSettingsToFlash(void) | |
282 { | |
283 if(WriteSettings) | |
284 { | |
662 | 285 reset_SettingWarning(); |
38 | 286 GFX_logoAutoOff(); |
427 | 287 ext_flash_write_settings(0); |
38 | 288 WriteSettings = 0; |
289 } | |
290 } | |
291 | |
292 void helperLeaveMenuEditField(uint8_t idID) | |
293 { | |
294 if(ident[idID].maintype == FIELD_NUMBERS) | |
295 { | |
296 change_CLUT_entry((CLUT_MenuEditField0 + idID), CLUT_MenuEditFieldRegular); | |
297 } | |
298 } | |
299 | |
300 | |
301 void helperGotoMenuEditField(uint8_t idID) | |
302 { | |
303 /* | |
304 if(ident[idID].maintype == FIELD_NUMBERS) | |
305 { | |
306 change_CLUT_entry((CLUT_MenuEditField0 + idID), CLUT_MenuEditFieldSelected); | |
307 } | |
308 */ | |
309 set_cursorNew(idID); | |
310 // set_cursor(idID); | |
311 } | |
312 | |
313 | |
314 void exitMenuEdit_to_BackMenu(void) | |
315 { | |
316 _Bool EnterPressedBackup = EnterPressed; | |
317 | |
318 if(backmenu.pEventFunction) | |
319 { | |
320 ((void (*)(uint8_t))(backmenu.pEventFunction))(backmenu.functionParameter); | |
321 | |
322 EnterPressed = EnterPressedBackup; | |
323 // if(backmenu.line > 1) | |
324 // helperGotoMenuEditField(backmenu.line); | |
325 } | |
326 } | |
327 | |
328 | |
329 void exitMenuEdit_to_Menu_with_Menu_Update(void) | |
330 { | |
331 EnterPressed = 1; | |
332 exitMenuEdit(1); | |
333 } | |
334 | |
335 | |
336 void exitMenuEdit_to_Menu_with_Menu_Update_do_not_write_settings_for_this_only(void) | |
337 { | |
338 EnterPressed = 1; | |
339 exitMenuEdit(0); | |
340 } | |
341 | |
342 | |
343 void exitMenuEdit_to_Home_with_Menu_Update(void) | |
344 { | |
345 EnterPressed = 1; | |
346 exitMenuEdit(1); | |
347 set_globalState_tHome(); | |
348 } | |
349 | |
350 | |
351 void exitMenuEdit_to_InfoCompassCalibration(void) | |
352 { | |
353 exitMenuEdit(1); | |
354 openInfo_Compass(); | |
355 } | |
356 | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
357 void exitMenuEdit_to_InfoSensor(void) |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
358 { |
783 | 359 uint32_t globState = get_globalState(); |
360 | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
361 exitMenuEdit(1); |
783 | 362 switch(globState) |
363 { | |
786 | 364 case (StMHARD3_O2_Sensor3): openInfo_Sensor(2); |
783 | 365 break; |
786 | 366 case (StMHARD3_O2_Sensor2): openInfo_Sensor(1); |
783 | 367 break; |
368 default: | |
786 | 369 case (StMHARD3_O2_Sensor1): openInfo_Sensor(0); |
783 | 370 break; |
371 } | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
372 } |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
373 |
38 | 374 |
375 void exitMenuEdit_to_Home(void) | |
376 { | |
377 exitMenuEdit(1); | |
378 set_globalState_tHome(); | |
379 } | |
380 | |
381 | |
382 void exitMenuEdit(uint8_t writeSettingsIfEnterPressed) | |
383 { | |
384 openMenu(0); | |
385 if(EnterPressed) | |
386 { | |
387 updateMenu(); | |
388 if((stateUsed->mode == MODE_SURFACE) && writeSettingsIfEnterPressed) | |
389 WriteSettings = 1; | |
390 } | |
391 releaseFrame(9,tMEscreen.FBStartAdress); | |
392 } | |
393 | |
394 | |
395 void exitMenuEditBackMenuOption(void) | |
396 { | |
397 if(backmenu.pEventFunction == 0) | |
398 exitMenuEdit(1); | |
399 else | |
400 exitMenuEdit_to_BackMenu(); | |
401 } | |
402 | |
403 | |
404 void startMenuEditFieldSelect(void) | |
405 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
406 actualId = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
407 helperGotoMenuEditField(actualId); |
38 | 408 } |
409 | |
410 | |
411 void nextMenuEditField(void) | |
412 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
413 helperLeaveMenuEditField(actualId); |
38 | 414 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
415 if(actualId < idLast) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
416 actualId++; |
38 | 417 else |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
418 actualId = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
419 helperGotoMenuEditField(actualId); |
38 | 420 } |
421 | |
422 /* | |
423 void previousMenuEditField(void) | |
424 { | |
425 helperLeaveMenuEditField(id); | |
426 if(id > 0) | |
427 id--; | |
428 else | |
429 id = idLast; | |
430 helperGotoMenuEditField(id); | |
431 } | |
432 */ | |
433 | |
434 _Bool inc_subBlock_or_block_of_actual_id(void) | |
435 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
436 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 437 return 0; |
438 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
439 if((ident[actualId].subtype != FIELD_3DIGIT) && (ident[actualId].subtype != FIELD_2DIGIT) && ((subBlockPosition + 1) < ident[actualId].size[block])) |
38 | 440 { |
441 subBlockPosition++; | |
442 return 1; | |
443 } | |
444 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
445 if(((block + 1) < 4) && (ident[actualId].size[block+1] > 0)) |
38 | 446 { |
447 block++; | |
448 subBlockPosition = 0; | |
449 return 1; | |
450 } | |
451 | |
452 return 0; | |
453 } | |
454 | |
455 | |
456 uint8_t get_newContent_of_actual_id_block_and_subBlock(uint8_t action) | |
457 { | |
458 uint8_t (*onActionFunc)(uint32_t, uint8_t, uint8_t, uint8_t, uint8_t); | |
459 uint8_t content; | |
460 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
461 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 462 return 0; |
463 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
464 onActionFunc = (uint8_t (*)(uint32_t, uint8_t, uint8_t, uint8_t, uint8_t))(event[actualevid].pEventFunction); |
38 | 465 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
466 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_3DIGIT)) |
38 | 467 { |
854 | 468 content = 100 * ( ident[actualId].newText[ident[actualId].begin[block] + 0] - '0'); |
469 content += 10 * ( ident[actualId].newText[ident[actualId].begin[block] + 1] - '0'); | |
470 content += ident[actualId].newText[ident[actualId].begin[block] + 2]; | |
38 | 471 } |
472 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
473 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_2DIGIT)) |
38 | 474 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
475 content = 10 * (ident[actualId].newText[ident[actualId].begin[block] + 0] - '0'); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
476 content += ident[actualId].newText[ident[actualId].begin[block] + 1]; |
38 | 477 } |
478 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
479 if(ident[actualId].maintype == FIELD_NUMBERS) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
480 content = ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition]; |
38 | 481 else |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
482 if((ident[actualId].maintype == FIELD_ON_OFF) || (ident[actualId].maintype == FIELD_TOGGLE)) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
483 content = ident[actualId].input[block]; |
38 | 484 else |
485 content = 0; /* just a default for protection */ | |
486 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
487 return onActionFunc(ident[actualId].callerID, block, subBlockPosition, content, action); |
38 | 488 } |
489 | |
490 void mark_digit_of_actual_id_with_this_block_and_subBlock(int8_t oldblock, int8_t oldsubblockpos) | |
491 { | |
492 char oneCharText[2]; | |
493 uint16_t positionOffset; | |
494 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
495 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 496 return; |
497 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
498 if(ident[actualId].maintype == FIELD_NUMBERS) |
38 | 499 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
500 oneCharText[0] = ident[actualId].newText[ident[actualId].begin[oldblock] + oldsubblockpos]; |
38 | 501 oneCharText[1] = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
502 positionOffset = GFX_return_offset(ident[actualId].fontUsed, ident[actualId].newText, ident[actualId].begin[oldblock] + oldsubblockpos); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
503 write_content( ident[actualId].coord[0] + positionOffset, ident[actualId].coord[1], ident[actualId].coord[2], ident[actualId].fontUsed, oneCharText, CLUT_MenuEditFieldSelected); |
38 | 504 } |
505 } | |
506 | |
507 | |
508 void mark_new_2digit_of_actual_id_block(void) | |
509 { | |
510 char oneCharText[3]; | |
511 uint16_t positionOffset; | |
512 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
513 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 514 return; |
515 | |
854 | 516 if(ident[actualId].maintype == FIELD_NUMBERS) |
38 | 517 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
518 oneCharText[0] = ident[actualId].newText[ident[actualId].begin[block] + 0]; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
519 oneCharText[1] = ident[actualId].newText[ident[actualId].begin[block] + 1]; |
38 | 520 oneCharText[2] = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
521 positionOffset = GFX_return_offset(ident[actualId].fontUsed, ident[actualId].newText, ident[actualId].begin[block] + 0); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
522 write_content( ident[actualId].coord[0] + positionOffset, ident[actualId].coord[1], ident[actualId].coord[2], ident[actualId].fontUsed, oneCharText, CLUT_MenuEditDigit); |
38 | 523 } |
524 } | |
525 | |
526 | |
527 void mark_new_3digit_of_actual_id_block(void) | |
528 { | |
529 char oneCharText[4]; | |
530 uint16_t positionOffset; | |
531 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
532 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 533 return; |
534 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
535 if(ident[actualId].maintype == FIELD_NUMBERS) |
38 | 536 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
537 oneCharText[0] = ident[actualId].newText[ident[actualId].begin[block] + 0]; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
538 oneCharText[1] = ident[actualId].newText[ident[actualId].begin[block] + 1]; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
539 oneCharText[2] = ident[actualId].newText[ident[actualId].begin[block] + 2]; |
38 | 540 oneCharText[3] = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
541 positionOffset = GFX_return_offset(ident[actualId].fontUsed, ident[actualId].newText, ident[actualId].begin[block] + 0); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
542 write_content( ident[actualId].coord[0] + positionOffset, ident[actualId].coord[1], ident[actualId].coord[2], ident[actualId].fontUsed, oneCharText, CLUT_MenuEditDigit); |
38 | 543 } |
544 } | |
545 | |
546 | |
547 void mark_new_digit_of_actual_id_block_and_subBlock(void) | |
548 { | |
549 char oneCharText[2]; | |
550 uint16_t positionOffset; | |
551 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
552 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 553 return; |
554 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
555 if(ident[actualId].maintype == FIELD_NUMBERS) |
38 | 556 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
557 oneCharText[0] = ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition]; |
38 | 558 oneCharText[1] = 0; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
559 positionOffset = GFX_return_offset(ident[actualId].fontUsed, ident[actualId].newText, ident[actualId].begin[block] + subBlockPosition); |
854 | 560 write_content( ident[actualId].coord[0] + positionOffset, ident[actualId].coord[1], ident[actualId].coord[2], ident[actualId].fontUsed, oneCharText, CLUT_MenuEditDigit); |
38 | 561 } |
562 } | |
563 | |
564 | |
565 void enterMenuEditField(void) | |
566 { | |
567 uint8_t newContent; | |
568 uint8_t digit100; | |
569 uint8_t digit10; | |
570 uint8_t digit1; | |
571 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
572 actualevid = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
573 while((actualevid < evidLast) && (event[actualevid].callerID != ident[actualId].callerID)) |
38 | 574 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
575 actualevid++; |
38 | 576 } |
577 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
578 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 579 return; |
580 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
581 set_globalState(event[actualevid].callerID); |
38 | 582 block = 0; |
583 subBlockPosition = 0; | |
584 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
585 if(ident[actualId].maintype == FIELD_NUMBERS) |
38 | 586 { |
587 change_CLUT_entry(CLUT_MenuEditLineSelected, CLUT_MenuEditCursor); | |
588 // old stuff? hw 150916, reactivated 150923, this shows which digit will be changed now as it marks the other grey/black | |
589 // now fixed for button settings with newContent <= '0'+99 condition | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
590 change_CLUT_entry((CLUT_MenuEditField0 + actualId), CLUT_MenuEditFieldSelected); |
38 | 591 } |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
592 if(ident[actualId].maintype == FIELD_TOGGLE) |
584 | 593 { |
594 change_CLUT_entry(CLUT_MenuEditLineSelected, CLUT_MenuEditCursor); | |
595 } | |
596 | |
38 | 597 |
598 newContent = get_newContent_of_actual_id_block_and_subBlock(ACTION_BUTTON_ENTER); | |
599 | |
600 if (((newContent == UPDATE_DIVESETTINGS) || (newContent == UPDATE_AND_EXIT_TO_HOME) || (newContent == UPDATE_AND_EXIT_TO_MENU)) && (actual_menu_content == MENU_SURFACE)) | |
601 createDiveSettings(); | |
602 | |
603 if(newContent == EXIT_TO_MENU_WITH_LOGO) | |
604 { | |
605 GFX_logoAutoOff(); | |
606 } | |
607 | |
608 if((newContent == EXIT_TO_MENU) || (newContent == UPDATE_AND_EXIT_TO_MENU) || (newContent == EXIT_TO_MENU_WITH_LOGO)) | |
609 { | |
610 if(backmenu.pEventFunction == 0) | |
611 exitMenuEdit(1); | |
612 else | |
613 exitMenuEdit_to_BackMenu(); | |
614 return; | |
615 } | |
616 | |
617 if((newContent == EXIT_TO_HOME) || (newContent == UPDATE_AND_EXIT_TO_HOME)) | |
618 { | |
619 exitMenuEdit_to_Home(); | |
620 return; | |
621 } | |
622 | |
623 if(newContent == EXIT_TO_INFO_COMPASS) | |
624 { | |
625 exitMenuEdit_to_InfoCompassCalibration(); | |
626 return; | |
627 } | |
628 | |
718
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
629 if(newContent == EXIT_TO_INFO_SENSOR) |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
630 { |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
631 exitMenuEdit_to_InfoSensor(); |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
632 return; |
b9f699d2e3d0
Updated menu structure to support new sensor information page:
Ideenmodellierer
parents:
707
diff
changeset
|
633 } |
38 | 634 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
635 switch(ident[actualId].maintype) |
38 | 636 { |
637 case FIELD_NUMBERS: | |
638 write_buttonTextline(TXT2BYTE_ButtonMinus,TXT2BYTE_ButtonEnter,TXT2BYTE_ButtonPlus); | |
639 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
640 switch (ident[actualId].subtype) { |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
641 case FIELD_UDIGIT: |
38 | 642 if((newContent >= '0') && (newContent <= '9')) |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
643 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
38 | 644 |
645 mark_new_digit_of_actual_id_block_and_subBlock(); | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
646 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
647 break; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
648 case FIELD_3DIGIT: |
38 | 649 if((newContent >= '0') && (newContent <= '0'+200)) |
650 { | |
651 split_Content_to_Digit_helper( newContent, &digit100, &digit10, &digit1); | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
652 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + digit100; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
653 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + digit10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
654 ident[actualId].newText[ident[actualId].begin[block] + 2] = '0' + digit1; |
38 | 655 mark_new_3digit_of_actual_id_block(); |
656 } | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
657 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
658 break; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
659 case FIELD_2DIGIT: |
38 | 660 if((newContent >= '0') && (newContent <= '0'+99)) |
661 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
662 ident[actualId].newText[ident[actualId].begin[block]] = '0' + (newContent - '0')/10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
663 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + ((newContent - '0') - (10*((newContent - '0')/10))); |
38 | 664 mark_new_2digit_of_actual_id_block(); |
665 } | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
666 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
667 break; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
668 case FIELD_SDIGIT: |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
669 if ((subBlockPosition == 0 && (newContent == '+' || newContent == '-')) || (subBlockPosition > 0 && newContent >= '0' && newContent <= '9')) { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
670 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
671 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
672 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
673 mark_new_digit_of_actual_id_block_and_subBlock(); |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
674 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
675 break; |
38 | 676 } |
677 break; | |
678 case FIELD_BUTTON: | |
679 case FIELD_ON_OFF: | |
680 set_globalState(menuID); | |
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
681 |
38 | 682 break; |
683 case FIELD_SYMBOL: | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
684 ident[actualId].input[0] += 1; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
685 if(ident[actualId].input[0] >= ident[actualId].input[1]) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
686 ident[actualId].input[0] = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
687 ident[actualId].newText[0] = ident[actualId].orgText[ident[actualId].input[0]]; |
38 | 688 write_content_of_actual_Id(); |
689 set_globalState(menuID); | |
690 break; | |
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
691 case FIELD_SELECT: |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
692 write_buttonTextline(TXT2BYTE_ButtonMinus, TXT2BYTE_ButtonEnter, TXT2BYTE_ButtonPlus); |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
693 |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
694 break; |
38 | 695 } |
696 } | |
697 | |
698 | |
699 void exitMenuEditField(void) | |
700 { | |
701 uint8_t newContent; | |
702 | |
703 set_globalState(menuID); | |
704 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
705 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 706 return; |
707 | |
708 newContent = get_newContent_of_actual_id_block_and_subBlock(ACTION_TIMEOUT); | |
709 | |
710 /* | |
711 uint8_t (*onActionFunc)(uint32_t, uint8_t, uint8_t, uint8_t, uint8_t); | |
712 uint8_t newContent; | |
713 | |
714 onActionFunc = (uint8_t (*)(uint32_t, uint8_t, uint8_t, uint8_t, uint8_t))(event[evid].pEventFunction); | |
715 | |
716 newContent = onActionFunc(ident[id].callerID, 0, 0, 255, ACTION_BUTTON_BACK); | |
717 */ | |
718 | |
719 /* destroy changes of editing in newText */ | |
720 change_CLUT_entry(CLUT_MenuEditLineSelected, CLUT_MenuLineSelected); | |
721 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
722 | |
723 create_newText_for_actual_Id(); | |
724 write_content_of_actual_Id(); | |
725 | |
726 if((newContent == EXIT_TO_MENU) || (newContent == UPDATE_AND_EXIT_TO_MENU)) | |
727 { | |
728 exitMenuEdit(1); | |
729 return; | |
730 } | |
731 | |
732 if((newContent == EXIT_TO_HOME) || (newContent == UPDATE_AND_EXIT_TO_HOME)) | |
733 { | |
734 exitMenuEdit_to_Home(); | |
735 return; | |
736 } | |
737 | |
738 } | |
739 | |
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
740 |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
741 static void startNextEdit(void) |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
742 { |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
743 EnterPressed = 1; |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
744 nextMenuEditField(); |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
745 enterMenuEditField(); |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
746 } |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
747 |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
748 |
38 | 749 void nextMenuEditFieldDigit(void) |
750 { | |
751 uint8_t action; | |
752 uint8_t newContent; | |
753 int8_t blockOld = 0; | |
754 int8_t subBlockPositionOld = 0; | |
755 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
756 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 757 return; |
758 | |
759 blockOld = block; | |
760 subBlockPositionOld = subBlockPosition; | |
761 | |
762 if(inc_subBlock_or_block_of_actual_id()) | |
763 action = ACTION_BUTTON_ENTER; | |
764 else | |
765 action = ACTION_BUTTON_ENTER_FINAL; | |
766 | |
767 newContent = get_newContent_of_actual_id_block_and_subBlock(action); | |
768 | |
769 if(action == ACTION_BUTTON_ENTER_FINAL) | |
770 { | |
771 write_buttonTextline(TXT2BYTE_ButtonBack,TXT2BYTE_ButtonEnter,TXT2BYTE_ButtonNext); | |
772 | |
773 change_CLUT_entry(CLUT_MenuEditLineSelected, CLUT_MenuLineSelected); | |
774 for(int i = 0;i<=9;i++) | |
775 change_CLUT_entry((CLUT_MenuEditField0 + i), CLUT_MenuEditFieldRegular); | |
776 | |
777 if(((newContent == UPDATE_DIVESETTINGS) || (newContent == UPDATE_AND_EXIT_TO_HOME) || (newContent == UPDATE_AND_EXIT_TO_MENU)) && (actual_menu_content == MENU_SURFACE)) | |
778 createDiveSettings(); | |
779 | |
780 if((newContent == EXIT_TO_MENU) || (newContent == UPDATE_AND_EXIT_TO_MENU)) | |
781 { | |
782 exitMenuEdit(1); | |
783 return; | |
784 } | |
785 | |
786 if((newContent == EXIT_TO_HOME) || (newContent == UPDATE_AND_EXIT_TO_HOME)) | |
787 { | |
788 exitMenuEdit_to_Home(); | |
789 return; | |
790 } | |
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
791 |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
792 if (newContent == EXIT_TO_NEXT_MENU) { |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
793 startNextEdit(); |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
794 |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
795 return; |
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
796 } |
38 | 797 } |
798 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
799 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_3DIGIT) && (action == ACTION_BUTTON_ENTER) &&(newContent >= '0') && (newContent <= '0' + 99)) |
38 | 800 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
801 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + (newContent - '0')/100; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
802 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + (newContent - '0')/10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
803 ident[actualId].newText[ident[actualId].begin[block] + 2] = '0' + ((newContent - '0') - (10*((newContent - '0')/10))); |
38 | 804 } |
805 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
806 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_2DIGIT) && (action == ACTION_BUTTON_ENTER) &&(newContent >= '0') && (newContent <= '0' + 99)) |
38 | 807 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
808 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + (newContent - '0')/10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
809 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + ((newContent - '0') - (10*((newContent - '0')/10))); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
810 } else if (ident[actualId].maintype == FIELD_NUMBERS && ident[actualId].subtype == FIELD_SDIGIT && action == ACTION_BUTTON_ENTER && subBlockPosition == 0) { |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
811 if (newContent == '+' || newContent == '-') { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
812 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
813 } |
38 | 814 } |
815 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
816 if((ident[actualId].maintype == FIELD_NUMBERS) && (action == ACTION_BUTTON_ENTER) && (newContent >= '0') && (newContent <= '9')) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
817 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
38 | 818 |
819 if(action == ACTION_BUTTON_ENTER) | |
820 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
821 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_3DIGIT)) |
38 | 822 { |
823 mark_new_3digit_of_actual_id_block(); | |
824 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,0); | |
825 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,1); | |
826 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,2); | |
827 } | |
828 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
829 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_2DIGIT)) |
38 | 830 { |
831 mark_new_2digit_of_actual_id_block(); | |
832 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,0); | |
833 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,1); | |
834 } | |
835 else | |
836 { | |
837 mark_new_digit_of_actual_id_block_and_subBlock(); | |
838 mark_digit_of_actual_id_with_this_block_and_subBlock(blockOld,subBlockPositionOld); | |
839 } | |
840 } | |
841 else /* action == ACTION_BUTTON_ENTER_FINAL */ | |
842 set_globalState(menuID); | |
843 } | |
844 | |
845 uint8_t split_Content_to_Digit_helper(uint8_t inContentAscii, uint8_t *outDigit100, uint8_t *outDigit10, uint8_t *outDigit1) | |
846 { | |
847 uint8_t newContent, tempDigit, CopyContent; | |
848 | |
849 newContent = inContentAscii - '0'; | |
850 CopyContent = newContent; | |
851 | |
852 tempDigit = newContent / 100; | |
853 newContent -= tempDigit * 100; | |
854 if(outDigit100) | |
855 *outDigit100 = tempDigit; | |
856 | |
857 tempDigit = newContent / 10; | |
858 newContent -= tempDigit * 10; | |
859 if(outDigit10) | |
860 *outDigit10 = tempDigit; | |
861 | |
862 tempDigit = newContent; | |
863 if(outDigit1) | |
864 *outDigit1 = tempDigit; | |
865 | |
866 return CopyContent; | |
867 } | |
868 | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
869 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
870 static void checkUpdateSDigit(uint8_t newContent) |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
871 { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
872 if ((subBlockPosition == 0 && (newContent == '+' || newContent == '-')) || (subBlockPosition > 0 && newContent >= '0' && newContent <= '9')) { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
873 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
874 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
875 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
876 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
877 |
38 | 878 void upMenuEditFieldDigit(void) |
879 { | |
880 uint8_t newContent; | |
881 uint8_t digit100; | |
882 uint8_t digit10; | |
883 uint8_t digit1; | |
884 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
885 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 886 return; |
887 | |
888 newContent = get_newContent_of_actual_id_block_and_subBlock(ACTION_BUTTON_NEXT); | |
889 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
890 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_3DIGIT) &&(newContent >= '0') && (newContent <= '0' + 200)) |
38 | 891 { |
892 split_Content_to_Digit_helper( newContent, &digit100, &digit10, &digit1); | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
893 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + digit100; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
894 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + digit10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
895 ident[actualId].newText[ident[actualId].begin[block] + 2] = '0' + digit1; |
38 | 896 mark_new_3digit_of_actual_id_block(); |
897 return; | |
898 } | |
899 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
900 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_2DIGIT) &&(newContent >= '0') && (newContent <= '0' + 99)) |
38 | 901 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
902 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + (newContent - '0')/10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
903 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + ((newContent - '0') - (10*((newContent - '0')/10))); |
38 | 904 mark_new_2digit_of_actual_id_block(); |
905 return; | |
906 } | |
907 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
908 if (ident[actualId].maintype == FIELD_NUMBERS && ident[actualId].subtype == FIELD_SDIGIT) { |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
909 checkUpdateSDigit(newContent); |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
910 } else if (ident[actualId].maintype == FIELD_NUMBERS && newContent >= '0' && newContent <= '9') { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
911 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
912 } |
38 | 913 |
914 mark_new_digit_of_actual_id_block_and_subBlock(); | |
915 } | |
916 | |
917 | |
918 void downMenuEditFieldDigit(void) | |
919 { | |
920 uint8_t newContent; | |
921 uint8_t digit100; | |
922 uint8_t digit10; | |
923 uint8_t digit1; | |
924 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
925 if(event[actualevid].callerID != ident[actualId].callerID) |
38 | 926 return; |
927 | |
928 newContent = get_newContent_of_actual_id_block_and_subBlock(ACTION_BUTTON_BACK); | |
929 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
930 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_3DIGIT) &&(newContent >= '0') && (newContent <= '0' + 200)) |
38 | 931 { |
932 split_Content_to_Digit_helper( newContent, &digit100, &digit10, &digit1); | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
933 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + digit100; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
934 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + digit10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
935 ident[actualId].newText[ident[actualId].begin[block] + 2] = '0' + digit1; |
38 | 936 mark_new_3digit_of_actual_id_block(); |
937 return; | |
938 } | |
939 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
940 if((ident[actualId].maintype == FIELD_NUMBERS) && (ident[actualId].subtype == FIELD_2DIGIT) &&(newContent >= '0') && (newContent <= '0' + 99)) |
38 | 941 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
942 ident[actualId].newText[ident[actualId].begin[block] + 0] = '0' + (newContent - '0')/10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
943 ident[actualId].newText[ident[actualId].begin[block] + 1] = '0' + ((newContent - '0') - (10*((newContent - '0')/10))); |
38 | 944 mark_new_2digit_of_actual_id_block(); |
945 return; | |
946 } | |
947 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
948 if (ident[actualId].maintype == FIELD_NUMBERS && ident[actualId].subtype == FIELD_SDIGIT) { |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
949 checkUpdateSDigit(newContent); |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
950 } else if (ident[actualId].maintype == FIELD_NUMBERS && newContent >= '0' && newContent <= '9') { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
951 ident[actualId].newText[ident[actualId].begin[block] + subBlockPosition] = newContent; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
952 } |
38 | 953 |
954 mark_new_digit_of_actual_id_block_and_subBlock(); | |
955 } | |
956 | |
957 | |
958 void evaluateNewString(uint32_t editID, uint32_t *pNewValue1, uint32_t *pNewValue2, uint32_t *pNewValue3, uint32_t *pNewValue4) | |
959 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
960 if(editID != ident[actualId].callerID) |
38 | 961 return; |
962 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
963 bool isSigned = ident[actualId].maintype == FIELD_NUMBERS && ident[actualId].subtype == FIELD_SDIGIT; |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
964 |
38 | 965 uint8_t i, digitCount, digit; |
966 uint32_t sum[4], multiplier; | |
967 | |
968 for(i=0;i<4;i++) | |
969 sum[i] = 0; | |
970 | |
971 i = 0; | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
972 while( ident[actualId].size[i] && (i < 4)) |
38 | 973 { |
974 multiplier = 1; | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
975 for(digitCount = 1; digitCount < ident[actualId].size[i]; digitCount++) |
38 | 976 multiplier *= 10; |
977 | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
978 bool isNegative = false; |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
979 for(digitCount = 0; digitCount < ident[actualId].size[i]; digitCount++) |
38 | 980 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
981 digit = ident[actualId].newText[ident[actualId].begin[i] + digitCount]; |
38 | 982 |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
983 if (isSigned && digitCount == 0) { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
984 if (digit == '-') { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
985 isNegative = true; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
986 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
987 } else { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
988 if(digit > '0') |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
989 digit -= '0'; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
990 else |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
991 digit = 0; |
38 | 992 |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
993 if(digit > 9) |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
994 digit = 9; |
38 | 995 |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
996 sum[i] += digit * multiplier; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
997 } |
38 | 998 |
999 if(multiplier >= 10) | |
1000 multiplier /= 10; | |
1001 else | |
1002 multiplier = 0; | |
1003 } | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1004 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1005 if (isSigned) { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1006 int32_t value = sum[i]; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1007 if (isNegative) { |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1008 value = -value; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1009 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1010 sum[i] = ((input_u)value).uint32; |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1011 } |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1012 |
38 | 1013 i++; |
1014 } | |
1015 | |
1016 *pNewValue1 = sum[0]; | |
1017 *pNewValue2 = sum[1]; | |
1018 *pNewValue3 = sum[2]; | |
1019 *pNewValue4 = sum[3]; | |
1020 } | |
1021 | |
1022 | |
1023 uint8_t get_id_of(uint32_t editID) | |
1024 { | |
1025 uint8_t temp_id; | |
1026 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1027 if(editID == ident[actualId].callerID) |
854 | 1028 return actualId; |
38 | 1029 else |
1030 { | |
1031 temp_id = 0; | |
1032 while((temp_id < 9) && (editID != ident[temp_id].callerID)) | |
1033 temp_id++; | |
1034 if(editID != ident[temp_id].callerID) | |
1035 temp_id = 255; | |
1036 return temp_id; | |
1037 } | |
1038 } | |
1039 | |
1040 | |
1041 void tMenuEdit_newButtonText(uint32_t editID, char *text) | |
1042 { | |
1043 uint8_t backup_id, temp_id; | |
1044 | |
1045 temp_id = get_id_of(editID); | |
1046 if(temp_id == 255) | |
1047 return; | |
1048 | |
1049 backup_id = id; | |
1050 id = temp_id; | |
1051 | |
1052 strncpy(ident[id].newText, text, 32); | |
1053 ident[id].newText[31] = 0; | |
1054 | |
854 | 1055 clean_content_of_Id(id); |
1056 write_content_of_Id(id); | |
38 | 1057 |
1058 id = backup_id; | |
1059 } | |
1060 | |
1061 | |
1062 void tMenuEdit_set_on_off(uint32_t editID, uint32_t int1) | |
1063 { | |
1064 uint8_t backup_id, temp_id; | |
1065 | |
1066 temp_id = get_id_of(editID); | |
1067 if(temp_id == 255) | |
1068 return; | |
1069 | |
1070 backup_id = id; | |
1071 id = temp_id; | |
1072 | |
1073 ident[id].input[0] = int1; | |
1074 | |
1075 if(int1) | |
1076 ident[id].newText[0] = '\005'; | |
1077 else | |
1078 ident[id].newText[0] = '\006'; | |
1079 | |
854 | 1080 clean_content_of_Id(id); |
1081 write_content_of_Id(id); | |
38 | 1082 |
1083 id = backup_id; | |
1084 } | |
1085 | |
508 | 1086 void tMenuEdit_select(uint32_t editID) |
1087 { | |
1088 uint8_t id_local = 0; | |
1089 id_local = get_id_of(editID); | |
38 | 1090 |
508 | 1091 if(id_local <= idLast) |
1092 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1093 actualId = id_local; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1094 set_cursorNew(id_local); |
508 | 1095 } |
1096 } | |
1097 | |
1098 #if OLD_SELECTION | |
38 | 1099 void tMenuEdit_select(uint32_t editID, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) |
1100 { | |
1101 if(int1 > 4) | |
1102 return; | |
1103 | |
1104 uint8_t backup_id, temp_id; | |
1105 | |
1106 temp_id = get_id_of(editID); | |
1107 if(temp_id == 255) | |
1108 return; | |
1109 | |
1110 backup_id = id; | |
1111 id = temp_id; | |
1112 | |
1113 ident[id].input[0] = int1; | |
1114 ident[id].input[1] = int1; | |
1115 ident[id].input[2] = int1; | |
1116 ident[id].input[3] = int1; | |
1117 | |
1118 create_newText_for_actual_Id(); | |
1119 clean_content_of_actual_Id(); | |
1120 write_content_of_actual_Id(); | |
1121 | |
1122 id = backup_id; | |
1123 } | |
508 | 1124 #endif |
38 | 1125 |
1126 | |
1127 void tMenuEdit_newInput(uint32_t editID, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) | |
1128 { | |
1129 uint8_t backup_id, temp_id; | |
1130 | |
1131 temp_id = get_id_of(editID); | |
1132 if(temp_id == 255) | |
1133 return; | |
1134 | |
1135 backup_id = id; | |
1136 id = temp_id; | |
1137 | |
1138 if(editID != ident[id].callerID) | |
1139 { | |
1140 temp_id = 0; | |
1141 while((temp_id < 9) && (editID != ident[temp_id].callerID)) | |
1142 temp_id++; | |
1143 if(editID != ident[temp_id].callerID) | |
1144 return; | |
1145 id = temp_id; | |
1146 } | |
1147 ident[id].input[0] = int1; | |
1148 ident[id].input[1] = int2; | |
1149 ident[id].input[2] = int3; | |
1150 ident[id].input[3] = int4; | |
1151 | |
854 | 1152 create_newText_for_Id(id); |
38 | 1153 if(id <= idLast) |
1154 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
854 | 1155 write_content_of_Id(id); |
38 | 1156 |
1157 id = backup_id; | |
1158 } | |
1159 | |
1160 | |
1161 void resetEnterPressedToStateBeforeButtonAction(void) | |
1162 { | |
1163 EnterPressed = EnterPressedBeforeButtonAction; | |
1164 } | |
1165 | |
1166 | |
1167 void sendActionToMenuEdit(uint8_t sendAction) | |
1168 { | |
1169 if(get_globalState() == menuID) | |
1170 { | |
1171 switch(sendAction) | |
1172 { | |
1173 case ACTION_BUTTON_ENTER: | |
1174 EnterPressedBeforeButtonAction = EnterPressed; | |
1175 EnterPressed = 1; | |
1176 enterMenuEditField(); | |
1177 break; | |
1178 case ACTION_BUTTON_NEXT: | |
1179 nextMenuEditField(); | |
1180 // previousMenuEditField(); | |
1181 break; | |
1182 case ACTION_BUTTON_BACK: | |
1183 exitMenuEditBackMenuOption(); | |
1184 break; | |
1185 case ACTION_TIMEOUT: | |
1186 case ACTION_MODE_CHANGE: | |
1187 exitMenuEdit(1); | |
1188 break; | |
1189 case ACTION_IDLE_TICK: | |
1190 case ACTION_IDLE_SECOND: | |
219 | 1191 default: |
38 | 1192 break; |
219 | 1193 |
38 | 1194 } |
1195 } | |
1196 else | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1197 if(get_globalState() == event[actualevid].callerID) |
38 | 1198 { |
1199 switch(sendAction) | |
1200 { | |
1201 case ACTION_BUTTON_ENTER: | |
1202 nextMenuEditFieldDigit(); | |
1203 break; | |
1204 case ACTION_BUTTON_NEXT: | |
1205 upMenuEditFieldDigit(); | |
1206 break; | |
1207 case ACTION_BUTTON_BACK: | |
1208 downMenuEditFieldDigit(); | |
1209 break; | |
1210 case ACTION_TIMEOUT: | |
1211 case ACTION_MODE_CHANGE: | |
1212 exitMenuEditField(); | |
1213 break; | |
1214 case ACTION_IDLE_TICK: | |
1215 case ACTION_IDLE_SECOND: | |
1216 break; | |
219 | 1217 default: |
1218 break; | |
38 | 1219 } |
1220 } | |
1221 else | |
1222 { | |
1223 switch(sendAction) | |
1224 { | |
1225 case ACTION_BUTTON_ENTER: | |
1226 break; | |
1227 case ACTION_BUTTON_NEXT: | |
1228 break; | |
1229 case ACTION_BUTTON_BACK: | |
1230 break; | |
1231 case ACTION_TIMEOUT: | |
1232 case ACTION_MODE_CHANGE: | |
1233 exitMenuEdit(1); | |
1234 break; | |
1235 case ACTION_IDLE_TICK: | |
1236 case ACTION_IDLE_SECOND: | |
1237 break; | |
219 | 1238 default: |
1239 break; | |
38 | 1240 } |
1241 } | |
1242 } | |
1243 | |
1244 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1245 void create_newText_for_Id_and_field_select(int8_t localId) |
38 | 1246 { |
1247 uint8_t i; | |
1248 | |
1249 i = 0; | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1250 while( ident[localId].size[i] && (i < 4)) |
38 | 1251 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1252 if(ident[localId].input[i]) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1253 ident[localId].newText[ident[localId].begin[i]] = '\005'; |
38 | 1254 else |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1255 ident[localId].newText[ident[localId].begin[i]] = '\006'; |
38 | 1256 i++; |
1257 } | |
1258 } | |
1259 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1260 void create_newText_for_actual_Id_and_field_select(void) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1261 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1262 create_newText_for_Id_and_field_select(actualId); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1263 } |
38 | 1264 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1265 void create_newText_for_Id(int8_t localId) |
38 | 1266 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1267 bool isSigned = ident[localId].maintype == FIELD_NUMBERS && ident[localId].subtype == FIELD_SDIGIT; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1268 |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1269 uint8_t i, digitCount; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1270 uint32_t remainder, digit, divider; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1271 i = 0; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1272 |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1273 if( ident[localId].maintype == FIELD_SELECT) |
38 | 1274 { |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1275 create_newText_for_Id_and_field_select(localId); |
38 | 1276 return; |
1277 } | |
1278 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1279 while( ident[localId].size[i] && (i < 4)) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1280 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1281 bool isNegative = false; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1282 if (isSigned) { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1283 int32_t value = ((input_u)ident[localId].input[i]).int32; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1284 if (value < 0) { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1285 isNegative = true; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1286 } |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1287 remainder = abs(value); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1288 } else { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1289 remainder = ident[localId].input[i]; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1290 } |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1291 divider = 1; |
38 | 1292 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1293 for(digitCount = 1; digitCount < ident[localId].size[i]; digitCount++) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1294 divider *= 10; |
38 | 1295 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1296 for(digitCount = 0; digitCount < ident[localId].size[i]; digitCount++) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1297 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1298 if (isSigned && digitCount == 0) { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1299 ident[localId].newText[ident[localId].begin[i] + digitCount] = isNegative ? '-' : '+'; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1300 } else { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1301 digit = remainder / divider; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1302 remainder -= digit * divider; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1303 if(digit < 10) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1304 ident[localId].newText[ident[localId].begin[i] + digitCount] = digit + '0'; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1305 else |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1306 ident[localId].newText[ident[localId].begin[i] + digitCount] = 'x'; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1307 } |
38 | 1308 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1309 divider /= 10; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1310 } |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1311 i++; |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1312 } |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1313 } |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1314 |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1315 void create_newText_for_actual_Id(void) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1316 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1317 create_newText_for_Id(actualId); |
38 | 1318 } |
1319 | |
1320 | |
1321 void write_content_without_Id(void) | |
1322 { | |
1323 write_content( ident[id].coord[0], ident[id].coord[1], ident[id].coord[2], ident[id].fontUsed, ident[id].newText, CLUT_MenuEditFieldRegular); | |
1324 } | |
1325 | |
1326 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1327 void write_content_of_Id(int8_t localId) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1328 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1329 write_content( ident[localId].coord[0], ident[localId].coord[1], ident[localId].coord[2], ident[localId].fontUsed, ident[localId].newText, (CLUT_MenuEditField0 + localId)); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1330 } |
38 | 1331 void write_content_of_actual_Id(void) |
1332 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1333 write_content_of_Id(actualId); |
38 | 1334 } |
1335 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1336 void clean_content_of_Id(int8_t localId) |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1337 { |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1338 clean_content( ident[localId].coord[0], ident[localId].coord[1], ident[localId].coord[2], ident[localId].fontUsed); |
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1339 } |
38 | 1340 |
1341 void clean_content_of_actual_Id(void) | |
1342 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1343 clean_content_of_Id(actualId); |
38 | 1344 } |
1345 | |
949 | 1346 uint8_t togglePlusMinus(uint8_t input) |
1347 { | |
1348 if (input == '+') { | |
1349 return '-'; | |
1350 } else { | |
1351 return '+'; | |
1352 } | |
1353 } | |
1354 | |
38 | 1355 void write_field_udigit_and_2digit(uint8_t subtype, uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) |
1356 { | |
1357 if(id >= 9) | |
1358 return; | |
1359 | |
1360 ident[id].maintype = FIELD_NUMBERS; | |
1361 ident[id].subtype = subtype; | |
1362 | |
1363 ident[id].coord[0] = XleftGimpStyle; | |
1364 ident[id].coord[1] = XrightGimpStyle; | |
1365 ident[id].coord[2] = YtopGimpStyle; | |
1366 ident[id].fontUsed = (tFont *)Font; | |
1367 ident[id].callerID = editID; | |
1368 | |
1369 strncpy(ident[id].orgText, text, 32); | |
1370 strncpy(ident[id].newText, text, 32); | |
1371 ident[id].orgText[31] = 0; | |
1372 ident[id].newText[31] = 0; | |
1373 | |
1374 /* uint32_t has max 10 digits */ | |
1375 | |
1376 int8_t beginTmp, sizeTmp; | |
1377 uint8_t i; | |
1378 | |
1379 ident[id].input[0] = int1; | |
1380 ident[id].input[1] = int2; | |
1381 ident[id].input[2] = int3; | |
1382 ident[id].input[3] = int4; | |
1383 | |
1384 for(i=0;i<4;i++) | |
1385 ident[id].size[i] = 0; | |
1386 | |
1387 beginTmp = 0; | |
1388 for(i=0;i<4;i++) | |
1389 { | |
1390 while((ident[id].orgText[beginTmp] != '#')&& ident[id].orgText[beginTmp]) | |
1391 beginTmp++; | |
1392 | |
1393 if(ident[id].orgText[beginTmp] == '#') | |
1394 { | |
1395 sizeTmp = 1; | |
1396 while(ident[id].orgText[beginTmp + sizeTmp] == '#') | |
1397 sizeTmp++; | |
1398 | |
1399 ident[id].begin[i] = beginTmp; | |
1400 ident[id].size[i] = sizeTmp; | |
1401 beginTmp = ident[id].begin[i] + ident[id].size[i]; | |
1402 } | |
1403 else | |
1404 break; | |
1405 } | |
1406 | |
1407 if(!tME_stop) | |
1408 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
1409 else | |
1410 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditInfo); | |
1411 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1412 create_newText_for_Id(id); |
38 | 1413 |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1414 if(editID == 0) |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1415 write_content_without_Id(); |
38 | 1416 else |
1417 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1418 write_content_of_Id(id); |
38 | 1419 if(!tME_stop) |
1420 idLast = id; | |
1421 id++; | |
1422 } | |
1423 } | |
1424 | |
1425 void write_field_udigit(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) | |
1426 { | |
1427 write_field_udigit_and_2digit(FIELD_UDIGIT, editID,XleftGimpStyle,XrightGimpStyle,YtopGimpStyle,Font,text,int1,int2,int3,int4); | |
1428 } | |
1429 | |
1430 void write_field_2digit(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) | |
1431 { | |
1432 write_field_udigit_and_2digit(FIELD_2DIGIT, editID,XleftGimpStyle,XrightGimpStyle,YtopGimpStyle,Font,text,int1,int2,int3,int4); | |
1433 } | |
1434 | |
1435 void write_field_3digit(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint32_t int1, uint32_t int2, uint32_t int3, uint32_t int4) | |
1436 { | |
1437 write_field_udigit_and_2digit(FIELD_3DIGIT, editID,XleftGimpStyle,XrightGimpStyle,YtopGimpStyle,Font,text,int1,int2,int3,int4); | |
1438 } | |
1439 | |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1440 |
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1441 void write_field_sdigit(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, int32_t int1, int32_t int2, int32_t int3, int32_t int4) |
38 | 1442 { |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1443 write_field_udigit_and_2digit(FIELD_SDIGIT, editID, XleftGimpStyle, XrightGimpStyle, YtopGimpStyle, Font, text, ((input_u)int1).uint32, ((input_u)int2).uint32, ((input_u)int3).uint32, ((input_u)int4).uint32); |
38 | 1444 } |
776
45b8f3c2acce
Add support for a configurable compass declination in a range of -99 to 99 degrees.
heinrichsweikamp
parents:
774
diff
changeset
|
1445 |
38 | 1446 |
1447 void write_field_select(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint8_t int1, uint8_t int2, uint8_t int3, uint8_t int4) | |
1448 { | |
1449 if(id >= 9) | |
1450 return; | |
1451 | |
1452 int8_t beginTmp; | |
1453 | |
1454 ident[id].maintype = FIELD_SELECT; | |
1455 ident[id].subtype = FIELD_SELECT; | |
1456 | |
1457 ident[id].coord[0] = XleftGimpStyle; | |
1458 ident[id].coord[1] = XrightGimpStyle; | |
1459 ident[id].coord[2] = YtopGimpStyle; | |
1460 ident[id].fontUsed = (tFont *)Font; | |
1461 ident[id].callerID = editID; | |
1462 | |
1463 strncpy(ident[id].orgText, text, 32); | |
1464 strncpy(ident[id].newText, text, 32); | |
1465 ident[id].orgText[31] = 0; | |
1466 ident[id].newText[31] = 0; | |
1467 | |
1468 ident[id].input[0] = int1; | |
1469 ident[id].input[1] = int2; | |
1470 ident[id].input[2] = int3; | |
1471 ident[id].input[3] = int4; | |
1472 | |
1473 for(int i=0;i<4;i++) | |
1474 ident[id].size[i] = 0; | |
1475 | |
1476 beginTmp = 0; | |
1477 for(int i=0;i<4;i++) | |
1478 { | |
1479 while((ident[id].orgText[beginTmp] != '#')&& ident[id].orgText[beginTmp]) | |
1480 beginTmp++; | |
1481 | |
1482 if(ident[id].orgText[beginTmp] == '#') | |
1483 { | |
1484 | |
1485 ident[id].begin[i] = beginTmp; | |
1486 ident[id].size[i] = 1; | |
1487 beginTmp = ident[id].begin[i] + ident[id].size[i]; | |
1488 } | |
1489 else | |
1490 break; | |
1491 } | |
1492 | |
1493 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
1494 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1495 create_newText_for_Id(id); |
38 | 1496 |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1497 if(editID == 0) |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1498 write_content_without_Id(); |
38 | 1499 else |
1500 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1501 write_content_of_Id(id); |
38 | 1502 if(!tME_stop) |
1503 idLast = id; | |
1504 id++; | |
1505 } | |
1506 } | |
1507 | |
1508 void write_field_button(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text) | |
1509 { | |
1510 if(id >= 9) | |
1511 return; | |
1512 | |
1513 ident[id].maintype = FIELD_BUTTON; | |
1514 ident[id].subtype = FIELD_BUTTON; | |
1515 | |
1516 ident[id].coord[0] = XleftGimpStyle; | |
1517 ident[id].coord[1] = XrightGimpStyle; | |
1518 ident[id].coord[2] = YtopGimpStyle; | |
1519 ident[id].fontUsed = (tFont *)Font; | |
1520 ident[id].callerID = editID; | |
1521 | |
1522 strncpy(ident[id].orgText, text, 32); | |
1523 strncpy(ident[id].newText, text, 32); | |
1524 ident[id].orgText[31] = 0; | |
1525 ident[id].newText[31] = 0; | |
1526 | |
1527 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditButtonColor1); | |
1528 | |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1529 if(editID == 0) |
38 | 1530 write_content_without_Id(); |
1531 else | |
1532 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1533 write_content_of_Id(id); |
38 | 1534 if(!tME_stop) |
1535 idLast = id; | |
1536 id++; | |
1537 } | |
1538 } | |
1539 | |
1540 | |
1541 void write_field_symbol(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint8_t int1) | |
1542 { | |
1543 if(id >= 9) | |
1544 return; | |
1545 | |
1546 ident[id].maintype = FIELD_SYMBOL; | |
1547 ident[id].subtype = FIELD_SYMBOL; | |
1548 | |
1549 ident[id].coord[0] = XleftGimpStyle; | |
1550 ident[id].coord[1] = XrightGimpStyle; | |
1551 ident[id].coord[2] = YtopGimpStyle; | |
1552 ident[id].fontUsed = (tFont *)Font; | |
1553 ident[id].callerID = editID; | |
1554 | |
1555 strncpy(ident[id].orgText, text, 32); | |
1556 strncpy(ident[id].newText, text, 32); | |
1557 ident[id].orgText[31] = 0; | |
1558 | |
1559 ident[id].newText[0] = text[0]; | |
1560 ident[id].newText[1] = 0; | |
1561 | |
1562 ident[id].input[0] = int1; | |
1563 ident[id].input[1] = strlen(ident[id].orgText); | |
1564 | |
1565 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditButtonColor1); | |
1566 | |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1567 if(editID == 0) |
38 | 1568 write_content_without_Id(); |
1569 else | |
1570 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1571 write_content_of_Id(id); |
38 | 1572 if(!tME_stop) |
1573 idLast = id; | |
1574 id++; | |
1575 } | |
1576 } | |
584 | 1577 void write_field_toggle(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint8_t int1, uint8_t int2) |
1578 { | |
1579 if(id >= 9) return; | |
1580 ident[id].maintype = FIELD_TOGGLE; | |
1581 ident[id].subtype = FIELD_TOGGLE; | |
1582 ident[id].coord[0] = XleftGimpStyle; | |
1583 ident[id].coord[1] = XrightGimpStyle; | |
1584 ident[id].coord[2] = YtopGimpStyle; | |
1585 ident[id].fontUsed = (tFont *)Font; | |
1586 ident[id].callerID = editID; | |
1587 strncpy(ident[id].orgText, text, 32); | |
1588 strncpy(ident[id].newText, text, 32); | |
1589 ident[id].orgText[31] = 0; | |
1590 ident[id].newText[31] = 0; | |
1591 | |
1592 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditButtonColor1); | |
1593 | |
1594 if(editID == 0) write_content_without_Id(); | |
1595 else | |
1596 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1597 write_content_of_Id(id); |
584 | 1598 if(!tME_stop) idLast = id; |
1599 id++; | |
1600 } | |
1601 } | |
1602 | |
38 | 1603 |
1604 | |
1605 /* was build for field_on_off | |
1606 * to be tested for other purposes first | |
1607 */ | |
1608 void tMenuEdit_refresh_field(uint32_t editID) | |
1609 { | |
1610 uint8_t temp_id; | |
1611 | |
1612 temp_id = get_id_of(editID); | |
1613 if(temp_id == 255) | |
1614 return; | |
1615 | |
1616 clean_content( ident[temp_id].coord[0], ident[temp_id].coord[1], ident[temp_id].coord[2], ident[temp_id].fontUsed); | |
1617 write_content( ident[temp_id].coord[0], ident[temp_id].coord[1], ident[temp_id].coord[2], ident[temp_id].fontUsed, ident[temp_id].newText, (CLUT_MenuEditField0 + temp_id)); | |
1618 } | |
1619 | |
1620 | |
1621 void write_field_on_off(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint8_t int1) | |
1622 { | |
1623 if(id >= 9) | |
1624 return; | |
1625 | |
1626 ident[id].maintype = FIELD_ON_OFF; | |
1627 ident[id].subtype = FIELD_ON_OFF; | |
1628 | |
1629 ident[id].coord[0] = XleftGimpStyle; | |
1630 ident[id].coord[1] = XrightGimpStyle; | |
1631 ident[id].coord[2] = YtopGimpStyle; | |
1632 ident[id].fontUsed = (tFont *)Font; | |
1633 ident[id].callerID = editID; | |
1634 | |
1635 if(int1) | |
1636 ident[id].orgText[0] = '\005'; | |
1637 else | |
1638 ident[id].orgText[0] = '\006'; | |
1639 | |
1640 ident[id].orgText[1] = ' '; | |
1641 | |
1642 strncpy(&ident[id].orgText[2], text, 30); | |
1643 strncpy(ident[id].newText, ident[id].orgText, 32); | |
1644 ident[id].orgText[31] = 0; | |
1645 ident[id].newText[31] = 0; | |
1646 | |
1647 if(!tME_stop) | |
1648 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
1649 else | |
1650 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditInfo); | |
1651 | |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1652 if(editID == 0) |
38 | 1653 write_content_without_Id(); |
1654 else | |
1655 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1656 write_content_of_Id(id); |
38 | 1657 if(!tME_stop) |
1658 idLast = id; | |
1659 id++; | |
1660 } | |
1661 } | |
1662 | |
1663 | |
1664 void write_field_fpoint(uint32_t editID, uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, float input) | |
1665 { | |
1666 if(id >= 9) | |
1667 return; | |
1668 | |
1669 ident[id].maintype = FIELD_NUMBERS; | |
1670 ident[id].subtype = FIELD_FLOAT; | |
1671 | |
1672 ident[id].coord[0] = XleftGimpStyle; | |
1673 ident[id].coord[1] = XrightGimpStyle; | |
1674 ident[id].coord[2] = YtopGimpStyle; | |
1675 ident[id].fontUsed = (tFont *)Font; | |
1676 ident[id].callerID = editID; | |
1677 | |
1678 strncpy(ident[id].orgText, text, 32); | |
1679 strncpy(ident[id].newText, text, 32); | |
1680 ident[id].orgText[31] = 0; | |
1681 ident[id].newText[31] = 0; | |
1682 | |
1683 change_CLUT_entry((CLUT_MenuEditField0 + id), CLUT_MenuEditFieldRegular); | |
1684 | |
166
255eedad4155
cleanup: get rid of some compile warnings
Jan Mulder <jlmulder@xs4all.nl>
parents:
138
diff
changeset
|
1685 if(editID == 0) |
38 | 1686 write_content_without_Id(); |
1687 else | |
1688 { | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1689 write_content_of_Id(id); |
38 | 1690 if(!tME_stop) |
1691 idLast = id; | |
1692 id++; | |
1693 } | |
1694 } | |
1695 | |
1696 | |
1697 void setBackMenu(uint32_t inputFunctionCall, uint8_t functionCallParameter, uint8_t gotoMenuEditField) | |
1698 { | |
1699 backmenu.pEventFunction = inputFunctionCall; | |
1700 backmenu.functionParameter = functionCallParameter; | |
1701 backmenu.line = gotoMenuEditField; | |
1702 } | |
1703 | |
1704 | |
1705 void setEvent(uint32_t inputEventID, uint32_t inputFunctionCall) | |
1706 { | |
1707 if(evidLast >= 9) | |
1708 return; | |
1709 | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1710 #if 0 |
38 | 1711 /* set cursor to first field */ |
1712 if(evidLast < 0) | |
1713 { | |
1714 startMenuEditFieldSelect(); | |
1715 } | |
853
de6023cc0580
Potential Bugfix Selection MenuEdit lifecycle:
Ideenmodellierer
parents:
845
diff
changeset
|
1716 #endif |
38 | 1717 event[evid].callerID = inputEventID; |
1718 event[evid].pEventFunction = inputFunctionCall; | |
1719 | |
1720 evidLast = evid; | |
1721 evid++; | |
1722 } | |
1723 | |
1724 void startEdit(void) | |
1725 { | |
1726 EnterPressed = 1; | |
1727 helperGotoMenuEditField(0); | |
1728 enterMenuEditField(); | |
1729 } | |
1730 | |
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
parents:
786
diff
changeset
|
1731 |
38 | 1732 void exitEditWithUpdate(void) |
1733 { | |
1734 createDiveSettings(); | |
1735 EnterPressed = 1; | |
1736 exitMenuEdit(1); | |
1737 } | |
1738 | |
1739 /* | |
1740 void set_cursor(uint8_t forThisIdentID) | |
1741 { | |
1742 int16_t x0, x1, y0, y1; | |
1743 | |
1744 uint32_t xtra_left_right = 10; | |
1745 uint32_t xtra_top_bottom = 10; | |
1746 | |
1747 // y geht von 0 bis 799 | |
1748 // x geht von 0 bis 479 | |
1749 | |
1750 x0 = (int16_t)ident[forThisIdentID].coord[0]; | |
1751 x1 = (int16_t)ident[forThisIdentID].coord[1]; | |
1752 y0 = (int16_t)ident[forThisIdentID].coord[2]; | |
1753 y1 = y0 + (int16_t)ident[forThisIdentID].fontUsed->height; | |
1754 | |
1755 if(((int16_t)ident[forThisIdentID].fontUsed->height) > 70) | |
1756 { | |
1757 xtra_left_right = 10; | |
1758 xtra_top_bottom = 10; | |
1759 } | |
1760 else | |
1761 { | |
1762 xtra_left_right = 10; | |
1763 xtra_top_bottom = 0; | |
1764 } | |
1765 | |
1766 x0 -= xtra_left_right; | |
1767 x1 += xtra_left_right; | |
1768 y0 -= xtra_top_bottom; | |
1769 y1 += xtra_top_bottom; | |
1770 | |
1771 GFX_SetWindowLayer0(tMEcursor.FBStartAdress, x0, x1, y0, y1); | |
1772 } | |
1773 */ | |
1774 | |
1775 void set_cursorNew(uint8_t forThisIdentID) | |
1776 { | |
1777 int16_t y0; | |
1778 uint8_t lineMinusOne; | |
1779 | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1780 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1781 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1782 y0 = (int16_t)ident[forThisIdentID].coord[2]; |
117 | 1783 y0 -= ME_Y_LINE1; |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1784 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1785 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1786 { |
117 | 1787 y0 = 390 + 25 - (int16_t)ident[forThisIdentID].coord[2]; |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1788 } |
117 | 1789 |
38 | 1790 y0 /= ME_Y_LINE_STEP; |
117 | 1791 if((y0 >= 0) && (y0 <=6)) |
38 | 1792 lineMinusOne = y0; |
1793 else | |
1794 lineMinusOne = 0; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1795 |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1796 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1797 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1798 GFX_SetFrameBottom((tMEcursorNew.FBStartAdress) + 65*2*(lineMinusOne), 0, 25, 800, 390); |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1799 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1800 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1801 { |
117 | 1802 GFX_SetFrameBottom((tMEcursorNew.FBStartAdress)+ (390 - 65 *(6-lineMinusOne)) *2, 0, 480-390-25, 800, 390); |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1803 } |
38 | 1804 } |
1805 | |
1806 | |
1807 void write_topline( char *text) | |
1808 { | |
1809 GFX_DrawCfgWindow hgfx; | |
1810 const tFont *Font = &FontT48; | |
1811 | |
1812 hgfx.Image = &tMEscreen; | |
1813 hgfx.WindowNumberOfTextLines = 1; | |
1814 hgfx.WindowLineSpacing = 0; | |
1815 hgfx.WindowTab = 0; | |
1816 hgfx.WindowX0 = 20; | |
1817 hgfx.WindowX1 = 779; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1818 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1819 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1820 hgfx.WindowY1 = 479; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1821 hgfx.WindowY0 = hgfx.WindowY1 - Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1822 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1823 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1824 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1825 hgfx.WindowY0 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1826 hgfx.WindowY1 = hgfx.WindowY0 + Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1827 } |
38 | 1828 GFX_write_label(Font, &hgfx, text, menuColor); |
1829 } | |
1830 | |
1831 | |
1832 void write_buttonTextline( uint8_t left2ByteCode, char middle2ByteCode, char right2ByteCode) | |
1833 { | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1834 |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1835 SSettings* pSettings; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1836 pSettings = settingsGetPointer(); |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1837 |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1838 if(!pSettings->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1839 { |
117 | 1840 GFX_clean_area(&tMEscreen, 0, 800, 479-24,480); |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1841 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1842 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1843 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1844 GFX_clean_area(&tMEscreen, 0, 800, 0, 24); |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1845 } |
38 | 1846 |
1847 char localtext[32]; | |
1848 | |
1849 if(left2ByteCode) | |
1850 { | |
1851 localtext[0] = TXT_2BYTE; | |
1852 localtext[1] = left2ByteCode; | |
1853 localtext[2] = 0; | |
117 | 1854 |
1855 write_content_simple(&tMEscreen, 0, 800, 479-24, &FontT24,localtext,CLUT_ButtonSurfaceScreen); | |
38 | 1856 } |
1857 | |
1858 if(middle2ByteCode) | |
1859 { | |
1860 localtext[0] = '\001'; | |
1861 localtext[1] = TXT_2BYTE; | |
1862 localtext[2] = middle2ByteCode; | |
1863 localtext[3] = 0; | |
117 | 1864 |
1865 write_content_simple(&tMEscreen, 0, 800, 479-24, &FontT24,localtext,CLUT_ButtonSurfaceScreen); | |
38 | 1866 } |
1867 | |
1868 if(right2ByteCode) | |
1869 { | |
1870 localtext[0] = '\002'; | |
1871 localtext[1] = TXT_2BYTE; | |
1872 localtext[2] = right2ByteCode; | |
1873 localtext[3] = 0; | |
117 | 1874 |
1875 write_content_simple(&tMEscreen, 0, 800, 479-24, &FontT24,localtext,CLUT_ButtonSurfaceScreen); | |
38 | 1876 } |
1877 } | |
1878 | |
1879 | |
1880 | |
1881 void write_label_var(uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text) | |
1882 { | |
1883 GFX_DrawCfgWindow hgfx; | |
1884 | |
1885 if(XrightGimpStyle > 799) | |
1886 XrightGimpStyle = 799; | |
1887 if(XleftGimpStyle >= XrightGimpStyle) | |
1888 XleftGimpStyle = 0; | |
1889 if(YtopGimpStyle > 479) | |
1890 YtopGimpStyle = 479; | |
1891 hgfx.Image = &tMEscreen; | |
1892 hgfx.WindowNumberOfTextLines = 1; | |
1893 hgfx.WindowLineSpacing = 0; | |
1894 hgfx.WindowTab = 0; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1895 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1896 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1897 hgfx.WindowX0 = XleftGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1898 hgfx.WindowX1 = XrightGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1899 hgfx.WindowY1 = 479 - YtopGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1900 if(hgfx.WindowY1 < Font->height) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1901 hgfx.WindowY0 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1902 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1903 hgfx.WindowY0 = hgfx.WindowY1 - Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1904 } |
38 | 1905 else |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1906 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1907 hgfx.WindowX0 = 800 - XrightGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1908 hgfx.WindowX1 = 800 - XleftGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1909 hgfx.WindowY0 = YtopGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1910 if(hgfx.WindowY0 < Font->height) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1911 hgfx.WindowY1 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1912 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1913 hgfx.WindowY1 = hgfx.WindowY0 + Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1914 } |
38 | 1915 GFX_write_label(Font, &hgfx, text, 0);/*menuColor);*/ |
1916 } | |
1917 | |
1918 | |
1919 void write_content(uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char *text, uint8_t color) | |
1920 { | |
1921 GFX_DrawCfgWindow hgfx; | |
1922 | |
1923 if(XrightGimpStyle > 799) | |
1924 XrightGimpStyle = 799; | |
1925 if(XleftGimpStyle >= XrightGimpStyle) | |
1926 XleftGimpStyle = 0; | |
1927 if(YtopGimpStyle > 479) | |
1928 YtopGimpStyle = 479; | |
1929 hgfx.Image = &tMEscreen; | |
1930 hgfx.WindowNumberOfTextLines = 1; | |
1931 hgfx.WindowLineSpacing = 0; | |
1932 hgfx.WindowTab = 0; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1933 |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1934 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1935 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1936 hgfx.WindowX0 = XleftGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1937 hgfx.WindowX1 = XrightGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1938 hgfx.WindowY1 = 479 - YtopGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1939 if(hgfx.WindowY1 < Font->height) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1940 hgfx.WindowY0 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1941 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1942 hgfx.WindowY0 = hgfx.WindowY1 - Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1943 } |
38 | 1944 else |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1945 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1946 hgfx.WindowX0 = 800 - XrightGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1947 hgfx.WindowX1 = 800 - XleftGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1948 hgfx.WindowY0 = YtopGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1949 if(hgfx.WindowY0 < Font->height) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1950 hgfx.WindowY1 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1951 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1952 hgfx.WindowY1 = hgfx.WindowY0 + Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1953 } |
38 | 1954 GFX_write_label(Font, &hgfx, text, color); |
1955 } | |
1956 | |
1957 | |
1958 void write_label_fix(uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font, const char textId) | |
1959 { | |
1960 char text[2]; | |
1961 | |
1962 text[0] = textId; | |
1963 text[1] = 0; | |
1964 | |
1965 write_label_var(XleftGimpStyle, XrightGimpStyle, YtopGimpStyle, Font, text); | |
1966 } | |
1967 | |
1968 | |
1969 void clean_content(uint16_t XleftGimpStyle, uint16_t XrightGimpStyle, uint16_t YtopGimpStyle, const tFont *Font) | |
1970 { | |
1971 GFX_DrawCfgWindow hgfx; | |
1972 | |
1973 if(XrightGimpStyle > 799) | |
1974 XrightGimpStyle = 799; | |
1975 if(XleftGimpStyle >= XrightGimpStyle) | |
1976 XleftGimpStyle = 0; | |
1977 if(YtopGimpStyle > 479) | |
1978 YtopGimpStyle = 479; | |
1979 hgfx.Image = &tMEscreen; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1980 if(!settingsGetPointer()->FlipDisplay) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1981 { |
38 | 1982 hgfx.WindowX0 = XleftGimpStyle; |
1983 hgfx.WindowX1 = XrightGimpStyle; | |
1984 hgfx.WindowY1 = 479 - YtopGimpStyle; | |
1985 if(hgfx.WindowY1 < Font->height) | |
1986 hgfx.WindowY0 = 0; | |
1987 else | |
1988 hgfx.WindowY0 = hgfx.WindowY1 - Font->height; | |
110
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1989 } |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1990 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1991 { |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1992 hgfx.WindowX0 = 800 - XrightGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1993 hgfx.WindowX1 = 800 - XleftGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1994 hgfx.WindowY0 = YtopGimpStyle; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1995 if(hgfx.WindowY0 < Font->height) |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1996 hgfx.WindowY1 = 0; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1997 else |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1998 hgfx.WindowY1 = hgfx.WindowY0 + Font->height; |
cc8e24374b83
Added option to handled mirrored display to existing functions
Ideenmodellierer
parents:
38
diff
changeset
|
1999 } |
38 | 2000 GFX_clear_window_immediately(&hgfx); |
2001 } | |
2002 | |
2003 | |
2004 /* Private functions ---------------------------------------------------------*/ | |
2005 | |
2006 void draw_tMEdesign(void) | |
2007 { | |
2008 GFX_draw_header(&tMEscreen,menuColor); | |
2009 } | |
2010 | |
2011 void draw_tMEdesignSubUnselected(uint32_t *ppDestination) | |
2012 { | |
2013 union al88_u | |
2014 { | |
2015 uint8_t al8[2]; | |
2016 uint16_t al88; | |
2017 }; | |
2018 | |
2019 union al88_u color_seperator; | |
2020 union al88_u color_unselected; | |
2021 int i; | |
2022 | |
2023 color_seperator.al8[0] = CLUT_MenuLineUnselectedSeperator; | |
2024 color_unselected.al8[0] = CLUT_MenuLineUnselected; | |
2025 | |
2026 color_seperator.al8[1] = 0xFF; | |
2027 color_unselected.al8[1] = 0xFF; | |
2028 | |
2029 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2030 *ppDestination += 2; | |
2031 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2032 *ppDestination += 2; | |
2033 | |
2034 for(i = 61; i > 0; i--) | |
2035 { | |
2036 *(__IO uint16_t*)*ppDestination = color_unselected.al88; | |
2037 *ppDestination += 2; | |
2038 } | |
2039 | |
2040 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2041 *ppDestination += 2; | |
2042 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2043 *ppDestination += 2; | |
2044 } | |
2045 | |
2046 | |
2047 void draw_tMEdesignSubSelected(uint32_t *ppDestination) | |
2048 { | |
2049 union al88_u | |
2050 { | |
2051 uint8_t al8[2]; | |
2052 uint16_t al88; | |
2053 }; | |
2054 | |
2055 union al88_u color_selected; | |
2056 union al88_u color_seperator; | |
2057 int i; | |
2058 | |
2059 color_selected.al8[0] = CLUT_MenuEditLineSelected; | |
2060 color_selected.al8[1] = 0xFF; | |
2061 | |
2062 color_seperator.al8[0] = CLUT_MenuLineSelectedSeperator; | |
2063 color_seperator.al8[1] = 0xFF; | |
2064 | |
2065 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2066 *ppDestination += 2; | |
2067 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2068 *ppDestination += 2; | |
2069 | |
2070 for(i = 61; i > 0; i--) | |
2071 { | |
2072 *(__IO uint16_t*)*ppDestination = color_selected.al88; | |
2073 *ppDestination += 2; | |
2074 } | |
2075 | |
2076 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2077 *ppDestination += 2; | |
2078 *(__IO uint16_t*)*ppDestination = color_seperator.al88; | |
2079 *ppDestination += 2; | |
2080 } | |
2081 | |
2082 | |
2083 void draw_tMEdesignSubSelectedBorder(uint32_t *ppDestination) | |
2084 { | |
2085 union al88_u | |
2086 { | |
2087 uint8_t al8[2]; | |
2088 uint16_t al88; | |
2089 }; | |
2090 | |
2091 union al88_u color_selected_sides; | |
2092 | |
2093 int i; | |
2094 | |
2095 color_selected_sides.al8[0] = CLUT_MenuLineSelectedSides; | |
2096 color_selected_sides.al8[1] = 0xFF; | |
2097 | |
2098 for(i = 65; i > 0; i--) | |
2099 { | |
2100 *(__IO uint16_t*)*ppDestination = color_selected_sides.al88; | |
2101 *ppDestination += 2; | |
2102 } | |
2103 } | |
2104 | |
2105 | |
2106 void draw_tMEcursorNewDesign(void) | |
2107 { | |
2108 int i,j; | |
2109 uint32_t pDestination; | |
2110 | |
2111 pDestination = tMEcursorNew.FBStartAdress; | |
2112 | |
2113 for(j = 801; j > 0; j--) | |
2114 { | |
2115 for(i = 5; i > 0; i--) | |
2116 { | |
2117 draw_tMEdesignSubUnselected(&pDestination); | |
2118 } | |
2119 if((j > 787) || (j < 17)) | |
2120 draw_tMEdesignSubSelectedBorder(&pDestination); | |
2121 else | |
2122 draw_tMEdesignSubSelected(&pDestination); | |
2123 } | |
2124 } | |
552
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2125 |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2126 GFX_DrawCfgScreen* getMenuEditScreen() |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2127 { |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2128 return &tMEscreen; |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2129 } |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2130 |
531e7818b737
Added menu structure to acces viewport calibration:
Ideenmodellierer
parents:
531
diff
changeset
|
2131 |