Mercurial > public > hwos_code
annotate src/tft_outputs.asm @ 608:d866684249bd
work on 2.99 stable
author | heinrichsweikamp |
---|---|
date | Mon, 07 Jan 2019 21:13:43 +0100 |
parents | 5ce603c29750 |
children | b87f23fae743 |
rev | line source |
---|---|
0 | 1 ;============================================================================= |
2 ; | |
608 | 3 ; File tft_outputs.asm REFACTORED VERSION V2.99f |
0 | 4 ; |
5 ; Startup subroutines | |
6 ; | |
7 ; Copyright (c) 2011, JD Gascuel, HeinrichsWeikamp, all right reserved. | |
8 ;============================================================================= | |
9 ; HISTORY | |
10 ; 2011-08-07 : [mH] moving from OSTC code | |
11 | |
604 | 12 #include "hwos.inc" ; mandatory header |
13 #include "shared_definitions.h" ; mailbox from/to p2_deco.c | |
582 | 14 #include "tft.inc" |
15 #include "start.inc" | |
16 #include "wait.inc" | |
17 #include "strings.inc" | |
18 #include "convert.inc" | |
19 #include "varargs.inc" | |
20 #include "math.inc" | |
21 #include "isr.inc" | |
22 #include "eeprom_rs232.inc" | |
23 #include "adc_lightsensor.inc" | |
24 #include "surfmode.inc" | |
25 #include "divemode.inc" | |
26 #include "external_flash.inc" | |
27 #include "ghostwriter.inc" | |
28 #include "customview.inc" | |
29 #include "i2c.inc" | |
30 #include "colorschemes.inc" | |
31 #include "calibrate.inc" | |
604 | 32 #include "gaslist.inc" |
33 | |
34 IFDEF _rx_functions | |
35 #include "rx_ops.inc" | |
36 ENDIF | |
560 | 37 |
0 | 38 extern aa_wordprocessor |
604 | 39 extern get_first_gas_to_WREG |
40 extern get_first_dil_to_WREG | |
41 | |
42 extern tFirmware | |
43 extern tSerial | |
44 extern tTotalDives | |
45 extern tBatteryV | |
46 extern tUptime | |
47 extern tCalX,tCalY,tCalZ | |
48 extern tPPO2MIN | |
49 extern tPPO2MINCC | |
50 extern tPPO2Max | |
51 extern tPPO2DECO | |
52 | |
53 IFDEF _rx_functions | |
54 extern tFirmware_rx | |
55 ENDIF | |
0 | 56 |
57 ;============================================================================= | |
58 | |
604 | 59 tft_out CODE |
582 | 60 |
0 | 61 ;============================================================================= |
62 | |
582 | 63 global TFT_divemask_color |
0 | 64 TFT_divemask_color: |
582 | 65 movlw color_green |
604 | 66 btfsc divemode ; in divemode? |
582 | 67 rcall TFT_divemask_color_dive |
50 | 68 bra TFT_standard_color0 |
69 | |
70 TFT_divemask_color_dive: | |
582 | 71 movff opt_dive_color_scheme,WREG ; 0-3 |
72 incf WREG | |
50 | 73 dcfsnz WREG |
582 | 74 retlw color_scheme_divemode_mask1 ;0 |
50 | 75 dcfsnz WREG |
582 | 76 retlw color_scheme_divemode_mask2 ;1 |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
77 dcfsnz WREG |
582 | 78 retlw color_scheme_divemode_mask3 ;2 |
79 retlw color_scheme_divemode_mask4 ;3 | |
80 | |
81 | |
604 | 82 global TFT_memo_color |
83 TFT_memo_color: ; information, values within normal range, things without a need to react upon | |
84 movlw color_white | |
85 bra TFT_standard_color0 | |
605 | 86 TFT_memo_color_dive: |
87 retlw color_white | |
604 | 88 |
89 global TFT_advice_color | |
90 TFT_advice_color: ; advices to do something, but without essential need to actually do it | |
91 movlw color_green | |
92 bra TFT_standard_color0 | |
93 TFT_advice_color_dive: | |
94 retlw color_green | |
95 | |
96 global TFT_attention_color ; important things to be aware of and things that are developing towards a warning | |
50 | 97 TFT_attention_color: |
604 | 98 movlw color_yellow |
0 | 99 bra TFT_standard_color0 |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
100 TFT_attention_color_dive: |
604 | 101 retlw color_yellow |
102 | |
103 global TFT_warnings_color ; important things with immediate need to react upon | |
0 | 104 TFT_warnings_color: |
604 | 105 movlw color_red |
0 | 106 bra TFT_standard_color0 |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
107 TFT_warnings_color_dive: |
604 | 108 retlw color_red |
582 | 109 |
110 | |
111 global TFT_disabled_color | |
0 | 112 TFT_disabled_color: |
582 | 113 movlw color_lightblue |
604 | 114 btfsc divemode ; in divemode? |
582 | 115 rcall TFT_disabled_color_dive ; YES |
116 bra TFT_standard_color0 | |
87 | 117 TFT_disabled_color_dive: |
582 | 118 movff opt_dive_color_scheme,WREG ; 0-3 |
119 incf WREG | |
87 | 120 dcfsnz WREG |
582 | 121 retlw color_scheme_divemode_dis1 ; 0 |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
122 dcfsnz WREG |
582 | 123 retlw color_scheme_divemode_dis2 ; 1 |
50 | 124 dcfsnz WREG |
582 | 125 retlw color_scheme_divemode_dis3 ; 2 |
126 retlw color_scheme_divemode_dis4 ; 3 | |
127 | |
128 | |
129 global TFT_standard_color | |
130 TFT_standard_color: | |
604 | 131 setf WREG ; default white |
132 btfsc divemode ; in divemode? | |
582 | 133 rcall TFT_standard_color_dive |
134 ;bra TFT_standard_color0 | |
135 TFT_standard_color0: | |
136 goto TFT_set_color ; and return... | |
137 | |
138 | |
139 TFT_standard_color_dive: | |
140 movff opt_dive_color_scheme,WREG ; 0-3 | |
141 incf WREG | |
0 | 142 dcfsnz WREG |
582 | 143 retlw color_scheme_divemode_std1 ;0 |
0 | 144 dcfsnz WREG |
582 | 145 retlw color_scheme_divemode_std2 ;1 |
0 | 146 dcfsnz WREG |
582 | 147 retlw color_scheme_divemode_std3 ;2 |
148 retlw color_scheme_divemode_std4 ;3 | |
149 | |
150 | |
604 | 151 global TFT_color_code_tank_pres_sac |
152 TFT_color_code_tank_pres_sac: ; color-code a tank pressure or SAC rate, data in hi:lo | |
153 btfss hi,int_not_avail_flag ; is the not-available flag set? | |
154 bra TFT_color_code_tank_pres_1 ; NO | |
155 bcf hi,int_not_avail_flag ; YES - clear not-available flag | |
156 TFT_color_code_tank_pres_0: ; entry point for outdated flag | |
157 bcf hi,int_outdated_flag ; clear outdated flag (it may be set) | |
158 bcf hi,int_warning_flag ; clear warning flag (it may be set) | |
159 bcf hi,int_attention_flag ; clear attention flag (it may be set) | |
160 bra TFT_disabled_color ; set to disabled color and return | |
161 TFT_color_code_tank_pres_1: | |
162 btfsc hi,int_outdated_flag ; is the outdated flag set? | |
163 bra TFT_color_code_tank_pres_0 ; YES - handle alike with not-available flag | |
164 TFT_color_code_tank_pres_2: | |
165 btfss hi,int_warning_flag ; is the warning flag set? | |
166 bra TFT_color_code_tank_pres_3 ; NO | |
167 bcf hi,int_warning_flag ; YES - clear warning flag | |
168 bcf hi,int_attention_flag ; - clear attention flag (it may be set) | |
169 bra TFT_warnings_color ; - set to warning color and return | |
170 TFT_color_code_tank_pres_3: | |
171 btfss hi,int_attention_flag ; is the attention flag set? | |
172 bra TFT_memo_color ; NO - set to memo color and return | |
173 bcf hi,int_attention_flag ; YES - clear attention flag | |
174 bra TFT_attention_color ; - set to attention color and return | |
175 | |
176 | |
582 | 177 global TFT_color_code_gaslist |
604 | 178 TFT_color_code_gaslist: ; color-code current row in gaslist (%O2 in hi) according to current amb_pressure |
0 | 179 ; Check very high ppO2 manually |
604 | 180 movff amb_press_10+0,xA+0 |
181 movff amb_press_10+1,xA+1 | |
560 | 182 movff hi,xB+0 |
183 clrf xB+1 | |
184 call mult16x16 ; hi * p_amb/10 | |
604 | 185 ; Check if ppO2 > 6.55 bar |
186 tstfsz xC+2 ; char_I_O2_ratio * p_amb/10 > 65536, ppO2 > 6.55 bar ? | |
187 bra TFT_warnings_color ; YES - warn in warning color | |
188 ; Check if ppO2 > 3.30 bar | |
560 | 189 btfsc xC+1,7 |
604 | 190 bra TFT_warnings_color ; YES - warn in warning color |
191 ; Check for low ppO2 | |
560 | 192 movff xC+0,sub_a+0 |
193 movff xC+1,sub_a+1 | |
582 | 194 movff char_I_ppO2_min,WREG |
195 mullw d'100' ; char_I_ppO2_min*100 | |
560 | 196 movff PRODL,sub_b+0 |
197 movff PRODH,sub_b+1 | |
198 call subU16 | |
604 | 199 btfsc neg_flag ; lower than ppO2 min? |
200 bra TFT_warnings_color ; YES - set warning color and return | |
201 ; Check for high ppO2 | |
202 movff char_O_deco_info,WREG ; bank-safe copy of deco info vector | |
582 | 203 btfsc WREG,deco_flag ; are we in deco? |
604 | 204 bra TFT_color_code_gaslist_deco ; YES - check against ppO2 max deco only |
205 ; NO - check against ppO2 max travel/normal and deco | |
206 ; Check for ppO2 max travel/normal | |
207 movff char_I_ppO2_max,WREG ; ppo2 max for travel/normal | |
560 | 208 mullw d'100' ; char_I_ppO2_max*100 |
526
0d1cda9f2d43
BUGFIX: Skip MOD Test for CCR in Sensor modes (OSTC cR and OSTC3 only)
heinrichsweikamp
parents:
517
diff
changeset
|
209 movff PRODL,sub_b+0 |
0d1cda9f2d43
BUGFIX: Skip MOD Test for CCR in Sensor modes (OSTC cR and OSTC3 only)
heinrichsweikamp
parents:
517
diff
changeset
|
210 movff PRODH,sub_b+1 |
604 | 211 infsnz sub_b+0,F ; add 1 mbar to avoid warning on equal |
212 incf sub_b+1,F | |
582 | 213 call subU16 ; sub_c = sub_a - sub_b |
604 | 214 btfss neg_flag ; higher than ppO2 max travel/deco? |
215 rcall TFT_attention_color ; YES - set attention color | |
216 ; Check for ppO2 max deco | |
217 TFT_color_code_gaslist_deco: | |
218 movff char_I_ppO2_max_deco,WREG ; ppo2 max for deco | |
219 mullw d'100' ; char_I_ppO2_max_deco*100 | |
220 movff PRODL,sub_b+0 | |
221 movff PRODH,sub_b+1 | |
222 infsnz sub_b+0,F ; add 1 mbar to avoid warning on equal | |
223 incf sub_b+1,F | |
224 call subU16 ; sub_c = sub_a - sub_b | |
225 btfss neg_flag ; higher than ppO2 max deco? | |
226 bra TFT_warnings_color ; YES - set warning color and return | |
227 return ; NO - keep current color | |
560 | 228 |
229 | |
582 | 230 TFT_color_code_ceiling: ; color-code the ceiling depth |
231 btfsc hi,char_invalid_flag ; is the invalid flag set? (bit 7 here) | |
560 | 232 bra TFT_color_code_ceiling_1 ; YES |
233 SAFE_2BYTE_COPY rel_pressure,sub_a ; NO | |
582 | 234 movff lo,sub_b+0 |
235 movff hi,sub_b+1 | |
604 | 236 call subU16 ; sub_c = sub_a - sub_b : sub_c = rel_pressure [mbar] - int_O_ceiling [mbar] |
582 | 237 btfsc neg_flag ; is ceiling > current depth? |
604 | 238 bra TFT_warnings_color ; YES - set to warning color and return |
239 bra TFT_memo_color ; NO - set to memo color and return | |
560 | 240 TFT_color_code_ceiling_1: |
241 bcf hi,char_invalid_flag ; clear the invalid flag (bit 7 here) | |
242 bra TFT_disabled_color ; set to disabled color and return | |
243 | |
244 | |
604 | 245 TFT_color_code_stop: ; color-code the stop depth: memo color if below stop depth, |
246 ; attention color if above stop but below ceiling, | |
247 ; warning color if above stop and ceiling | |
248 ; (ceiling depth is calculated using current GF) | |
560 | 249 movff char_O_deco_gas+0,WREG ; get flag for invalid deco data |
250 btfsc WREG,char_invalid_flag ; is the invalid flag set? | |
604 | 251 bra TFT_disabled_color ; YES - set to disabled color and return |
252 movff char_O_first_deco_depth,WREG; NO - get stop depth in m into WREG | |
253 subwf curr_depth,W ; - compute current depth - stop depth | |
254 btfsc STATUS,C ; - result negative? | |
255 bra TFT_memo_color ; NO - set to memo color and return | |
256 movff int_O_ceiling+0,sub_b+0 ; YES - get ceiling depth in mbar | |
257 movff int_O_ceiling+1,sub_b+1 ; - ... | |
258 btfsc sub_b+1,char_invalid_flag ; - is the invalid flag set? (bit 7 here) | |
259 bra TFT_warnings_color ; YES - set to warning color and return | |
260 SAFE_2BYTE_COPY rel_pressure,sub_a ; NO - get current depth in mbar | |
261 call subU16 ; - sub_c = sub_a - sub_b : sub_c = rel_pressure [cm] - int_O_ceiling [mbar => cm] | |
262 btfsc neg_flag ; - is ceiling > current depth? | |
263 bra TFT_warnings_color ; YES - set to warning color and return | |
264 bra TFT_attention_color ; NO - set to attention color and return | |
265 | |
266 | |
267 TFT_color_code_depth: ; with actual depth as rel_pressure in [mbar] in hi:lo and threshold depth_warn_mbar [mbar] | |
560 | 268 movff lo,sub_a+0 |
269 movff hi,sub_a+1 | |
582 | 270 movlw LOW depth_warn_mbar |
560 | 271 movwf sub_b+0 |
272 movlw HIGH depth_warn_mbar | |
273 movwf sub_b+1 | |
274 call subU16 ; sub_c = sub_a - sub_b | |
582 | 275 TSTOSS opt_modwarning ; 0=standard, 1=blink |
560 | 276 bra TFT_color_code_depth_std |
277 btfss neg_flag | |
278 bra TFT_color_code_depth_warn ; set to warning color | |
279 bra TFT_color_code_depth_ppO2 ; check depth against MOD and return... | |
280 TFT_color_code_depth_std: | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
281 btfss neg_flag |
604 | 282 bra TFT_warnings_color ; set to warning color and return |
283 bra TFT_memo_color ; set to memo color and return... | |
560 | 284 TFT_color_code_depth_ppO2: |
582 | 285 movff opt_dive_mode,WREG ; 0=OC, 1=CC, 2=Gauge, 3=Apnea, 4=PSCR |
560 | 286 decfsz WREG,F ; are we in CCR mode? |
287 bra TFT_color_code_depth_no_ccr ; NO - continue checking for ppO2 | |
604 | 288 btfss FLAG_bailout_mode ; YES - check if in bailout |
289 bra TFT_color_code_depth_outside; NO - continue checking for outside ZHL16 model | |
560 | 290 TFT_color_code_depth_no_ccr: |
291 movff int_O_breathed_ppO2+1,WREG ; get upper byte of currently breathed ppO2 | |
292 btfsc WREG,int_warning_flag ; is the warning flag set? | |
293 bra TFT_color_code_depth_warn ; YES - animate in warning design | |
604 | 294 TFT_color_code_depth_outside: |
295 movff char_O_deco_warnings,WREG ; bank-safe copy of deco warnings | |
296 btfsc WREG,outside_warning ; are we currently outside of the ZH-L16 model? | |
297 bra TFT_color_code_depth_warn ; YES | |
298 btfsc WREG,outside_attention ; are we near to outside of the ZH-L16 model? | |
299 bra TFT_color_code_depth_att ; YES | |
300 bcf blinking_depth_warning ; NO - terminate warning blinking | |
301 bcf blinking_depth_attention ; - terminate attention blinking | |
302 bra TFT_memo_color ; - set memo color and return | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
303 TFT_color_code_depth_warn: |
604 | 304 bsf blinking_depth_warning ; activate warning blinking |
582 | 305 bra TFT_warnings_color ; set to warning color and return... |
604 | 306 TFT_color_code_depth_att: |
307 bsf blinking_depth_attention ; activate attention blinking | |
308 bra TFT_attention_color ; set to attention color and return... | |
582 | 309 |
310 | |
311 global TFT_color_code_cns | |
312 TFT_color_code_cns: ; color-code CNS values (CNS in hi:lo [%]) | |
560 | 313 btfss hi,int_invalid_flag ; is the invalid flag set? |
314 bra TFT_color_code_cns_1 ; NO | |
582 | 315 bcf hi,int_invalid_flag ; YES - clear invalid flag |
604 | 316 bcf hi,int_warning_flag ; clear warning flag (it may be set) |
582 | 317 bcf hi,int_attention_flag ; clear attention flag (it may be set) |
318 bra TFT_disabled_color ; set to disabled color and return | |
560 | 319 TFT_color_code_cns_1 |
320 btfss hi,int_warning_flag ; is the warning flag set? | |
321 bra TFT_color_code_cns_2 ; NO | |
604 | 322 bcf hi,int_warning_flag ; YES - clear warning flag |
323 bcf hi,int_attention_flag ; - clear attention flag (it may be set) | |
324 bra TFT_warnings_color ; - set to warning color and return | |
560 | 325 TFT_color_code_cns_2: |
582 | 326 btfss hi,int_attention_flag ; is the attention flag set? |
604 | 327 bra TFT_memo_color ; NO - set to memo color and return |
582 | 328 bcf hi,int_attention_flag ; YES - clear attention flag |
604 | 329 bra TFT_attention_color ; - set to attention color and return |
560 | 330 |
0 | 331 |
332 TFT_color_code_gf: | |
582 | 333 ; with int_O_gradient_factor, the upper byte is solely used for the flags |
334 ; and not for the value, thus there is no need to clear the flags | |
335 btfsc hi,int_invalid_flag ; is the invalid flag set? | |
336 bra TFT_disabled_color ; YES - set to disabled color and return | |
337 btfsc hi,int_warning_flag ; NO - is the warning flag set? | |
338 bra TFT_warnings_color ; YES - set to warning color and return | |
339 btfsc hi,int_attention_flag ; NO - is the attention flag set? | |
340 bra TFT_attention_color ; YES - set to attention color and return | |
604 | 341 bra TFT_memo_color ; NO - set to memo color and return |
582 | 342 |
343 | |
344 TFT_color_code_ppo2: ; color-code ppO2 values (ppO2 in hi:lo [cbar]) by its warning flags | |
560 | 345 btfss hi,int_warning_flag ; is the warning flag set? |
346 bra TFT_color_code_ppo2_1 ; NO | |
582 | 347 bcf hi,int_warning_flag ; YES - clear warning flag |
348 bcf hi,int_attention_flag ; clear attention flag (it may be set) | |
349 bcf hi,int_high_flag ; clear high warning flag (it may be set) | |
350 bcf hi,int_low_flag ; clear low warning flag (it may be set) | |
351 bra TFT_warnings_color ; warn in warning color | |
560 | 352 TFT_color_code_ppo2_1: |
582 | 353 btfss hi,int_attention_flag ; is the attention flag set? |
354 bra TFT_color_code_ppo2_2 ; NO | |
355 bcf hi,int_attention_flag ; YES - clear attention flag (it may be set) | |
356 bcf hi,int_high_flag ; clear high warning flag (it may be set) | |
357 bcf hi,int_low_flag ; clear low warning flag (it may be set) | |
608 | 358 bra TFT_attention_color ; set to attention color and return |
582 | 359 TFT_color_code_ppo2_2: |
360 bcf hi,int_high_flag ; clear high warning flag (it may be set) | |
361 bcf hi,int_low_flag ; clear low warning flag (it may be set) | |
604 | 362 bra TFT_memo_color ; set to memo color and return |
560 | 363 |
364 | |
582 | 365 TFT_color_code_ppo2_hud: ; color-code ppO2 values (ppO2 in --:lo [cbar]) by its value |
604 | 366 movff char_O_deco_info,WREG ; get the deco info vector |
560 | 367 btfss WREG,deco_flag ; are we in deco? |
368 bra TFT_color_code_ppo2_hud_a ; NO - load normal max value as threshold | |
369 movff char_I_ppO2_max_deco,WREG ; YES - load deco value as threshold | |
370 bra TFT_color_code_ppo2_hud_b | |
582 | 371 TFT_color_code_ppo2_hud_a: |
560 | 372 movff char_I_ppO2_max,WREG ; ppO2 max while not in deco |
582 | 373 TFT_color_code_ppo2_hud_b: |
374 cpfsgt lo ; lo > threshold? | |
375 bra TFT_color_code_ppo2_hud1 ; NO - continue with checking for ppO2 low | |
376 bra TFT_warnings_color ; YES - set warning color and return | |
0 | 377 TFT_color_code_ppo2_hud1: |
560 | 378 movff opt_dive_mode,WREG ; 0=OC, 1=CC, 2=Gauge, 3=Apnea, 4=PSCR |
379 decfsz WREG,F ; now: 0=CC, 1=Gauge, 2=Apnea, 3=PSCR | |
380 bra TFT_color_code_ppo2_hud_nocc; not CCR... | |
604 | 381 btfsc FLAG_bailout_mode |
560 | 382 bra TFT_color_code_ppo2_hud_nocc; is bailout, hence not loop mode... |
383 movff char_I_ppO2_min_loop,WREG ; ppO2 min loop mode color coding | |
384 bra TFT_color_code_ppo2_hud_cont | |
385 TFT_color_code_ppo2_hud_nocc: | |
386 movff char_I_ppO2_min,WREG ; PPO2 min for all other modes | |
387 TFT_color_code_ppo2_hud_cont: | |
582 | 388 cpfslt lo ; lo < char_I_ppO2_min? |
604 | 389 bra TFT_memo_color ; NO - set memo color and return... |
390 bra TFT_warnings_color ; Yes - set warning color and return | |
582 | 391 |
392 | |
393 TFT_color_code_battery: ; color-code the battery display, with battery percent in lo | |
394 movlw color_code_battery_low ; get warning threshold | |
395 cpfsgt lo ; is battery percent < threshold? | |
604 | 396 bra TFT_warnings_color ; YES - set to warning color and return |
397 bra TFT_memo_color ; NO - set to memo color and return | |
582 | 398 |
399 | |
400 global TFT_color_code_gas | |
401 TFT_color_code_gas: ; color-code the output according to gas number (1-6) in WREG | |
402 movwf up ; copy gas number (1-6) to up | |
403 movlw color_white ; Default color | |
404 dcfsnz up,F | |
604 | 405 movlw color_white ; color for gas 1 |
582 | 406 dcfsnz up,F |
604 | 407 movlw color_green ; color for gas 2 |
582 | 408 dcfsnz up,F |
604 | 409 movlw color_red ; color for gas 3 |
582 | 410 dcfsnz up,F |
604 | 411 movlw color_yellow ; color for gas 4 |
582 | 412 dcfsnz up,F |
604 | 413 movlw color_cyan ; color for gas 5 |
582 | 414 dcfsnz up,F |
604 | 415 movlw color_pink ; color for gas 6 |
416 goto TFT_set_color ; set color... | |
582 | 417 |
0 | 418 |
419 ; **************************************************************************** | |
420 | |
582 | 421 global TFT_show_OC_startgas_surface |
604 | 422 TFT_show_OC_startgas_surface: ; show first gas and "OSTC2-like" active gases |
582 | 423 ; Show first gas |
424 WIN_SMALL surf_decotype_column+.1,surf_decotype_row+.30 | |
604 | 425 call get_first_gas_to_WREG ; get first gas (1-5) into WREG |
560 | 426 decf WREG,W ; 1-5 -> 0-4 |
582 | 427 movwf PRODL |
604 | 428 call gaslist_strcat_gas ; input: PRODL : gas number (0..4), Output: Text appended into buffer pointed by FSR2. |
582 | 429 STRCAT_PRINT "" |
430 ; Show boxes | |
431 WIN_TOP surf_decotype_row+.30+.25 | |
432 WIN_LEFT surf_decotype_boxes_left1+.1 | |
433 rcall TFT_disabled_color | |
434 movff opt_gas_type+0,hi ; 0=Disabled, 1=First, 2=Travel, 3=Deco | |
435 tstfsz hi | |
436 rcall TFT_standard_color | |
437 STRCPY_PRINT "1" | |
438 decfsz hi,F ; Type = 1 (First)? | |
604 | 439 bra DISP_active_gas_surfmode3 ; NO - skip box |
582 | 440 WIN_FRAME_STD surf_decotype_boxes_top, surf_decotype_boxes_bottom, surf_decotype_boxes_left1, surf_decotype_boxes_left1+.8 ;top, bottom, left, right |
234
57155164faad
Show OSTC2-like active gas boxes in surface mode
heinrichsweikamp
parents:
231
diff
changeset
|
441 DISP_active_gas_surfmode3: |
582 | 442 rcall TFT_disabled_color |
443 movff opt_gas_type+1,hi ; 0=Disabled, 1=First, 2=Travel, 3=Deco | |
444 tstfsz hi | |
445 rcall TFT_standard_color | |
446 WIN_LEFT surf_decotype_boxes_left2+.1 | |
447 STRCPY_PRINT "2" | |
448 decfsz hi,F ; Type = 1 (First)? | |
604 | 449 bra DISP_active_gas_surfmode4 ; NO - skip box |
582 | 450 WIN_FRAME_STD surf_decotype_boxes_top, surf_decotype_boxes_bottom, surf_decotype_boxes_left2, surf_decotype_boxes_left2+.8 ;top, bottom, left, right |
234
57155164faad
Show OSTC2-like active gas boxes in surface mode
heinrichsweikamp
parents:
231
diff
changeset
|
451 DISP_active_gas_surfmode4: |
582 | 452 rcall TFT_disabled_color |
453 movff opt_gas_type+2,hi ; 0=Disabled, 1=First, 2=Travel, 3=Deco | |
454 tstfsz hi | |
455 rcall TFT_standard_color | |
456 WIN_LEFT surf_decotype_boxes_left3+.1 | |
457 STRCPY_PRINT "3" | |
458 decfsz hi,F ; Type = 1 (First)? | |
604 | 459 bra DISP_active_gas_surfmode5 ; NO - skip box |
582 | 460 WIN_FRAME_STD surf_decotype_boxes_top, surf_decotype_boxes_bottom, surf_decotype_boxes_left3, surf_decotype_boxes_left3+.8 ;top, bottom, left, right |
234
57155164faad
Show OSTC2-like active gas boxes in surface mode
heinrichsweikamp
parents:
231
diff
changeset
|
461 DISP_active_gas_surfmode5: |
582 | 462 rcall TFT_disabled_color |
463 movff opt_gas_type+3,hi ; 0=Disabled, 1=First, 2=Travel, 3=Deco | |
464 tstfsz hi | |
465 rcall TFT_standard_color | |
466 WIN_LEFT surf_decotype_boxes_left4+.1 | |
467 STRCPY_PRINT "4" | |
468 decfsz hi,F ; Type = 1 (First)? | |
604 | 469 bra DISP_active_gas_surfmode6 ; NO - skip box |
582 | 470 WIN_FRAME_STD surf_decotype_boxes_top, surf_decotype_boxes_bottom, surf_decotype_boxes_left4, surf_decotype_boxes_left4+.8 ;top, bottom, left, right |
234
57155164faad
Show OSTC2-like active gas boxes in surface mode
heinrichsweikamp
parents:
231
diff
changeset
|
471 DISP_active_gas_surfmode6: |
582 | 472 rcall TFT_disabled_color |
473 movff opt_gas_type+4,hi ; 0=Disabled, 1=First, 2=Travel, 3=Deco | |
474 tstfsz hi | |
475 rcall TFT_standard_color | |
476 WIN_LEFT surf_decotype_boxes_left5+.1 | |
477 STRCPY_PRINT "5" | |
604 | 478 rcall TFT_standard_color ; reset color |
479 decfsz hi,F ; type = 1 (First)? | |
480 bra DISP_active_gas_surfmode7 ; NO - done | |
582 | 481 WIN_FRAME_STD surf_decotype_boxes_top, surf_decotype_boxes_bottom, surf_decotype_boxes_left5, surf_decotype_boxes_left5+.8 ;top, bottom, left, right |
604 | 482 DISP_active_gas_surfmode7: |
483 return ; done | |
582 | 484 |
485 | |
486 global TFT_show_color_schemes | |
560 | 487 TFT_show_color_schemes: ; update the color schemes |
582 | 488 bsf divemode ; put in divemode |
489 call TFT_divemask_color | |
490 WIN_TINY .12,.40 | |
491 STRCAT_TEXT_PRINT tDepth | |
492 WIN_TINY .62,.40 | |
493 STRCAT_TEXT_PRINT tMaxDepth | |
494 WIN_TINY .122,.40 | |
495 STRCAT_TEXT_PRINT tDivetime | |
496 | |
497 ; Show some demo screen | |
498 | |
499 ; Depth demo | |
604 | 500 call TFT_memo_color |
501 WIN_MEDIUM .3,.54 | |
582 | 502 movlw LOW .5172 |
503 movwf lo | |
504 movlw HIGH .5172 | |
505 movwf hi | |
50 | 506 bsf leftbind |
507 bsf ignore_digit4 | |
604 | 508 output_16 ; full meters in big font |
50 | 509 bcf leftbind |
604 | 510 STRCAT_PRINT "" ; display full meters |
511 WIN_SMALL .25,.66 | |
512 movlw LOW .5172 | |
582 | 513 movwf lo |
604 | 514 movlw HIGH .5172 |
582 | 515 movwf hi |
516 PUTC "." | |
50 | 517 movlw d'4' |
518 movwf ignore_digits | |
604 | 519 bsf ignore_digit5 ; (flag will be cleared by output_16) |
582 | 520 output_16dp d'0' ; .1m in SMALL font |
604 | 521 STRCAT_PRINT "" ; display decimeters |
582 | 522 WIN_FONT FT_SMALL |
523 | |
524 ; Max. Depth demo | |
604 | 525 WIN_MEDIUM .64,.54 |
582 | 526 bsf ignore_digit4 ; no 0.1m |
527 bsf leftbind | |
604 | 528 movlw LOW .6349 |
582 | 529 movwf lo |
604 | 530 movlw HIGH .6349 |
582 | 531 movwf hi |
50 | 532 output_16 |
604 | 533 STRCAT_PRINT "" ; display full meters |
582 | 534 bcf leftbind |
50 | 535 ; .1m in SMALL font |
582 | 536 WIN_SMALL .87,.66 |
537 PUTC "." | |
50 | 538 movlw d'4' |
539 movwf ignore_digits | |
604 | 540 bsf ignore_digit5 ; (flag will be cleared by output_16) |
582 | 541 bsf leftbind |
604 | 542 movlw LOW .6349 |
582 | 543 movwf lo |
604 | 544 movlw HIGH .6349 |
582 | 545 movwf hi |
50 | 546 output_16dp d'0' |
604 | 547 STRCAT_PRINT "" ; display decimeters |
582 | 548 bcf leftbind |
549 | |
550 ; Divetime demo | |
551 movff mins,lo | |
552 clrf hi | |
553 WIN_MEDIUM .103, .54 | |
554 output_16_3 ; limit to 999 and display only (0-999) | |
604 | 555 STRCAT_PRINT "" ; show minutes in large font |
582 | 556 WIN_SMALL .139, .66 ; left position for two sec figures |
557 PUTC ':' | |
50 | 558 bsf leftbind |
582 | 559 movff secs,lo |
50 | 560 output_99x |
582 | 561 bcf leftbind |
604 | 562 STRCAT_PRINT "" ; show seconds in small font |
582 | 563 |
564 bcf divemode ; don't stay in divemode | |
50 | 565 return |
566 | |
604 | 567 |
0 | 568 global TFT_divemode_mask |
604 | 569 TFT_divemode_mask: ; displays mask in divemode |
582 | 570 bcf FLAG_TFT_divemode_mask |
571 call TFT_divemask_color | |
560 | 572 WIN_TINY dm_mask_depth_column,dm_mask_depth_row |
582 | 573 STRCAT_TEXT_PRINT tDepth |
560 | 574 WIN_TINY dm_mask_maxdepth_column_nvsi,dm_mask_maxdepth_row |
604 | 575 TSTOSS opt_vsigraph ; graphical VSI bar enabled? |
576 bra TFT_divemode_mask_1 ; NO | |
577 WIN_TINY dm_mask_maxdepth_column,dm_mask_maxdepth_row ; YES - adopt position | |
578 TFT_divemode_mask_1: | |
579 btfsc FLAG_apnoe_mode ; in Apnea mode? | |
580 bra TFT_divemode_mask_2 ; YES - draw max depth | |
581 TSTOSS opt_2ndDepthDisp ; draw avg depth? | |
582 bra TFT_divemode_mask_2 ; NO - draw max depth | |
583 STRCAT_TEXT_PRINT tAvgDepth ; YES | |
584 bra TFT_divemode_mask_3 | |
585 TFT_divemode_mask_2: | |
582 | 586 STRCAT_TEXT_PRINT tMaxDepth |
604 | 587 TFT_divemode_mask_3: |
560 | 588 WIN_TINY dm_mask_divetime_column,dm_mask_divetime_row |
582 | 589 STRCAT_TEXT_PRINT tDivetime |
590 bra TFT_standard_color ; and return... | |
591 | |
592 global TFT_divemode_mask_alternative | |
604 | 593 TFT_divemode_mask_alternative: ; alt. mask for divemode |
582 | 594 bcf FLAG_TFT_divemode_mask_alt |
595 call TFT_divemask_color | |
596 WIN_TINY dm_mask_depth_column,dm_mask_depth_row | |
597 STRCAT_TEXT_PRINT tDepth | |
598 WIN_TINY dm_mask_divetime_column-.30,dm_mask_divetime_row | |
599 STRCAT_TEXT_PRINT tDivetime | |
600 bra TFT_standard_color ; and return... | |
601 | |
602 global TFT_draw_gassep_line | |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
603 TFT_draw_gassep_line: |
604 | 604 btfsc FLAG_apnoe_mode ; ignore in Apnoe mode |
582 | 605 return |
604 | 606 btfsc divemode_menu ; is the dive mode menu shown? |
607 return ; YES - return | |
608 bra TFT_standard_color ; NO - set standard color and return | |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
609 |
307
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
610 ;========================================================================= |
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
611 |
0 | 612 global TFT_display_velocity |
604 | 613 TFT_display_velocity: ; with divA+0 = m/min, neg_flag_velocity: ascend=1, descend=0 |
582 | 614 bcf STATUS,C |
615 movlw velocity_display_threshold_1; lowest threshold for display vertical velocity | |
616 subwf divA+0,W | |
617 btfss STATUS,C | |
618 bra TFT_velocity_clear ; lower then threshold. Clear text and graph (If active) | |
619 | |
620 ; We have something to display | |
604 | 621 bsf display_velocity ; set flag |
582 | 622 ; check if descending: no warning color if descending |
604 | 623 rcall TFT_memo_color |
624 btfsc neg_flag_velocity ; ignore for descent | |
625 rcall TFT_velocity_set_color ; set color for text and set threshold for graph | |
626 | |
627 rcall TFT_velocity_disp ; show the text | |
628 | |
629 TSTOSS opt_vsigraph ; graphical VSI bar enabled? | |
630 bra TFT_display_velocity_done ; NO | |
631 | |
632 btfsc alternative_divelayout ; alternative layout? | |
633 bra TFT_display_velocity_done ; YES - no graph! (no room when divetime minutes is three digits) | |
634 | |
635 btfsc neg_flag_velocity ; ignore for descent | |
636 rcall TFT_velocity_graph ; show the graph | |
637 btfss neg_flag_velocity ; ignore for descent | |
638 rcall TFT_velocity_clear_graph ; clear the graph for descent | |
582 | 639 |
640 TFT_display_velocity_done: | |
641 bra TFT_standard_color ; and return! | |
398
1f2e35f5a5aa
BUGFIX: Make sure SP1 is always selected on start in Auto-SP mode
heinrichsweikamp
parents:
394
diff
changeset
|
642 |
1f2e35f5a5aa
BUGFIX: Make sure SP1 is always selected on start in Auto-SP mode
heinrichsweikamp
parents:
394
diff
changeset
|
643 TFT_speed_table: |
582 | 644 ; use a depth-dependent ascent rate warning |
645 ; depth(ft): <20 >20 >40 >60 >75 >88 >101 >115 >128 >144 >164 | |
646 ; speed(ft/min): 23 26 29 33 36 43 49 56 59 62 66 | |
647 ; depth(m): <=6 >6 >12 >18 >23 >27 >31 >35 >39 >44 >50 | |
648 ; speed(m/min): 7 8 9 10 11 13 15 17 18 19 20 (warning) | |
307
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
649 ; speed(m/min): 5 6 7 8 8 10 12 13 14 15 15 (attention) |
398
1f2e35f5a5aa
BUGFIX: Make sure SP1 is always selected on start in Auto-SP mode
heinrichsweikamp
parents:
394
diff
changeset
|
650 |
582 | 651 ; <xx m, warning speed, attention speed, unused |
652 DB .6,.7,.5,.0 | |
653 DB .12,.8,.6,.0 | |
654 DB .18,.9,.7,.0 | |
655 DB .23,.10,.8,.0 | |
656 DB .27,.11,.8,.0 | |
657 DB .31,.13,.10,.0 | |
658 DB .35,.15,.12,.0 | |
659 DB .39,.17,.13,.0 | |
660 DB .44,.18,.14,.0 | |
661 DB .50,.19,.15,.0 | |
662 DB .200,.20,.15,.0 | |
663 | |
664 TFT_velocity_set_color: ; Set color based on speed table or use static thresholds, with divA+0 = m/min | |
665 ; check if old/new ascend logic is used | |
666 TSTOSS opt_vsitextv2 ; 0=standard, 1=dynamic | |
667 bra TFT_velocity_set_color_static ; static ascend rate limit | |
668 | |
669 ; point to speed table | |
670 movlw LOW (TFT_speed_table-.3) | |
671 movwf TBLPTRL | |
672 movlw HIGH (TFT_speed_table-.3) | |
673 movwf TBLPTRH | |
674 movlw UPPER (TFT_speed_table-.3) | |
675 movwf TBLPTRU | |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
676 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
677 TFT_velocity_set_color_skip: |
582 | 678 TBLRD*+ ; 3 dummy reads |
679 TBLRD*+ | |
680 TBLRD*+ | |
604 | 681 TBLRD*+ ; get speed threshold |
682 movf curr_depth,W ; current depth in m | |
683 cpfsgt TABLAT ; threshold > current depth ? | |
684 bra TFT_velocity_set_color_skip ; NO - loop | |
685 | |
686 TBLRD*+ ; get warning speed threshold | |
582 | 687 movf TABLAT,W |
604 | 688 movwf divA+1 ; copy for graph routine |
582 | 689 cpfslt divA+0 ; smaller then actual value (in m/min)? |
604 | 690 bra TFT_warnings_color ; set Warning color (And return) |
691 TBLRD*+ ; get attention speed threshold | |
582 | 692 movf TABLAT,W |
693 cpfslt divA+0 ; smaller then actual value (in m/min)? | |
604 | 694 bra TFT_attention_color ; NO - set attention color and return |
695 bra TFT_memo_color ; YES - set memo color and return | |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
696 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
697 TFT_velocity_set_color_static: |
582 | 698 movlw color_code_velocity_warn_high ; in m/min |
604 | 699 movwf divA+1 ; copy for graph routine |
582 | 700 cpfslt divA+0 ; smaller then actual value (in m/min)? |
604 | 701 bra TFT_warnings_color ; set Warning color (And return) |
582 | 702 movlw color_code_velocity_attn_high ; in m/min |
703 cpfslt divA+0 ; smaller then actual value (in m/min)? | |
604 | 704 bra TFT_attention_color ; NO - set attention color and return |
705 bra TFT_memo_color ; YES - set memo color and return | |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
706 |
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
707 TFT_velocity_disp: |
604 | 708 WIN_SMALL dm_velocity_text_column, dm_velocity_text_row |
582 | 709 TSTOSS opt_units ; 0=Meters, 1=Feets |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
710 bra TFT_velocity_metric |
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
711 ;TFT_velocity_imperial: |
0 | 712 movff divA+0,WREG ; divA+0 = m/min |
713 mullw .100 ; PRODL:PRODH = mbar/min | |
714 movff PRODL,lo | |
715 movff PRODH,hi | |
604 | 716 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet |
0 | 717 movlw '-' |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
718 btfsc neg_flag_velocity |
0 | 719 movlw '+' |
720 movwf POSTINC2 | |
721 bsf leftbind | |
722 output_16 | |
723 bcf leftbind | |
604 | 724 STRCAT_TEXT_PRINT tVelImperial ; unit switch |
582 | 725 return |
0 | 726 |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
727 TFT_velocity_metric: |
0 | 728 movff divA+0,lo ; divA+0 = m/min |
729 movlw '-' | |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
730 btfsc neg_flag_velocity |
0 | 731 movlw '+' |
732 movwf POSTINC2 | |
733 output_99 | |
604 | 734 STRCAT_TEXT_PRINT tVelMetric ; unit switch |
582 | 735 return |
736 | |
737 TFT_velocity_graph: ; divA+0 = m/min | |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
738 ; divA+0 holding the ascend speed in m/min |
604 | 739 movff divA+0,hi ; copy |
582 | 740 WIN_BOX_BLACK dm_velobar_top, dm_velobar_bot, dm_velobar_lft, dm_velobar_rgt ;top, bottom, left, right -> outer frame |
604 | 741 rcall TFT_divemask_color_dive ; color -> WREG |
582 | 742 WIN_FRAME_COLOR dm_velobar_top, dm_velobar_bot, dm_velobar_lft, dm_velobar_rgt ;inner frame |
604 | 743 rcall TFT_divemask_color_dive ; color -> WREG |
582 | 744 WIN_FRAME_COLOR dm_velobar_top+.10, dm_velobar_bot-.10, dm_velobar_lft, dm_velobar_rgt ;inner frame |
604 | 745 rcall TFT_divemask_color_dive ; color -> WREG |
582 | 746 WIN_FRAME_COLOR dm_velobar_top+.20, dm_velobar_bot-.20, dm_velobar_lft, dm_velobar_rgt ;inner frame |
604 | 747 rcall TFT_divemask_color_dive ; color -> WREG |
582 | 748 WIN_FRAME_COLOR dm_velobar_top+.30, dm_velobar_bot-.30, dm_velobar_lft, dm_velobar_rgt ;inner frame |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
749 |
582 | 750 movff divA+1,xA+0 ; m/min for warning level (upper two blocks) |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
751 clrf xA+1 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
752 movlw .5 |
604 | 753 movwf xB+0 ; threshold for color warning (5 color normal + 2 color warning) |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
754 clrf xB+1 |
604 | 755 call div16x16 ; xC = xA / xB with xA as remainder |
582 | 756 ; xC+0 holds step size in m/min (e.g. =3 for 15m/min warning threshold) |
604 | 757 movff hi,xA+0 ; velocity in m/min |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
758 clrf xA+1 |
604 | 759 movff xC+0,xB+0 ; step size |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
760 clrf xB+1 |
604 | 761 call div16x16 ; xC = xA / xB with xA as remainder |
762 ; xC+0 now holds amount of segments to show | |
763 movff hi,divA+0 ; copy back for numeric output | |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
764 movlw d'7' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
765 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
766 bra DISP_graph_vel_7 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
767 movlw d'6' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
768 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
769 bra DISP_graph_vel_6 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
770 movlw d'5' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
771 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
772 bra DISP_graph_vel_5 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
773 movlw d'4' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
774 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
775 bra DISP_graph_vel_4 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
776 movlw d'3' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
777 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
778 bra DISP_graph_vel_3 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
779 movlw d'2' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
780 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
781 bra DISP_graph_vel_2 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
782 movlw d'1' |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
783 cpfslt xC+0 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
784 bra DISP_graph_vel_1 |
604 | 785 bra DISP_graph_vel_0 ; should not happen... |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
786 |
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
787 DISP_graph_vel_7: |
604 | 788 rcall TFT_warnings_color_dive ; color -> WREG |
582 | 789 WIN_BOX_COLOR dm_velobar_top+.2, dm_velobar_top+.8, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
790 DISP_graph_vel_6: |
604 | 791 rcall TFT_warnings_color_dive ; color -> WREG |
582 | 792 WIN_BOX_COLOR dm_velobar_top+.12, dm_velobar_top+.18, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
793 DISP_graph_vel_5: |
604 | 794 rcall TFT_attention_color_dive ; color -> WREG |
582 | 795 WIN_BOX_COLOR dm_velobar_top+.22, dm_velobar_top+.28, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
796 DISP_graph_vel_4: |
604 | 797 rcall TFT_standard_color_dive ; color -> WREG |
582 | 798 WIN_BOX_COLOR dm_velobar_top+.32, dm_velobar_top+.38, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
799 DISP_graph_vel_3: |
604 | 800 rcall TFT_standard_color_dive ; color -> WREG |
582 | 801 WIN_BOX_COLOR dm_velobar_top+.42, dm_velobar_top+.48, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
802 DISP_graph_vel_2: |
604 | 803 rcall TFT_standard_color_dive ; color -> WREG |
582 | 804 WIN_BOX_COLOR dm_velobar_top+.52, dm_velobar_top+.58, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
805 DISP_graph_vel_1: |
604 | 806 rcall TFT_standard_color_dive ; color -> WREG |
582 | 807 WIN_BOX_COLOR dm_velobar_top+.62, dm_velobar_top+.68, dm_velobar_lft+.2, dm_velobar_rgt-.2 ;top, bottom, left, right |
399
db25f2028074
CHANGE: New segmented speed graph in divemode
heinrichsweikamp
parents:
398
diff
changeset
|
808 DISP_graph_vel_0: |
604 | 809 return ; done |
810 | |
326
d21b172d5a7a
VSIbar #4: VSI settings submenu, graph option, logbook offset and compass calib. menu exit fix
Janos Kovacs <kovjanos@gmail.com>
parents:
321
diff
changeset
|
811 |
315
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
812 global TFT_velocity_clear |
4f83470dcece
VSIbar #3: remaining changes for the split style bar
Janos Kovacs <kovjanos@gmail.com>
parents:
310
diff
changeset
|
813 TFT_velocity_clear: |
604 | 814 btfss display_velocity ; velocity was not displayed, do not delete |
307
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
815 return |
604 | 816 bcf display_velocity ; velocity was displayed, delete velocity now |
0 | 817 ; Clear Text |
582 | 818 WIN_BOX_BLACK dm_velocity_text_row, dm_velocity_text_bot, dm_velocity_text_column, dm_velocity_text_rgt ; top, bottom, left, right |
819 | |
604 | 820 TSTOSS opt_vsigraph ; graphical VSI bar enabled? |
821 return ; NO - no graph to clear | |
398
1f2e35f5a5aa
BUGFIX: Make sure SP1 is always selected on start in Auto-SP mode
heinrichsweikamp
parents:
394
diff
changeset
|
822 TFT_velocity_clear_graph: |
582 | 823 ; Clear Graph |
604 | 824 WIN_BOX_BLACK dm_velobar_top, dm_velobar_bot, dm_velobar_lft, dm_velobar_rgt ; top, bottom, left, right |
0 | 825 return |
826 | |
307
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
827 ;========================================================================= |
14719662fb95
Merged Screen layout work #4 into VSItextv2
Janos Kovacs <kovjanos@gmail.com>
parents:
303
diff
changeset
|
828 |
582 | 829 global TFT_clear_decoarea |
0 | 830 TFT_clear_decoarea: |
604 | 831 WIN_BOX_BLACK dm_decostop_1st_stop_row, .239, dm_decostop_1st_stop_column, .159 ; top, bottom, left, right |
0 | 832 return |
833 | |
560 | 834 |
582 | 835 global TFT_clear_divemode_menu |
0 | 836 TFT_clear_divemode_menu: |
604 | 837 WIN_BOX_BLACK dm_menu_row-.2, dm_menu_lower, dm_menu_left, dm_menu_right ; top, bottom, left, right - starts 2 pixel higher to completely wipe away the temperature display |
0 | 838 return |
839 | |
560 | 840 |
0 | 841 global TFT_display_ndl_mask |
842 TFT_display_ndl_mask: | |
582 | 843 bcf FLAG_TFT_display_ndl_mask |
604 | 844 btfsc divemode_menu ; is the dive mode menu shown? |
845 return ; YES - return | |
846 btfsc FLAG_gauge_mode ; in gauge mode? | |
847 return ; YES - return | |
848 call TFT_clear_decoarea ; NO - clear stop depth and TTS | |
582 | 849 call TFT_divemask_color |
850 WIN_STD dm_ndl_text_column, dm_ndl_text_row | |
851 STRCPY_TEXT_PRINT tNDL ; NDL | |
852 bra TFT_standard_color ; and return... | |
560 | 853 |
854 | |
855 global TFT_display_tts | |
856 TFT_display_tts: | |
582 | 857 bcf FLAG_TFT_display_tts |
604 | 858 btfsc divemode_menu ; is the dive mode menu shown? |
859 return ; YES - return | |
860 call TFT_memo_color ; NO - set memo color | |
861 movff int_O_ascenttime+0,lo ; - TTS | |
862 movff int_O_ascenttime+1,hi ; - on 16 bits | |
863 btfss hi,int_invalid_flag ; - is the invalid flag set? | |
864 bra TFT_display_tts_1 ; - NO | |
865 bcf hi,int_invalid_flag ; - YES - clear flag | |
866 call TFT_disabled_color ; - switch to disabled color | |
560 | 867 TFT_display_tts_1: |
582 | 868 WIN_MEDIUM dm_tts_value_column, dm_tts_value_row |
604 | 869 output_16_3 ; display only 0...999 |
0 | 870 STRCAT_PRINT "'" |
871 return | |
872 | |
560 | 873 |
0 | 874 global TFT_display_ndl |
875 TFT_display_ndl: | |
582 | 876 bcf FLAG_TFT_display_ndl |
604 | 877 btfsc divemode_menu ; is the dive mode menu shown? |
878 return ; YES - return | |
582 | 879 WIN_MEDIUM dm_ndl_value_column, dm_ndl_value_row |
604 | 880 call TFT_memo_color |
881 movff char_O_nullzeit,lo ; get NDL from C-code | |
582 | 882 output_8 |
883 STRCAT_PRINT "'" | |
884 return | |
885 | |
886 | |
604 | 887 global TFT_big_deco_alt ; the big deco |
560 | 888 TFT_big_deco_alt: |
582 | 889 bcf FLAG_TFT_big_deco_alt |
890 | |
604 | 891 btfss decostop_active ; deco stop shown? |
892 bra TFT_big_deco_ndl_alt ; NO - show NDL | |
582 | 893 |
894 ; Deco | |
895 bcf FLAG_TFT_display_deko | |
896 call TFT_divemask_color | |
897 WIN_STD .70,.165 | |
898 STRCPY_TEXT_PRINT tTTS ; TTS | |
604 | 899 rcall TFT_memo_color |
582 | 900 |
901 ; TTS | |
902 WIN_LARGE .97,.170 | |
604 | 903 movff int_O_ascenttime+0,lo ; get the TTS |
904 movff int_O_ascenttime+1,hi ; | |
582 | 905 btfss hi,int_invalid_flag ; is the invalid flag set? |
906 bra TFT_display_tts_alt_1 ; NO | |
907 bcf hi,int_invalid_flag ; YES - clear flag | |
604 | 908 call TFT_disabled_color ; - switch to disabled color |
560 | 909 TFT_display_tts_alt_1: |
604 | 910 output_16_3 ; display only 0...999 |
582 | 911 STRCAT_PRINT "" |
912 | |
913 ; 1st Stop | |
914 call TFT_divemask_color | |
915 WIN_STD .25,dm_customview_row | |
916 STRCPY_TEXT_PRINT tDiveSafetyStop ; "Stop" | |
917 | |
918 WIN_LARGE .60,.95 | |
604 | 919 call TFT_color_code_stop ; color-code output |
920 movff char_O_first_deco_depth,lo ; stop depth in m | |
921 rcall TFT_display_deko_output_depth ; output depth (stored in lo) to POSTINC2 with "m" or w/o (for ft) | |
582 | 922 STRCAT_PRINT "" |
923 | |
924 ; m or ft after the stop depth | |
925 WIN_MEDIUM .100,.118 | |
926 TSTOSS opt_units ; 0=m, 1=ft | |
927 bra TFT_display_tts_alt_1_metric | |
928 STRCAT_TEXT_PRINT tFeets1 | |
929 bra TFT_display_tts_alt_1_com | |
560 | 930 TFT_display_tts_alt_1_metric: |
582 | 931 STRCAT_TEXT_PRINT tMeters |
560 | 932 TFT_display_tts_alt_1_com: |
582 | 933 WIN_LARGE .117,.95 |
604 | 934 movff char_O_first_deco_time,lo ; get stop time in minutes |
935 tstfsz lo ; stop time = 0 ? | |
936 bra TFT_display_tts_alt_2 ; NO - print time | |
937 STRCAT_PRINT ".." ; YES - special treatment | |
938 bra TFT_display_tts_alt_exit | |
939 TFT_display_tts_alt_2: | |
582 | 940 bcf leftbind |
941 output_99 | |
942 STRCAT_PRINT "" | |
604 | 943 TFT_display_tts_alt_exit: |
582 | 944 goto TFT_standard_color ; and return... |
604 | 945 |
946 | |
560 | 947 TFT_big_deco_ndl_alt: |
582 | 948 ; NDL |
949 bcf FLAG_TFT_display_ndl | |
950 bcf decostop_active ; clear flag (again) | |
604 | 951 btfsc FLAG_gauge_mode ; in gauge mode? |
952 bra TFT_big_deco_ndl_alt_1 ; YES - skip NDL | |
582 | 953 call TFT_divemask_color |
954 WIN_STD .70,.165 | |
955 STRCPY_TEXT_PRINT tNDL ; NDL | |
604 | 956 call TFT_memo_color |
582 | 957 WIN_LARGE .97,.170 |
604 | 958 movff char_O_nullzeit,lo ; get NDL from C-code |
582 | 959 output_8 |
960 STRCAT_PRINT "" | |
604 | 961 TFT_big_deco_ndl_alt_1: |
582 | 962 btfsc FLAG_TFT_show_safety_stop |
604 | 963 bra TFT_show_safety_stop_alt ; show safety stop (and return) |
582 | 964 ; Clear any safety stop or Decostop |
560 | 965 TFT_no_more_safety_stop_alt: |
582 | 966 WIN_BOX_BLACK dm_customview_row, .150, .0, .159 ; top, bottom, left, right |
967 WIN_BOX_BLACK dm_customview_row, .164, .60, .159 ; top, bottom, left, right | |
968 return | |
560 | 969 |
970 TFT_show_safety_stop_alt: | |
582 | 971 bcf FLAG_TFT_show_safety_stop |
604 | 972 tstfsz safety_stop_countdown ; countdown at zero? |
973 bra TFT_show_safety_stop_alt2 ; NO - show stop | |
974 bcf show_safety_stop ; clear flag | |
975 btfss safety_stop_active ; displayed? | |
976 return ; NO | |
977 bcf safety_stop_active ; YES - clear flag | |
978 bra TFT_no_more_safety_stop_alt ; - clear stop and return | |
560 | 979 |
980 TFT_show_safety_stop_alt2: | |
604 | 981 bsf safety_stop_active ; set flag |
982 decf safety_stop_countdown,F ; reduce countdown | |
582 | 983 |
984 call TFT_divemask_color | |
985 WIN_STD .50,dm_customview_row | |
560 | 986 STRCPY_TEXT_PRINT tDiveSafetyStop |
582 | 987 call TFT_attention_color ; show in yellow |
560 | 988 WIN_LARGE .90,.95 |
989 movff safety_stop_countdown,lo | |
990 clrf hi | |
604 | 991 call convert_time ; converts hi:lo in seconds to mins (up:hi) and seconds (lo) |
560 | 992 movf hi,W |
993 movff lo,hi | |
994 movwf lo ; exchange lo and hi | |
582 | 995 bsf leftbind |
0 | 996 output_8 |
560 | 997 STRCAT_PRINT "" |
582 | 998 WIN_MEDIUM .112,.120 |
560 | 999 STRCAT_PRINT ":" |
582 | 1000 WIN_LARGE .117,.95 |
1001 bcf leftbind | |
560 | 1002 movff hi,lo |
1003 output_99x | |
1004 STRCAT_PRINT "" | |
582 | 1005 WIN_FONT FT_SMALL |
604 | 1006 bra TFT_display_exit_1 |
560 | 1007 |
0 | 1008 |
1009 global TFT_divemode_warning | |
1010 TFT_divemode_warning: | |
604 | 1011 bcf FLAG_TFT_divemode_warning ; clear job flag |
1012 bsf dive_warning_displayed ; set advice/attention/warning sign is shown flag | |
560 | 1013 WIN_TOP dm_warning_icon_row |
1014 WIN_LEFT dm_warning_icon_column | |
604 | 1015 btfsc message_warning ; do we have a warning? |
1016 bra TFT_divemode_warning_1 ; YES - show warning sign | |
1017 btfsc message_attention ; NO - do we have an attention? | |
1018 bra TFT_divemode_warning_2 ; YES - show attention sign | |
1019 bra TFT_divemode_warning_3 ; NO to both - must be an advice then | |
1020 | |
1021 dive_warning2_warning_colors: ; custom colors table for dive_warning2 icon - warning | |
1022 db .4, 0 ; #colors, spare | |
1023 dw 0x0000 ; color 0x00: outside black | |
1024 dw 0xff80 ; color 0x01: triangle yellow | |
1025 dw 0xff80 ; color 0x02: excl.mark yellow | |
1026 dw 0xf800 ; color 0x03: inside red | |
1027 | |
1028 dive_warning2_advice_colors: ; custom colors table for dive_warning2 icon - advice | |
1029 db .4, 0 ; #colors, spare | |
1030 dw 0x0000 ; color 0x00: outside black | |
1031 dw 0xffff ; color 0x01: triangle white | |
1032 dw 0xffff ; color 0x02: excl.mark white | |
1033 dw 0x0780 ; color 0x03: inside green | |
1034 | |
1035 TFT_divemode_warning_1: | |
1036 TFT_WRITE_PROM_IMAGE_CUST_COLOR dive_warning2_warning_colors | |
1037 TFT_WRITE_PROM_IMAGE_BY_LABEL dive_warning2_block ; output warning sign (with custom colors) | |
560 | 1038 return |
604 | 1039 TFT_divemode_warning_2: |
1040 TFT_WRITE_PROM_IMAGE_BY_LABEL dive_warning2_block ; output attention sign (with default colors) | |
1041 return | |
1042 TFT_divemode_warning_3: | |
1043 TFT_WRITE_PROM_IMAGE_CUST_COLOR dive_warning2_advice_colors | |
1044 TFT_WRITE_PROM_IMAGE_BY_LABEL dive_warning2_block ; output advice sign (with custom colors) | |
1045 return | |
1046 | |
0 | 1047 |
1048 global TFT_divemode_warning_clear | |
1049 TFT_divemode_warning_clear: | |
604 | 1050 bcf FLAG_TFT_divemode_warning_clear ; clear job flag |
1051 btfss dive_warning_displayed ; advice/attention/warning sign is shown? | |
1052 return ; NO | |
1053 bcf dive_warning_displayed ; YES - clear advice/attention/warning sign and its flag | |
582 | 1054 WIN_BOX_BLACK dm_warning_icon_row, dm_warning_icon_bot, dm_warning_icon_column, dm_warning_icon_rgt ; top, bottom, left, right |
560 | 1055 return |
1056 | |
604 | 1057 |
0 | 1058 global TFT_display_deko_mask |
1059 TFT_display_deko_mask: | |
582 | 1060 bcf FLAG_TFT_display_deko_mask |
604 | 1061 btfsc divemode_menu ; is the dive mode menu shown? |
1062 return ; YES - return | |
1063 rcall TFT_clear_decoarea ; clear decostop and decosum (and NDL in this case) | |
582 | 1064 WIN_STD dm_tts_text_column, dm_tts_text_row |
1065 call TFT_divemask_color | |
1066 STRCPY_TEXT_PRINT tTTS ; TTS | |
604 | 1067 bcf show_safety_stop ; clear safety stop flag |
1068 bra TFT_display_exit_1 | |
1069 | |
1070 | |
1071 TFT_display_deko_output_depth: ; output depth (stored in lo) to POSTINC2 with "m" or w/o (for ft) | |
0 | 1072 TSTOSS opt_units ; 0=m, 1=ft |
604 | 1073 bra TFT_display_deko_output_metric |
0 | 1074 ;TFT_display_deko_output_imperial: |
1075 movf lo,W ; lo = m | |
1076 mullw .100 ; PRODL:PRODH = mbar | |
1077 movff PRODL,lo | |
1078 movff PRODH,hi | |
604 | 1079 ; Convert with 334feet/100m to have 10ft, 20ft, 30ft stops... |
0 | 1080 movff lo,xA+0 |
1081 movff hi,xA+1 | |
582 | 1082 movlw LOW d'334' ; 334feet/100m |
0 | 1083 movwf xB+0 |
582 | 1084 movlw HIGH d'334' |
0 | 1085 movwf xB+1 |
582 | 1086 call mult16x16 ; xA*xB=xC (lo:hi * 328) |
1087 movlw d'50' ; round up | |
0 | 1088 addwf xC+0,F |
1089 movlw 0 | |
1090 addwfc xC+1,F | |
1091 addwfc xC+2,F | |
1092 addwfc xC+3,F | |
582 | 1093 movlw d'100' |
0 | 1094 movwf xB+0 |
1095 clrf xB+1 | |
582 | 1096 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder |
0 | 1097 movff xC+0,lo |
582 | 1098 movff xC+1,hi ; restore lo and hi with updated value |
0 | 1099 bcf leftbind |
560 | 1100 btfsc alternative_divelayout |
582 | 1101 bsf leftbind ; left for alternative layout mode |
604 | 1102 bsf ignore_digit4 ; only full feet |
0 | 1103 output_16 |
560 | 1104 btfsc alternative_divelayout |
604 | 1105 return ; not for alternative layout mode |
1106 STRCAT_TEXT tFeets1 | |
0 | 1107 return |
1108 | |
1109 TFT_display_deko_output_metric: | |
1110 output_99 | |
560 | 1111 btfsc alternative_divelayout |
604 | 1112 return ; not for alternative layout mode |
1113 STRCAT_TEXT tMeters | |
0 | 1114 PUTC ' ' |
1115 return | |
1116 | |
560 | 1117 |
0 | 1118 global TFT_display_deko |
1119 TFT_display_deko: | |
582 | 1120 bcf FLAG_TFT_display_deko |
604 | 1121 btfsc divemode_menu ; is the dive mode menu shown? |
1122 return ; YES - return | |
560 | 1123 WIN_MEDIUM dm_decostop_1st_stop_column, dm_decostop_1st_stop_row |
604 | 1124 call TFT_color_code_stop ; color-code output |
1125 movff char_O_first_deco_depth,lo ; stop depth in m | |
1126 rcall TFT_display_deko_output_depth ; output depth (stored in lo) to POSTINC2 with "m" or w/o (for ft) | |
1127 movff char_O_first_deco_time,lo ; get stop time in minutes | |
1128 tstfsz lo ; stop time = 0 ? | |
1129 bra TFT_display_deko_1 ; NO - print minutes | |
1130 STRCAT_PRINT " ..'" ; YES - special treatment | |
1131 bra TFT_display_exit_1 | |
1132 TFT_display_deko_1: | |
1133 output_99 ; output lo | |
0 | 1134 STRCAT_PRINT "'" |
604 | 1135 TFT_display_exit_1 |
1136 goto TFT_standard_color ; and return... | |
1137 | |
1138 | |
1139 global TFT_decoplan_mask ; mask for deco plan | |
1140 TFT_decoplan_mask: | |
582 | 1141 call TFT_divemask_color |
604 | 1142 WIN_TINY dm_custom_decoplan_title_column, dm_custom_decoplan_title_row |
582 | 1143 STRCPY_TEXT_PRINT tDiveDecoplan |
604 | 1144 return |
1145 | |
1146 global TFT_decoplan ; data for deco plan - stops 2 - 7 (stop 1 is shown in the main screen) | |
1147 TFT_decoplan: | |
1148 lfsr FSR0,char_O_deco_depth ; load base address of stops table | |
1149 clrf ex ; will be used for auxiliary flags | |
1150 call TFT_memo_color ; set default output color | |
560 | 1151 movff char_O_deco_gas+0,lo ; get flag for invalid deco data |
1152 btfsc lo,char_invalid_flag ; is the invalid flag set? | |
1153 call TFT_disabled_color ; YES - set to disabled color | |
604 | 1154 ; 2nd stop |
1155 WIN_SMALL dm_cust_dstop_2nd_stop_column, dm_cust_dstop_2nd_stop_row | |
1156 rcall TFT_decoplan_helper | |
1157 ; 3rd stop | |
1158 WIN_SMALL dm_cust_dstop_3rd_stop_column, dm_cust_dstop_3rd_stop_row | |
1159 rcall TFT_decoplan_helper | |
1160 ; 4th stop | |
1161 bsf ex,4 ; flag we are on 4th screen position | |
1162 WIN_SMALL dm_cust_dstop_4th_stop_column, dm_cust_dstop_4th_stop_row | |
1163 rcall TFT_decoplan_helper | |
1164 bcf ex,4 ; clear 4th position flag again | |
1165 ; 5th stop | |
1166 WIN_SMALL dm_cust_dstop_5th_stop_column, dm_cust_dstop_5th_stop_row | |
1167 rcall TFT_decoplan_helper | |
1168 ; 6th stop | |
1169 WIN_SMALL dm_cust_dstop_6th_stop_column, dm_cust_dstop_6th_stop_row | |
1170 rcall TFT_decoplan_helper | |
1171 ; 7th stop | |
1172 WIN_SMALL dm_cust_dstop_7th_stop_column, dm_cust_dstop_7th_stop_row | |
1173 rcall TFT_decoplan_helper | |
1174 bra TFT_display_exit_1 ; set standard color and return... | |
1175 | |
1176 TFT_decoplan_helper: | |
1177 btfsc ex,0 ; no more stops to show? | |
1178 bra TFT_decoplan_helper_1 ; YES - skip checking next entry - it will be empty, too | |
1179 movff PREINC0,lo ; NO - advance pointer to get the depth of the 2nd, 3rd, 4th, ... stop | |
1180 tstfsz lo ; is the stop depth = 0, i.e. no stop entry? | |
1181 bra TFT_decoplan_helper_3 ; NO - show stop data | |
1182 TFT_decoplan_helper_1: ; no more stop table entries | |
1183 bsf ex,0 ; flag that there are no more stop table entries | |
1184 btfss ex,4 ; are we on the 4th screen position? | |
1185 bra TFT_decoplan_helper_2 ; NO - normal handling on this position | |
1186 btfsc ex,1 ; YES - special handling, has any stop been shown? | |
1187 bra TFT_decoplan_helper_2 ; YES - print normal blanking | |
1188 STRCPY_PRINT " ---- " ; NO - print a "no stops" indication (blanking potential previous content, too) | |
1189 return | |
1190 TFT_decoplan_helper_2: ; no more stop table entries, blank potential previous content | |
1191 STRCPY_PRINT " " ; wipe screen position by printing 7 spaces | |
1192 return | |
1193 TFT_decoplan_helper_3: | |
1194 rcall TFT_display_deko_output_depth ; output depth (stored in lo) to POSTINC2 with "m" or w/o (for ft) | |
1195 movlw NUM_STOPS ; offset between arrays holding depths and durations | |
1196 movff PLUSW0,lo ; get duration of the current stop | |
1197 output_99 ; output duration to POSTINC2 | |
1198 STRCAT_PRINT "'" ; append symbol for minutes and print to screen | |
1199 bsf ex,1 ; flag that a stop was shown | |
1200 return | |
560 | 1201 |
0 | 1202 |
582 | 1203 global TFT_clear_safety_stop |
131 | 1204 TFT_clear_safety_stop: |
604 | 1205 bcf FLAG_TFT_clear_safety_stop ; clear flag |
582 | 1206 WIN_BOX_BLACK dm_safetystop_row, dm_safetystop_bot, dm_safetystop_text_column, .159 ; top, bottom, left, right |
1207 return | |
1208 | |
1209 global TFT_show_safety_stop | |
104
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1210 TFT_show_safety_stop: |
582 | 1211 bcf FLAG_TFT_show_safety_stop |
604 | 1212 tstfsz safety_stop_countdown ; countdown at zero? |
1213 bra TFT_show_safety_stop2 ; NO - show stop | |
1214 bcf show_safety_stop ; clear flag | |
1215 btfss safety_stop_active ; displayed? | |
1216 return ; NO | |
1217 bcf safety_stop_active ; clear flag | |
1218 btfsc divemode_menu ; is the dive mode menu shown? | |
1219 return ; YES - return | |
1220 bra TFT_clear_safety_stop ; NO - clear stop and return... | |
104
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1221 TFT_show_safety_stop2: |
604 | 1222 bsf safety_stop_active ; set flag |
1223 decf safety_stop_countdown,F ; reduce countdown | |
1224 btfsc divemode_menu ; is the dive mode menu shown? | |
1225 return ; YES - return | |
582 | 1226 ;btfsc menuview |
604 | 1227 ;bra TFT_show_safety_stop3 ; no room when menuview=1... |
582 | 1228 call TFT_divemask_color |
604 | 1229 WIN_STD dm_safetystop_text_column, dm_safetystop_text_row |
582 | 1230 STRCPY_TEXT_PRINT tDiveSafetyStop |
131 | 1231 TFT_show_safety_stop3: |
604 | 1232 call TFT_attention_color ; show in yellow |
582 | 1233 WIN_MEDIUM dm_safetystop_column, dm_safetystop_row |
104
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1234 movff safety_stop_countdown,lo |
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1235 clrf hi |
604 | 1236 call convert_time ; converts hi:lo in seconds to mins (up:hi) and seconds (lo) |
104
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1237 movf hi,W |
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1238 movff lo,hi |
604 | 1239 movwf lo ; exchange lo and hi |
582 | 1240 bsf leftbind |
131 | 1241 output_8 |
582 | 1242 bcf leftbind |
1243 PUTC ':' | |
104
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1244 movff hi,lo |
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1245 output_99x |
223579e905c3
Show a Safety Stop if enabled (Menu "Deco Parameters")
heinrichsweikamp
parents:
102
diff
changeset
|
1246 STRCAT_PRINT "" |
582 | 1247 WIN_FONT FT_SMALL |
604 | 1248 bra TFT_display_exit_1 |
1249 | |
1250 | |
1251 global TFT_avr_stopwatch_mask ; mask for average depth and stopwatch | |
1252 TFT_avr_stopwatch_mask: | |
582 | 1253 call TFT_divemask_color |
604 | 1254 WIN_TINY dm_custom_avr_stop_column1+.2,dm_custom_avr_stop_title_row |
1255 TSTOSS opt_2ndDepthDisp ; draw avg depth instead of max depth in main screen? | |
1256 bra TFT_avr_stopwatch_mask_1 ; NO - draw avg depth in custom view then | |
1257 STRCAT_TEXT_PRINT tMaxDepth ; YES - draw max depth in custom view then | |
1258 bra TFT_avr_stopwatch_mask_2 | |
1259 TFT_avr_stopwatch_mask_1: | |
582 | 1260 STRCPY_TEXT_PRINT tDiveTotalAvg |
604 | 1261 TFT_avr_stopwatch_mask_2: |
1262 WIN_TINY dm_custom_avr_stop_column2+.3,dm_custom_avr_stop_title_row | |
582 | 1263 STRCPY_TEXT_PRINT tDiveStopwatch |
604 | 1264 WIN_TINY dm_custom_avr_stop_column3-.8,dm_custom_avr_stop_title_row |
582 | 1265 STRCPY_TEXT_PRINT tDiveStopAvg |
604 | 1266 bra TFT_display_exit_1 |
1267 | |
1268 | |
1269 global TFT_avr_stopwatch ; data for average depth and stopwatch | |
1270 TFT_avr_stopwatch: | |
1271 call TFT_memo_color | |
582 | 1272 bsf leftbind |
604 | 1273 |
1274 ; total average depth or max depth | |
1275 WIN_MEDIUM dm_custom_avr_stop_column1,dm_custom_avr_stop_row | |
1276 TSTOSS opt_2ndDepthDisp ; draw avg depth instead of max depth in main screen? | |
1277 bra TFT_avr_stopwatch_01 ; NO - draw avg depth in custom view then | |
1278 SAFE_2BYTE_COPY max_pressure,lo ; YES - draw max depth in custom view then | |
1279 bra TFT_avr_stopwatch_02 | |
1280 TFT_avr_stopwatch_01: | |
582 | 1281 movff avg_rel_pressure_total+0,lo |
1282 movff avg_rel_pressure_total+1,hi | |
604 | 1283 TFT_avr_stopwatch_02: |
582 | 1284 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] |
604 | 1285 TSTOSS opt_units ; 0=m, 1=ft |
1286 bra TFT_update_avr_stopwatch1_metric ; 0 - metric | |
1287 ;bra TFT_update_avr_stopwatch1_imp ; 1 - imperial | |
1288 TFT_update_avr_stopwatch1_imp: | |
1289 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
582 | 1290 output_16 ; yxz |
604 | 1291 STRCAT " " ; wipe out remains from last output |
1292 clrf WREG | |
1293 movff WREG,buffer+.3 ; limit string length to 3 digits | |
1294 bra TFT_update_avr_stopwatch2 | |
1295 TFT_update_avr_stopwatch1_metric: | |
1296 bsf ignore_digit5 ; no cm (flag will be cleared by output_16) | |
1297 output_16dp .3 ; yxz.a | |
1298 PUTC " " ; wipe out remains from last output | |
1299 clrf WREG | |
1300 movff WREG,buffer+.4 ; limit string length to 4 = 3 digits + 1 half-size decimal dot | |
1301 TFT_update_avr_stopwatch2: | |
1302 STRCAT_PRINT "" | |
1303 | |
1304 ; stopped average depth | |
1305 WIN_MEDIUM dm_custom_avr_stop_column3,dm_custom_avr_stop_row | |
582 | 1306 movff avg_rel_pressure+0,lo |
1307 movff avg_rel_pressure+1,hi | |
1308 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
604 | 1309 TSTOSS opt_units ; 0=m, 1=ft |
1310 bra TFT_update_avr_stopwatch2_metric ; 0 - metric | |
1311 ;bra TFT_update_avr_stopwatch2_imp ; 1 - imperial | |
1312 TFT_update_avr_stopwatch2_imp: | |
1313 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
582 | 1314 output_16 ; yxz |
604 | 1315 STRCAT " " ; wipe out remains from last output |
582 | 1316 clrf WREG |
604 | 1317 movff WREG,buffer+.3 ; limit string length to 3 digits/characters |
1318 bra TFT_update_avr_stopwatch3 | |
1319 TFT_update_avr_stopwatch2_metric: | |
1320 bsf ignore_digit5 ; no cm (flag will be cleared by output_16) | |
582 | 1321 output_16dp .3 ; yxz.a |
604 | 1322 PUTC " " ; wipe out remains from last output |
589
8a7d2d8bcd33
limit string length to 4 digits/chars in average depth
heinrichsweikamp
parents:
587
diff
changeset
|
1323 clrf WREG |
604 | 1324 movff WREG,buffer+.4 ; limit string length to 4 = 3 digits + 1 half-size decimal dot |
1325 TFT_update_avr_stopwatch3: | |
582 | 1326 STRCAT_PRINT "" |
604 | 1327 |
1328 ; stopped dive time | |
1329 WIN_MEDIUM dm_custom_avr_stop_column2,dm_custom_avr_stop_row | |
1330 TFT_update_stopwatch: ; jump-in point for stopped dive time in compass custom view | |
608 | 1331 bsf leftbind ; print numbers without leading spaces |
604 | 1332 movff average_divesecs+0,lo ; average_divesecs is incremented outside ISR |
1333 movff average_divesecs+1,hi | |
1334 call convert_time ; converts hi:lo in seconds to minutes (up:hi) and seconds (lo) | |
1335 movlw .100 ; display layout will change if minutes become >= 100 | |
1336 cpfslt hi ; minutes < 100 ? | |
1337 bra TFT_update_stopwatch_2 ; NO - display hours:minutes | |
1338 ;bra TFT_update_stopwatch_1 ; YES - display minutes:seconds | |
1339 TFT_update_stopwatch_1: | |
1340 movf hi,W ; exchange lo and hi | |
1341 movff lo,hi ; ... | |
1342 movwf lo ; ... | |
1343 output_8 ; output minutes or hours | |
1344 PUTC ':' | |
1345 movff hi,lo ; restore lo | |
1346 output_99x ; output seconds or minutes | |
1347 movlw .5 | |
1348 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
1349 clrf WREG | |
1350 movff WREG,buffer+.5 ; limit to 5 chars | |
1351 STRCAT_PRINT "" | |
1352 bra TFT_display_exit_2 | |
1353 TFT_update_stopwatch_2: | |
1354 movff hi,lo ; transfer minutes (low byte) to lo | |
1355 movff up,hi ; transfer minutes (high byte) to hi | |
1356 call convert_time ; converts hi:lo in minutes to hours (up:hi) and minutes (lo) | |
1357 bra TFT_update_stopwatch_1 | |
560 | 1358 |
1359 | |
1360 global TFT_CNS_mask | |
1361 TFT_CNS_mask: | |
582 | 1362 call TFT_divemask_color |
604 | 1363 WIN_TINY dm_custom_cns3_column1, dm_custom_cns3_title_row |
582 | 1364 STRCPY_TEXT_PRINT tCNSsurf |
604 | 1365 WIN_TINY dm_custom_cns3_column2, dm_custom_cns3_title_row |
1366 btfsc FLAG_oc_mode ; in OC mode? | |
1367 bra TFT_CNS_mask_1 ; YES - print fTTS label | |
1368 btfsc FLAG_bailout_mode ; in bailout? | |
1369 bra TFT_CNS_mask_1 ; YES - print fTTS label (label will be printed, but a fTTS will actually not be calculated) | |
1370 TSTOSS opt_calc_asc_gasvolume ; bailout volume calculation requested? | |
1371 bra TFT_CNS_mask_1 ; NO - print fTTS label | |
1372 STRCPY_TEXT_PRINT tCNSBO ; YES - print bailout label | |
1373 bra TFT_CNS_mask_2 | |
1374 TFT_CNS_mask_1: ; OC or bailout | |
1375 STRCPY_TEXT_PRINT tCNSfTTS ; print fTTS label | |
1376 TFT_CNS_mask_2: | |
1377 WIN_TINY dm_custom_cns3_column3, dm_custom_cns3_title_row | |
582 | 1378 STRCPY_TEXT_PRINT tCNSnow |
604 | 1379 bra TFT_display_exit_2 |
1380 | |
582 | 1381 |
560 | 1382 global TFT_CNS |
1383 TFT_CNS: | |
604 | 1384 bsf leftbind |
560 | 1385 ; CNS at end of normal dive |
604 | 1386 WIN_STD dm_custom_cns3_column1+.3,dm_custom_cns3_row |
582 | 1387 movff int_O_normal_CNS_fraction+0,lo |
1388 movff int_O_normal_CNS_fraction+1,hi | |
1389 call TFT_color_code_cns | |
604 | 1390 output_16_3 ; output as xxx |
582 | 1391 STRCAT_PRINT "% " |
560 | 1392 ; fTTS / Bailout CNS, if enabled |
604 | 1393 WIN_STD dm_custom_cns3_column2+.2,dm_custom_cns3_row |
1394 btfsc FLAG_bailout_mode ; in bailout? | |
1395 bra TFT_CNS_3 ; YES - show "---" | |
1396 TSTOSS opt_calc_asc_gasvolume ; NO - bailout volume calculation requested? | |
1397 bra TFT_CNS_1 ; NO - continue checking fTTS extra time | |
1398 btfss FLAG_oc_mode ; YES - in OC mode? | |
1399 bra TFT_CNS_2 ; NO - show CNS% | |
1400 TFT_CNS_1: ; not in bailout, no volume calculation, and/or in OC mode | |
1401 TSTOSS char_I_extra_time ; fTTS extra time configured? | |
1402 bra TFT_CNS_3 ; NO - show "---" | |
560 | 1403 TFT_CNS_2: |
582 | 1404 movff int_O_alternate_CNS_fraction+0,lo ; YES - show CNS% |
1405 movff int_O_alternate_CNS_fraction+1,hi | |
1406 call TFT_color_code_cns | |
604 | 1407 output_16_3 ; output as xxx |
582 | 1408 STRCAT_PRINT "% " |
560 | 1409 bra TFT_CNS_4 |
1410 TFT_CNS_3: | |
604 | 1411 call TFT_memo_color |
582 | 1412 STRCPY_PRINT "--- " |
560 | 1413 TFT_CNS_4: |
1414 ; current CNS | |
604 | 1415 WIN_STD dm_custom_cns3_column3+.3,dm_custom_cns3_row |
582 | 1416 movff int_O_CNS_fraction+0,lo |
1417 movff int_O_CNS_fraction+1,hi | |
1418 call TFT_color_code_cns | |
604 | 1419 output_16_3 ; output as xxx |
582 | 1420 STRCAT_PRINT "%" |
604 | 1421 TFT_display_exit_2: |
1422 bcf leftbind | |
1423 goto TFT_standard_color ; and return... | |
1424 | |
1425 | |
1426 global TFT_ppo2_sensors_mask ; mask for ppO2 sensors | |
1427 TFT_ppo2_sensors_mask: | |
582 | 1428 call TFT_divemask_color |
604 | 1429 WIN_TINY dm_custom_hud_sensor1_column+.4,dm_custom_hud_title_row |
582 | 1430 STRCPY_TEXT_PRINT tDiveHudMask1 |
604 | 1431 WIN_TINY dm_custom_hud_sensor2_column+.3,dm_custom_hud_title_row |
582 | 1432 STRCPY_TEXT_PRINT tDiveHudMask2 |
604 | 1433 WIN_TINY dm_custom_hud_sensor3_column+.2,dm_custom_hud_title_row |
582 | 1434 STRCPY_TEXT_PRINT tDiveHudMask3 |
604 | 1435 bra TFT_display_exit_2 |
1436 | |
1437 | |
1438 global TFT_ppo2_sensors ; data for ppO2 sensors | |
1439 TFT_ppo2_sensors: | |
560 | 1440 ; |
1441 ; Definition of the output: | |
1442 ; | |
582 | 1443 ; sensorX use voting o2 |
1444 ; _calibrated _O2 _logic _ppo2 Output Color | |
1445 ; _ok _sensorX _sensorX _sensorX | |
560 | 1446 ;----------------------------------------------------------------------------------------------- |
604 | 1447 ; 0 -/- -/- -/- "----" TFT_memo_color |
582 | 1448 ; 1 0 -/- = 0 o2_ppo2_sensorX TFT_attention_color |
1449 ; 1 0 -/- > 0 o2_ppo2_sensorX TFT_disabled_color | |
1450 ; 1 1 0 -/- o2_ppo2_sensorX TFT_color_code_ppo2_hud + win_invert | |
1451 ; 1 1 1 -/- o2_ppo2_sensorX TFT_color_code_ppo2_hud | |
560 | 1452 ; |
582 | 1453 bsf leftbind |
560 | 1454 ; sensor 1 |
582 | 1455 btfsc sensor1_calibrated_ok ; valid calibration? |
604 | 1456 bra TFT_update_hud1b ; YES |
1457 btfsc sensor1_active ; valid HUD data for this sensor | |
1458 bra TFT_update_hud1b ; YES | |
1459 | |
560 | 1460 ; no valid calibration |
604 | 1461 WIN_STD dm_custom_hud_sensor1_column+.7, dm_custom_hud_row+.5 |
1462 call TFT_memo_color | |
582 | 1463 STRCPY_PRINT "---" |
1464 bra TFT_update_hud2a ; continue with sensor 2 | |
560 | 1465 TFT_update_hud1b: |
1466 ; sensor has a valid calibration | |
604 | 1467 WIN_MEDIUM dm_custom_hud_sensor1_column,dm_custom_hud_row |
582 | 1468 movff o2_ppo2_sensor1,lo ; load ppO2 value into transfer storage for output |
1469 clrf hi ; | |
560 | 1470 btfsc use_O2_sensor1 ; in use? |
604 | 1471 bra TFT_update_hud1d ; YES |
560 | 1472 ; valid calibration, but not in use |
1473 tstfsz o2_ppo2_sensor1 ; sensor value = 0? | |
1474 bra TFT_update_hud1c ; no | |
1475 ; valid calibration, not in use and value = 0 | |
582 | 1476 call TFT_attention_color ; output in yellow |
560 | 1477 bra TFT_update_hud1e |
1478 TFT_update_hud1c: | |
1479 ; sensor has valid calibration, is not in use and has a value > 0 | |
582 | 1480 call TFT_disabled_color ; output in light blue |
560 | 1481 bra TFT_update_hud1e |
1482 TFT_update_hud1d: | |
1483 ; sensor has valid calibration and is in use | |
582 | 1484 call TFT_color_code_ppo2_hud ; With ppO2 [cbar] in lo |
560 | 1485 btfsc voting_logic_sensor1 ; sensor value agrees with other sensor's values? |
604 | 1486 bra TFT_update_hud1e ; YES |
560 | 1487 ; valid calibration, in use, but value does not agree with other sensors |
582 | 1488 bsf win_invert ; invert output |
1489 TFT_update_hud1e: | |
560 | 1490 ; all coloring is set up now, let's write the value to the display! |
582 | 1491 output_16dp .3 ; x.xx bar |
1492 STRCAT_PRINT "" | |
1493 bcf win_invert | |
560 | 1494 |
1495 TFT_update_hud2a: ; sensor 2 | |
582 | 1496 btfsc sensor2_calibrated_ok ; valid calibration? |
604 | 1497 bra TFT_update_hud2b ; YES |
1498 btfsc sensor2_active ; valid HUD data for this sensor | |
1499 bra TFT_update_hud2b ; YES | |
560 | 1500 ; no valid calibration |
604 | 1501 WIN_STD dm_custom_hud_sensor2_column+.7, dm_custom_hud_row+.5 |
1502 call TFT_memo_color | |
582 | 1503 STRCPY_PRINT "---" |
1504 bra TFT_update_hud3a ; continue with sensor 3 | |
560 | 1505 TFT_update_hud2b: |
1506 ; sensor has a valid calibration | |
604 | 1507 WIN_MEDIUM dm_custom_hud_sensor2_column,dm_custom_hud_row |
582 | 1508 movff o2_ppo2_sensor2,lo ; load ppO2 value into transfer storage for output |
1509 clrf hi ; | |
560 | 1510 btfsc use_O2_sensor2 ; in use? |
604 | 1511 bra TFT_update_hud2d ; YES |
560 | 1512 ; valid calibration, but not in use |
1513 tstfsz o2_ppo2_sensor2 ; sensor value = 0? | |
604 | 1514 bra TFT_update_hud2c ; NO |
560 | 1515 ; valid calibration, not in use and value = 0 |
582 | 1516 call TFT_attention_color ; output in yellow |
560 | 1517 bra TFT_update_hud2e |
1518 TFT_update_hud2c: | |
1519 ; sensor has valid calibration, is not in use and has a value > 0 | |
582 | 1520 call TFT_disabled_color ; output in light blue |
560 | 1521 bra TFT_update_hud2e |
1522 TFT_update_hud2d: | |
1523 ; sensor has valid calibration and is in use | |
582 | 1524 call TFT_color_code_ppo2_hud ; With ppO2 [cbar] in lo |
560 | 1525 btfsc voting_logic_sensor2 ; sensor value agrees with other sensor's vlaues? |
604 | 1526 bra TFT_update_hud2e ; YES |
560 | 1527 ; valid calibration, in use, but value does not agree with other sensors |
582 | 1528 bsf win_invert ; invert output |
1529 TFT_update_hud2e: | |
560 | 1530 ; all coloring is set up now, let's write the value to the display! |
582 | 1531 output_16dp .3 ; x.xx bar |
1532 STRCAT_PRINT "" | |
1533 bcf win_invert | |
560 | 1534 |
1535 TFT_update_hud3a: ; sensor 3 | |
582 | 1536 btfsc sensor3_calibrated_ok ; valid calibration? |
604 | 1537 bra TFT_update_hud3b ; YES |
1538 btfsc sensor3_active ; valid HUD data for this sensor | |
1539 bra TFT_update_hud3b ; YES | |
560 | 1540 ; no valid calibration |
604 | 1541 WIN_STD dm_custom_hud_sensor3_column+.7, dm_custom_hud_row+.5 |
1542 call TFT_memo_color | |
582 | 1543 STRCPY_PRINT "---" |
1544 bra TFT_update_hud4 ; done | |
560 | 1545 TFT_update_hud3b: |
1546 ; sensor has a valid calibration | |
604 | 1547 WIN_MEDIUM dm_custom_hud_sensor3_column,dm_custom_hud_row |
582 | 1548 movff o2_ppo2_sensor3,lo ; load ppO2 value into transfer storage for output |
1549 clrf hi ; | |
560 | 1550 btfsc use_O2_sensor3 ; in use? |
604 | 1551 bra TFT_update_hud3d ; YES |
560 | 1552 ; valid calibration, but not in use |
1553 tstfsz o2_ppo2_sensor3 ; sensor value = 0? | |
604 | 1554 bra TFT_update_hud3c ; NO |
560 | 1555 ; valid calibration, not in use and value = 0 |
582 | 1556 call TFT_attention_color ; output in yellow |
560 | 1557 bra TFT_update_hud3e |
1558 TFT_update_hud3c: | |
1559 ; sensor has valid calibration, is not in use and has a value > 0 | |
582 | 1560 call TFT_disabled_color ; output in light blue |
560 | 1561 bra TFT_update_hud3e |
1562 TFT_update_hud3d: | |
1563 ; sensor has valid calibration and is in use | |
582 | 1564 call TFT_color_code_ppo2_hud ; With ppO2 [cbar] in lo |
604 | 1565 btfsc voting_logic_sensor3 ; sensor value agrees with other sensor's values? |
1566 bra TFT_update_hud3e ; YES | |
560 | 1567 ; valid calibration, in use, but value does not agree with other sensors |
582 | 1568 bsf win_invert ; invert output |
1569 TFT_update_hud3e: | |
560 | 1570 ; all coloring is set up now, let's write the value to the display! |
582 | 1571 output_16dp .3 ; x.xx bar |
1572 STRCAT_PRINT "" | |
1573 bcf win_invert | |
1574 | |
560 | 1575 TFT_update_hud4: ; closure |
604 | 1576 bra TFT_display_exit_3 |
1577 | |
1578 | |
1579 global TFT_surface_sensor ; update sensor data in surface mode | |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1580 TFT_surface_sensor: |
604 | 1581 movf hardware_flag1,W |
582 | 1582 sublw 0x11 ; 2 with BLE |
1583 btfsc STATUS,Z | |
604 | 1584 return ; ignore for 0x11 |
582 | 1585 ; show three sensors |
1586 bsf leftbind | |
1587 WIN_SMALL surf_hud_sensor1_column,surf_hud_sensor1_row | |
560 | 1588 btfsc sensor1_calibrated_ok |
604 | 1589 bra TFT_surface_sensor1 ; YES |
1590 btfsc sensor1_active ; valid HUD data for this sensor | |
1591 bra TFT_surface_sensor1 ; YES | |
582 | 1592 call TFT_standard_color |
1593 STRCPY_PRINT "--- " | |
604 | 1594 bra TFT_surface_sensor2 ; skip sensor 1 |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1595 TFT_surface_sensor1: |
582 | 1596 movff o2_ppo2_sensor1,lo |
604 | 1597 call TFT_color_code_ppo2_hud ; with ppO2 [cbar] in lo |
582 | 1598 clrf hi |
560 | 1599 bsf leftbind |
582 | 1600 output_16dp .3 ; x.xx bar |
1601 bcf leftbind | |
1602 STRCAT_PRINT "" | |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1603 TFT_surface_sensor2: |
582 | 1604 WIN_SMALL surf_hud_sensor2_column,surf_hud_sensor2_row |
560 | 1605 btfsc sensor2_calibrated_ok |
604 | 1606 bra TFT_surface_sensor3 ; YES |
1607 btfsc sensor2_active ; valid HUD data for this sensor | |
1608 bra TFT_surface_sensor3 ; YES | |
582 | 1609 call TFT_standard_color |
1610 STRCPY_PRINT "--- " | |
604 | 1611 bra TFT_surface_sensor4 ; skip sensor 2 |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1612 TFT_surface_sensor3: |
582 | 1613 movff o2_ppo2_sensor2,lo |
604 | 1614 call TFT_color_code_ppo2_hud ; with ppO2 [cbar] in lo |
582 | 1615 clrf hi |
560 | 1616 bsf leftbind |
582 | 1617 output_16dp .3 ; x.xx bar |
1618 bcf leftbind | |
1619 STRCAT_PRINT "" | |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1620 TFT_surface_sensor4: |
582 | 1621 WIN_SMALL surf_hud_sensor3_column,surf_hud_sensor3_row |
560 | 1622 btfsc sensor3_calibrated_ok |
604 | 1623 bra TFT_surface_sensor5 ; YES |
1624 btfsc sensor3_active ; valid HUD data for this sensor | |
1625 bra TFT_surface_sensor5 ; YES | |
582 | 1626 call TFT_standard_color |
1627 STRCPY_PRINT "--- " | |
604 | 1628 bra TFT_surface_sensor6 ; skip sensor 3 |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1629 TFT_surface_sensor5: |
582 | 1630 movff o2_ppo2_sensor3,lo |
604 | 1631 call TFT_color_code_ppo2_hud ; with ppO2 [cbar] in lo |
582 | 1632 clrf hi |
560 | 1633 bsf leftbind |
582 | 1634 output_16dp .3 ; x.xx bar |
1635 bcf leftbind | |
1636 STRCAT_PRINT "" | |
188
ebc28381f17d
NEW: Show Bailout Gas List in Surface mode (CCR Modes)
heinrichsweikamp
parents:
187
diff
changeset
|
1637 TFT_surface_sensor6: |
604 | 1638 TFT_display_exit_3: |
582 | 1639 bcf leftbind |
1640 goto TFT_standard_color ; and return... | |
1641 | |
1642 | |
604 | 1643 global TFT_sensor_mV |
1644 TFT_sensor_mV: | |
1645 call TFT_standard_color | |
582 | 1646 bsf leftbind |
604 | 1647 |
582 | 1648 WIN_SMALL surf_mV_sensor_column,surf_mV_sensor1_row |
1649 movff o2_mv_sensor1+0,lo ; in 0.1mV steps | |
1650 movff o2_mv_sensor1+1,hi ; in 0.1mV steps | |
1651 STRCAT "1: " | |
604 | 1652 rcall TFT_sensor_mV_helper |
1653 | |
582 | 1654 WIN_SMALL surf_mV_sensor_column,surf_mV_sensor2_row |
1655 movff o2_mv_sensor2+0,lo ; in 0.1mV steps | |
1656 movff o2_mv_sensor2+1,hi ; in 0.1mV steps | |
1657 STRCAT "2: " | |
604 | 1658 rcall TFT_sensor_mV_helper |
582 | 1659 |
1660 WIN_SMALL surf_mV_sensor_column,surf_mV_sensor3_row | |
1661 movff o2_mv_sensor3+0,lo ; in 0.1mV steps | |
1662 movff o2_mv_sensor3+1,hi ; in 0.1mV steps | |
1663 STRCAT "3: " | |
604 | 1664 rcall TFT_sensor_mV_helper |
1665 bra TFT_display_exit_3 | |
1666 | |
1667 TFT_sensor_mV_helper: | |
582 | 1668 output_16dp .4 ; xxx.y mV |
1669 STRCAT_PRINT "mV " | |
604 | 1670 return |
582 | 1671 |
1672 | |
1673 global TFT_sensor_surface_warning | |
535
cf68fe0c3002
NEW: Show a warning for each sensor if the sensor is end-of-life after calibration (Less then 8mV in Air at sea level)
heinrichsweikamp
parents:
533
diff
changeset
|
1674 TFT_sensor_surface_warning: |
582 | 1675 call TFT_warnings_color |
560 | 1676 btfss sensor1_calibrated_ok ; do not show end of lifetime arrow if sensor failed calibration at all |
1677 bra TFT_sensor_mV2 | |
582 | 1678 movff opt_x_s1+1,lo ; into bank1 |
604 | 1679 movf lo,W ; when opt_x_s1 > 255 the sensor will just give 8 mV at a ppO2 of 0.21 any more |
582 | 1680 bz TFT_sensor_mV2 ; the sensor is not too bad yet for a warning |
1681 WIN_SMALL surf_mV_sensor_status_column,surf_mV_sensor1_row-.5 | |
1682 STRCPY_PRINT "\xb8" ; mark sensor as being at end of lifetime | |
535
cf68fe0c3002
NEW: Show a warning for each sensor if the sensor is end-of-life after calibration (Less then 8mV in Air at sea level)
heinrichsweikamp
parents:
533
diff
changeset
|
1683 TFT_sensor_mV2: |
560 | 1684 btfss sensor2_calibrated_ok ; do not show end of lifetime arrow if sensor failed calibration at all |
1685 bra TFT_sensor_mV3 | |
582 | 1686 movff opt_x_s2+1,lo ; into bank1 |
604 | 1687 movf lo,W ; when opt_x_s2 > 255 the sensor will just give 8 mV at a ppO2 of 0.21 any more |
582 | 1688 bz TFT_sensor_mV3 ; the sensor is not too bad yet for a warning |
1689 WIN_SMALL surf_mV_sensor_status_column,surf_mV_sensor2_row-.5 | |
1690 STRCPY_PRINT "\xb8" ; mark sensor as being at end of lifetime | |
535
cf68fe0c3002
NEW: Show a warning for each sensor if the sensor is end-of-life after calibration (Less then 8mV in Air at sea level)
heinrichsweikamp
parents:
533
diff
changeset
|
1691 TFT_sensor_mV3: |
560 | 1692 btfss sensor3_calibrated_ok ; do not show end of lifetime arrow if sensor failed calibration at all |
1693 bra TFT_sensor_mV4 | |
582 | 1694 movff opt_x_s3+1,lo ; into bank1 |
604 | 1695 movf lo,W ; when opt_x_s3 > 255 the sensor will just give 8 mV at a ppO2 of 0.21 any more |
582 | 1696 bz TFT_sensor_mV4 ; the sensor is not too bad yet for a warning |
1697 WIN_SMALL surf_mV_sensor_status_column,surf_mV_sensor3_row-.5 | |
1698 STRCPY_PRINT "\xb8" ; mark sensor as being at end of lifetime | |
535
cf68fe0c3002
NEW: Show a warning for each sensor if the sensor is end-of-life after calibration (Less then 8mV in Air at sea level)
heinrichsweikamp
parents:
533
diff
changeset
|
1699 TFT_sensor_mV4: |
604 | 1700 bra TFT_display_exit_3 |
582 | 1701 |
1702 | |
1703 global TFT_menu_calibrate | |
1704 TFT_menu_calibrate: ; update mV data in calibration menu | |
1705 btfss s8_digital ; =1: Digital I/O | |
1706 bra TFT_menu_calibrate_analog ; use analog | |
1707 btfss new_s8_data_available ; new data frame received? | |
1708 bra TFT_menu_calibrate_common ; NO - use old values... | |
1709 ; YES - update the values | |
560 | 1710 call compute_mvolts_for_all_sensors |
582 | 1711 bra TFT_menu_calibrate_common |
560 | 1712 TFT_menu_calibrate_analog: |
582 | 1713 call get_analog_inputs |
560 | 1714 TFT_menu_calibrate_common: |
582 | 1715 call TFT_attention_color ; show in yellow |
1716 bsf leftbind | |
1717 WIN_SMALL surf_menu_sensor1_column,surf_menu2_sensor1_row | |
1718 movff o2_mv_sensor1+0,lo ; in 0.1mV steps | |
1719 movff o2_mv_sensor1+1,hi ; in 0.1mV steps | |
1720 output_16dp .4 ; xxx.y mV | |
1721 STRCAT_PRINT "mV " | |
1722 WIN_SMALL surf_menu_sensor2_column,surf_menu2_sensor2_row | |
1723 movff o2_mv_sensor2+0,lo ; in 0.1mV steps | |
1724 movff o2_mv_sensor2+1,hi ; in 0.1mV steps | |
1725 output_16dp .4 ; xxx.y mV | |
1726 STRCAT_PRINT "mV " | |
1727 WIN_SMALL surf_menu_sensor3_column,surf_menu2_sensor3_row | |
1728 movff o2_mv_sensor3+0,lo ; in 0.1mV steps | |
1729 movff o2_mv_sensor3+1,hi ; in 0.1mV steps | |
1730 output_16dp .4 ; xxx.y mV | |
1731 STRCAT_PRINT "mV " | |
604 | 1732 bra TFT_display_exit_3 |
582 | 1733 |
1734 | |
1735 global TFT_clock | |
0 | 1736 TFT_clock: |
604 | 1737 IFDEF _ostc_logo |
582 | 1738 WIN_SMALL surf_clock_column,surf_clock_row |
604 | 1739 ELSE |
1740 WIN_SMALL surf_clock_column+.7,surf_clock_row | |
1741 ENDIF | |
582 | 1742 TFT_clock2: ; called from divemode clock |
1743 call TFT_standard_color | |
0 | 1744 movff hours,lo |
1745 output_99 | |
1746 movlw ':' | |
582 | 1747 btfss secs,0 ; blinking every second |
0 | 1748 movlw ' ' |
1749 movwf POSTINC2 | |
1750 movff mins,lo | |
1751 output_99x | |
1752 STRCAT_PRINT "" | |
1753 return | |
1754 | |
1755 global TFT_show_time_date_menu | |
1756 TFT_show_time_date_menu: | |
582 | 1757 call speed_fastest |
1758 WIN_SMALL .15,.30 | |
1759 call TFT_standard_color | |
0 | 1760 movff hours,lo |
1761 output_99 | |
1762 PUTC ':' | |
1763 movff mins,lo | |
1764 output_99x | |
1765 PUTC ':' | |
1766 movff secs,lo | |
1767 output_99x | |
582 | 1768 STRCAT " - " |
1769 movff day,lo | |
1770 movff month,hi | |
1771 movff year,up | |
1772 call TFT_convert_date ; converts into "DD/MM/YY" or "MM/DD/YY" or "YY/MM/DD" in postinc2 | |
0 | 1773 STRCAT_PRINT " " |
1774 return | |
560 | 1775 |
0 | 1776 ;============================================================================= |
1777 | |
604 | 1778 global TFT_surface_decosettings ; show all deco settings |
41 | 1779 TFT_surface_decosettings: |
560 | 1780 ; Deco Mode |
41 | 1781 call TFT_standard_color |
560 | 1782 WIN_SMALL surf_gaslist_column,surf_gaslist_row |
582 | 1783 STRCAT_PRINT "ZH-L16" |
1784 movff char_I_deco_model,WREG | |
1785 iorwf WREG | |
1786 bnz TFT_surface_decosettings1 | |
560 | 1787 ; Display ZH-L16 sat/desat model |
582 | 1788 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.1) |
1789 lfsr FSR2,buffer | |
1790 movff char_I_desaturation_multiplier,lo | |
1791 bsf leftbind | |
1792 output_8 | |
1793 STRCAT "%/" | |
1794 movff char_I_saturation_multiplier,lo | |
1795 output_8 | |
1796 STRCAT_PRINT "%" | |
1797 bra TFT_surface_decosettings2 | |
1798 ; Display ZH-L16-GF low/high model | |
41 | 1799 TFT_surface_decosettings1: |
582 | 1800 TEXT_SMALL surf_gaslist_column+.43,surf_gaslist_row,tZHL16GF |
1801 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.1) | |
1802 STRCPY_TEXT tGF ; GF: | |
560 | 1803 movff opt_GF_low,lo |
582 | 1804 output_99x |
1805 STRCAT "/" | |
560 | 1806 movff opt_GF_high,lo |
582 | 1807 output_99x |
1808 STRCAT_PRINT "" | |
1809 TFT_surface_decosettings2: ; fTTS | |
1810 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.2) | |
1811 STRCPY_TEXT tFTTSMenu | |
1812 movff char_I_extra_time,lo | |
1813 bsf leftbind | |
1814 output_8 | |
1815 STRCAT_TEXT_PRINT tMinutes | |
1816 ; Last Stop | |
1817 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.3) | |
604 | 1818 STRCPY_TEXT tLastDecostopSurf |
560 | 1819 movff opt_last_stop,lo |
582 | 1820 output_8 |
1821 STRCAT_TEXT_PRINT tMeters | |
1822 ; Salinity | |
1823 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.4) | |
1824 STRCPY_TEXT tDvSalinity | |
1825 movff opt_salinity,lo | |
1826 output_8 | |
1827 bcf leftbind | |
1828 STRCAT_TEXT_PRINT tPercent | |
1829 return | |
0 | 1830 |
1831 global TFT_debug_output | |
1832 TFT_debug_output: | |
582 | 1833 WIN_TINY .80,.0 |
1834 call TFT_standard_color | |
1835 lfsr FSR2,buffer | |
1836 movff analog_sw1,lo | |
1837 output_8 | |
1838 PUTC "," | |
1839 movff analog_sw2,lo | |
1840 output_8 | |
1841 STRCAT_PRINT "" | |
1842 return | |
1843 | |
604 | 1844 global TFT_divetimeout ; show timeout counter |
55 | 1845 TFT_divetimeout: |
604 | 1846 call TFT_warning_set_window ; set the row and column for the current message |
1847 tstfsz WREG ; is there room for the message? | |
1848 return ; NO | |
1849 call TFT_memo_color | |
1850 STRCPY 0x94 ; "End of dive" symbol | |
582 | 1851 movff opt_diveTimeout,WREG ; in [min] |
1852 mullw .60 | |
1853 movff PRODL,sub_a+0 | |
1854 movff PRODH,sub_a+1 ; in [s] | |
1855 movff timeout_counter1+0,sub_b+0 | |
1856 movff timeout_counter1+1,sub_b+1 | |
1857 call subU16 ; sub_c = sub_a - sub_b (with UNSIGNED values) | |
1858 movff sub_c+0,lo | |
1859 movff sub_c+1,hi | |
604 | 1860 call convert_time ; converts hi:lo in minutes to hours (up:hi) and minutes (lo) |
55 | 1861 movf hi,W |
1862 movff lo,hi | |
1863 movwf lo ; exchange lo and hi | |
1864 output_99x | |
582 | 1865 PUTC ':' |
55 | 1866 movff hi,lo |
1867 output_99x | |
604 | 1868 movlw dm_warning_length ; divemode string length |
1869 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
55 | 1870 STRCAT_PRINT "" |
582 | 1871 bcf win_invert |
55 | 1872 return |
1873 | |
560 | 1874 global TFT_display_ftts |
1875 TFT_display_ftts: | |
582 | 1876 call TFT_warning_set_window ; sets the row and column for the current warning |
604 | 1877 tstfsz WREG ; is there room for the message? |
1878 return ; NO - done | |
1879 btfsc FLAG_oc_mode ; YES - in OC mode? | |
582 | 1880 bra TFT_display_ftts_1 ; YES - print fTTS label |
604 | 1881 TSTOSS opt_calc_asc_gasvolume ; NO - bailout volume calculation requested? |
1882 bra TFT_display_ftts_1 ; NO - print fTTS label | |
1883 STRCPY "B/O" ; YES - print bailout label | |
1884 bra TFT_display_ftts_2 | |
1885 TFT_display_ftts_1: ; OC or CCR/pSCR but no bailout volume calculation | |
582 | 1886 STRCPY "@+" ; print fTTS label |
604 | 1887 TFT_display_ftts_2: |
1888 movff char_I_extra_time,lo ; get fTTS delay time | |
1889 bsf leftbind ; print with alignment to the left | |
1890 output_8 ; print fTTS delay time | |
1891 PUTC ":" ; ":" | |
582 | 1892 movff int_O_alternate_ascenttime+0,lo |
1893 movff int_O_alternate_ascenttime+1,hi | |
604 | 1894 call TFT_memo_color ; set memo color |
1895 btfss hi,int_invalid_flag ; is the invalid flag set? | |
1896 bra TFT_display_ftts_3 ; NO - keep memo color | |
1897 bcf hi,int_invalid_flag ; YES - clear flag | |
1898 call TFT_disabled_color ; - switch to disabled color | |
1899 TFT_display_ftts_3: | |
1900 btfsc hi,int_not_yet_computed ; is the not-computed-yet flag set? | |
1901 bra TFT_display_ftts_4 ; YES - show dashes | |
582 | 1902 movf lo,W |
604 | 1903 iorwf hi,W ; extra_ascenttime = 0 ? |
1904 bz TFT_display_ftts_5 ; YES - show "NDL" | |
1905 movff char_O_deco_info,up ; get deco info vector | |
1906 btfsc up,deco_steady ; fTTS = TTS ? | |
1907 call TFT_advice_color ; YES - set to advice color (green) | |
1908 btfsc up,deco_decreasing ; fTTS < TTS ? | |
1909 call TFT_advice_color ; YES - set to advice color (green) | |
1910 output_16 ; NO - show ascent time | |
1911 PUTC "'" ; - minutes symbol | |
1912 bra TFT_display_ftts_6 | |
1913 TFT_display_ftts_4: | |
1914 STRCAT "---" ; "---" for not computed | |
1915 bra TFT_display_ftts_6 | |
1916 TFT_display_ftts_5: | |
1917 STRCAT_TEXT tNDL ; "NDL" | |
1918 TFT_display_ftts_6: | |
1919 movlw dm_warning_length ; dive mode string length | |
1920 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
0 | 1921 STRCAT_PRINT "" |
604 | 1922 bcf leftbind ; clear left alignment |
1923 goto TFT_standard_color ; ...and return | |
0 | 1924 |
1925 | |
1926 ;============================================================================= | |
560 | 1927 |
1928 global TFT_temp_surfmode | |
0 | 1929 TFT_temp_surfmode: |
582 | 1930 call TFT_divemask_color |
1931 WIN_SMALL surf_temp_column+3*8,surf_temp_row | |
1932 TSTOSS opt_units ; 0=°C, 1=°F | |
560 | 1933 bra TFT_temp_surfmode_metric |
582 | 1934 STRCAT_TEXT tLogTunitF ; °F |
560 | 1935 bra TFT_temp_surfmode_common |
0 | 1936 TFT_temp_surfmode_metric: |
582 | 1937 STRCAT_TEXT tLogTunitC ; °C |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1938 TFT_temp_surfmode_common: |
560 | 1939 STRCAT_PRINT "" |
582 | 1940 WIN_SMALL surf_temp_column,surf_temp_row |
604 | 1941 call TFT_memo_color |
560 | 1942 bra TFT_temp_common |
582 | 1943 |
1944 | |
560 | 1945 global TFT_temp_divemode |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1946 TFT_temp_divemode: |
582 | 1947 bcf FLAG_TFT_temp_divemode |
604 | 1948 btfsc divemode_menu ; is the dive mode menu shown? |
1949 return ; YES - no update of temperature now | |
1950 btfsc blinking_better_gas ; blinking better gas? | |
1951 return ; YES - no update of temperature now | |
1952 btfsc blinking_better_dil ; blinking better diluent? | |
1953 return ; YES - no update of temperature now | |
1954 WIN_SMALL dm_temp_column,dm_temp_row | |
1955 call TFT_memo_color | |
1956 btfsc alternative_divelayout ; in alternative layout? | |
1957 bra TFT_temp_common ; YES - proceed with temperature | |
1958 movlw index_compass_dm ; NO - index of compass custom view | |
1959 cpfseq menupos3 ; - compass shown in custom view? | |
1960 bra TFT_temp_common ; NO - proceed with temperature | |
1961 bra TFT_update_stopwatch ; YES - show resettable dive time instead of temperature | |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1962 TFT_temp_common: |
560 | 1963 SAFE_2BYTE_COPY temperature,lo ; get current temperature |
582 | 1964 TSTOSS opt_units ; 0=°C, 1=°F |
560 | 1965 bra TFT_temp_common_1 |
1966 call convert_celsius_to_fahrenheit ; convert value in lo:hi from celsius to fahrenheit | |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1967 TFT_temp_common_1: |
560 | 1968 rcall TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required |
1969 btfsc neg_flag ; is the temperature negative? | |
1970 bra TFT_temp_common_2 ; YES - the minus sign has already been written | |
604 | 1971 ; temp is positive, is it less than 10°C ? |
582 | 1972 tstfsz hi |
560 | 1973 bra TFT_temp_common_1a ; >25.5°C, skip here |
1974 movlw .100 | |
1975 cpfslt lo | |
1976 bra TFT_temp_common_1a ; >10.0°C, skip here | |
1977 bsf leftbind | |
1978 output_16dp d'4' ; x.y°C | |
1979 bcf leftbind | |
604 | 1980 bra TFT_temp_common_3 ; done |
553
2e70700774b9
Display dezimal for temperatures between 10 and 0?C
heinrichsweikamp
parents:
552
diff
changeset
|
1981 TFT_temp_common_1a: |
560 | 1982 PUTC " " ; NO - write a space instead of the minus sign |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1983 TFT_temp_common_2: |
604 | 1984 bsf ignore_digit5 ; ignore decimal (flag will be cleared by output_16) |
560 | 1985 output_16_3 ; output 0-999 without decimal -> writes ' ' - 99 |
582 | 1986 movff buffer+2,lo ; get output from unit position |
1987 movlw " " ; load code of the space character | |
560 | 1988 cpfseq lo ; is there a space sign on the unit position? (happens between +1 and -1) |
1989 bra TFT_temp_common_3 ; NO | |
1990 movff WREG,buffer+0 ; YES - replace potential minus sign with a space (temps from -0.9° to -0.1° else would appear as '- 0') | |
1991 movlw "0" ; load code of the zero character | |
1992 movff WREG,buffer+2 ; replace space with a zero | |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
1993 TFT_temp_common_3: |
560 | 1994 btfss divemode ; are we in dive mode? |
1995 bra TFT_temp_common_5 ; NO - no unit to append | |
1996 TSTOSS opt_units ; YES - check unit type: 0=°C, 1=°F | |
1997 bra TFT_temp_common_4 ; go metric | |
1998 STRCAT_TEXT tLogTunitF ; append °F | |
1999 bra TFT_temp_common_5 | |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
2000 TFT_temp_common_4: |
582 | 2001 STRCAT_TEXT tLogTunitC ; append °C |
552
af84c45429fd
BUGFIX: Display of negative (?C) water temperatures
heinrichsweikamp
parents:
551
diff
changeset
|
2002 TFT_temp_common_5: |
560 | 2003 STRCAT_PRINT "" ; output to screen |
582 | 2004 return |
2005 | |
0 | 2006 ;============================================================================= |
560 | 2007 |
582 | 2008 global TFT_divemode_menu_cursor |
0 | 2009 TFT_divemode_menu_cursor: |
582 | 2010 WIN_BOX_BLACK dm_menu_row+.1, dm_menu_lower-.1, dm_menu_item1_column-.8, dm_menu_item1_column-.1 |
2011 WIN_BOX_BLACK dm_menu_row+.1, dm_menu_lower-.1, dm_menu_item4_column-.8, dm_menu_item4_column-.1 | |
2012 call TFT_standard_color | |
2013 | |
2014 movlw dm_menu_item1_column-.8 | |
604 | 2015 btfsc menupos1,2 ; > 3 ? |
2016 movlw dm_menu_item4_column-.8 ; YES | |
2017 movwf win_leftx2 | |
2018 | |
2019 movff menupos1,lo ; copy menu position | |
582 | 2020 movlw dm_menu_item6_row |
2021 dcfsnz lo,F | |
2022 movlw dm_menu_item1_row | |
2023 dcfsnz lo,F | |
2024 movlw dm_menu_item2_row | |
2025 dcfsnz lo,F | |
2026 movlw dm_menu_item3_row | |
2027 dcfsnz lo,F | |
2028 movlw dm_menu_item4_row | |
2029 dcfsnz lo,F | |
2030 movlw dm_menu_item5_row | |
604 | 2031 movwf win_top |
582 | 2032 movlw FT_SMALL |
604 | 2033 movwf win_font |
582 | 2034 STRCPY_PRINT "\xb7" ; print cursor |
2035 return | |
145
e3ac5b2021bc
NEW: Setpoint-Fallback option for external O2 sensor failure
heinrichsweikamp
parents:
139
diff
changeset
|
2036 |
604 | 2037 |
0 | 2038 global TFT_active_gas_divemode |
604 | 2039 TFT_active_gas_divemode: ; display gas/setpoint |
582 | 2040 bcf FLAG_TFT_active_gas_divemode |
604 | 2041 btfsc divemode_menu ; is the dive mode menu shown? |
2042 return ; YES - return | |
2043 btfsc FLAG_apnoe_mode ; in apnoe mode? | |
2044 return ; YES - return | |
2045 btfsc FLAG_gauge_mode ; in gauge mode? | |
2046 return ; YES - return | |
2047 btfss FLAG_oc_mode ; in OC mode? | |
2048 bra TFT_active_setpoint ; NO - show setpoint and gas mix | |
2049 bra TFT_active_gas_divemode_oc ; YES - show OC gas | |
2050 | |
2051 TFT_active_setpoint_bail: ; bailout case | |
2052 tstfsz menupos2 ; any option shown? | |
2053 bra TFT_active_gas_divemode_oc ; YES - do not overwrite with bailout text | |
2054 WIN_SMALL dm_active_dil_column, dm_active_dil_row | |
605 | 2055 call TFT_attention_color ; print in yellow |
604 | 2056 STRCPY_TEXT_PRINT tDiveBailout ; "Bailout" |
2057 TFT_active_gas_divemode_oc: ; common part for OC and bailout | |
2058 movff int_O_breathed_ppO2+0,lo ; color-code the output of the gas by the ppO2 it yields | |
2059 movff int_O_breathed_ppO2+1,hi ; | |
2060 call TFT_color_code_ppo2 ; with ppO2 [cbar] in hi:lo | |
2061 btfss better_gas_available ; check if a better gas is available and a gas change shall be advised | |
2062 bra TFT_active_gas_print ; NO - print in normal rendering | |
582 | 2063 btg blinking_better_gas ; YES - toggle blink bit |
2064 btfss blinking_better_gas ; blink now? | |
604 | 2065 bra TFT_active_gas_print ; NO - print in normal rendering |
582 | 2066 call TFT_attention_color ; YES - blink in yellow |
2067 bsf win_invert ; set invert flag | |
604 | 2068 TFT_active_gas_print: |
2069 WIN_STD dm_active_gas_column, dm_active_gas_row | |
582 | 2070 movff char_I_O2_ratio,lo ; lo now stores O2 in % |
2071 movff char_I_He_ratio,hi ; hi now stores He in % | |
2072 call customview_show_mix ; put "Nxlo", "Txlo/hi", "Air" or "O2" into Postinc2 | |
560 | 2073 STRCAT_PRINT "" |
582 | 2074 bcf win_invert ; reset invert flag |
560 | 2075 goto TFT_standard_color ; ...and return |
2076 | |
604 | 2077 ; in CCR / pSCR mode - and maybe in bailout |
2078 TFT_active_setpoint: ; | |
2079 btfsc FLAG_bailout_mode ; in bailout? | |
582 | 2080 bra TFT_active_setpoint_bail ; YES - show "Bailout" instead of setpoint |
604 | 2081 |
2082 ; on the loop | |
2083 movff int_O_breathed_ppO2+0,lo ; color-code the output by the ppO2 of the loop gas mixture | |
560 | 2084 movff int_O_breathed_ppO2+1,hi |
582 | 2085 call TFT_color_code_ppo2 ; with ppO2 [cbar] in hi:lo |
604 | 2086 btfss secs,0 ; timebase for blinking effect: on even second? |
2087 bra TFT_active_setpoint_print ; YES - print ppO2 with normal rendering | |
2088 btfsc setpoint_fallback ; NO - check if we are in fallback condition | |
582 | 2089 bra TFT_active_setpoint_fallb ; YES - process fallback case |
2090 movff int_O_breathed_ppO2+1,WREG ; NO - get flags again (have been cleared in hi:lo by TFT_color_code_ppo2 meanwhile) | |
2091 btfss WREG,int_warning_flag ; warning flag set? | |
2092 bra TFT_active_setpoint_print ; NO - ppO2 is ok, print ppO2 with normal rendering | |
2093 bra TFT_active_setpoint_com ; YES - continue with blinking common part | |
560 | 2094 TFT_active_setpoint_fallb: ; set up fallback case |
604 | 2095 call TFT_attention_color ; text in yellow |
582 | 2096 TFT_active_setpoint_com: ; blinking common part |
2097 bsf win_invert ; set invert flag | |
560 | 2098 TFT_active_setpoint_print: |
2099 WIN_STD dm_active_gas_column, dm_active_gas_row | |
2100 bsf leftbind | |
582 | 2101 output_16dp .3 ; x.xx bar |
2102 bcf leftbind | |
2103 STRCAT_TEXT tbar | |
2104 movff opt_ccr_mode,WREG ; =0: Fixed SP, =1: Sensor, =2: Auto SP | |
2105 sublw .1 ; opt_ccr_mode = 1 (Sensor)? | |
2106 bnz TFT_active_setpoint2_a ; NO - skip | |
2107 PUTC "*" ; YES - add an astrix | |
560 | 2108 TFT_active_setpoint2_a: |
2109 STRCAT_PRINT "" | |
582 | 2110 bcf win_invert ; reset invert flag |
604 | 2111 call TFT_memo_color ; revert to memo color |
2112 TFT_active_setpoint_diluent: ; diluent gas | |
2113 movff int_O_pure_ppO2+0,lo ; color-code the output | |
2114 movff int_O_pure_ppO2+1,hi | |
2115 call TFT_color_code_ppo2 ; with ppO2 [cbar] in hi:lo | |
2116 btfss better_dil_available ; check if a better diluent is available and a diluent change shall be advised | |
560 | 2117 bra TFT_active_setpoint_diluent_show ; NO - print in normal rendering |
604 | 2118 btg blinking_better_dil ; YES - toggle blink bit... |
2119 btfss blinking_better_dil ; blink now? | |
560 | 2120 bra TFT_active_setpoint_diluent_show ; NO - print in normal rendering |
604 | 2121 call TFT_attention_color ; YES - print in yellow color |
2122 bsf win_invert ; - set invert flag | |
560 | 2123 TFT_active_setpoint_diluent_show: |
2124 WIN_SMALL dm_active_dil_column, dm_active_dil_row | |
582 | 2125 movff char_I_O2_ratio,lo ; lo now stores O2 in % |
2126 movff char_I_He_ratio,hi ; hi now stores He in % | |
2127 call customview_show_mix ; put "Nxlo", "Txlo/hi", "Air" or "O2" into Postinc2 | |
0 | 2128 STRCAT_PRINT "" |
582 | 2129 bcf win_invert ; reset invert flag |
604 | 2130 call TFT_memo_color ; set memo color |
2131 btfsc menuview ; is the dive options menu shown? | |
2132 return ; YES - do not overwrite it | |
560 | 2133 WIN_TINY dm_active_dil_column+.45, dm_active_dil_row+.3 |
604 | 2134 btfsc FLAG_ccr_mode ; in CCR mode? |
2135 bra TFT_active_setpoint_ccr ; YES - write CCR label | |
2136 btfsc FLAG_pscr_mode ; in pSCR mode? | |
2137 bra TFT_active_setpoint_pscr ; YES - write pSCR label | |
2138 return ; NO to both - should not happen, anyhow: done | |
2139 TFT_active_setpoint_ccr: | |
560 | 2140 STRCPY_TEXT_PRINT tDvCCR ; print "CCR" |
2141 return ; done | |
604 | 2142 TFT_active_setpoint_pscr: |
560 | 2143 STRCPY_TEXT_PRINT tDvPSCR ; print "PSCR" |
604 | 2144 return ; done |
582 | 2145 |
0 | 2146 |
2147 global TFT_display_decotype_surface | |
2148 TFT_display_decotype_surface: | |
582 | 2149 WIN_STD surf_decotype_column,surf_decotype_row |
2150 WIN_COLOR color_lightblue | |
604 | 2151 movff opt_dive_mode,lo ; 0=OC, 1=CC, 2=Gauge, 3=Apnoe, 4=PSCR |
582 | 2152 tstfsz lo |
2153 bra TFT_display_decotype_surface2 | |
116
737d6f488729
show decomode in logbook and simulator w/o sensor type
heinrichsweikamp
parents:
113
diff
changeset
|
2154 TFT_display_decotype_surface0: |
604 | 2155 STRCAT_TEXT_PRINT tDvOC ; OC |
582 | 2156 bra TFT_display_decotype_exit |
0 | 2157 TFT_display_decotype_surface2: |
582 | 2158 decfsz lo,F |
2159 bra TFT_display_decotype_surface3 | |
604 | 2160 STRCAT_TEXT_PRINT tDvCC ; CC |
582 | 2161 call TFT_standard_color |
113 | 2162 WIN_TINY surf_decotype_column+.18,surf_decotype_row+.12 |
604 | 2163 TSTOSS opt_ccr_mode ; =0: Fixed SP, =1: Sensor, =2: Auto SP |
2164 bra TFT_display_decotype_cc_fixed | |
582 | 2165 ; Sensor mode or Auto |
2166 movff opt_ccr_mode,WREG | |
2167 sublw .2 | |
2168 bz TFT_display_decotype_cc_auto | |
604 | 2169 STRCPY_TEXT tCCRModeSensor ; sensor |
582 | 2170 bra TFT_display_decotype_cc_common |
337
508d7fb98b34
cleanup menu, add "Auto SP" option (Not working yet), minor layout change in compass menu
heinrichsweikamp
parents:
333
diff
changeset
|
2171 TFT_display_decotype_cc_auto: |
582 | 2172 STRCPY_TEXT tCCRModeAutoSP ; Auto SP |
2173 bra TFT_display_decotype_cc_common | |
113 | 2174 TFT_display_decotype_cc_fixed: |
604 | 2175 STRCPY_TEXT tCCRModeFixedSP ; fixed SP |
113 | 2176 TFT_display_decotype_cc_common: |
582 | 2177 clrf WREG |
2178 movff WREG,buffer+.8 ; limit string length to 8 | |
2179 STRCAT_PRINT "" | |
2180 bra TFT_display_decotype_exit | |
0 | 2181 TFT_display_decotype_surface3: |
582 | 2182 decfsz lo,F |
2183 bra TFT_display_decotype_surface4 | |
116
737d6f488729
show decomode in logbook and simulator w/o sensor type
heinrichsweikamp
parents:
113
diff
changeset
|
2184 TFT_display_decotype_surface3_1: |
582 | 2185 STRCAT_TEXT_PRINT tDvGauge ; Gauge |
2186 bra TFT_display_decotype_exit | |
0 | 2187 TFT_display_decotype_surface4: |
582 | 2188 decfsz lo,F |
2189 bra TFT_display_decotype_surface5 | |
2190 TFT_display_decotype_surface4_1: | |
2191 STRCAT_TEXT_PRINT tDvApnea ; Apnea | |
2192 bra TFT_display_decotype_exit | |
480
ad8acade5567
NEW: PSCR mode (Passive semi-closed rebreather)
heinrichsweikamp
parents:
477
diff
changeset
|
2193 TFT_display_decotype_surface5: |
604 | 2194 STRCAT_TEXT_PRINT tDvPSCR ; pSCR |
0 | 2195 TFT_display_decotype_exit: |
582 | 2196 goto TFT_standard_color ; and return... |
2197 | |
2198 | |
604 | 2199 global TFT_display_decotype_surface1 |
2200 TFT_display_decotype_surface1: ; used from logbook and from deco calculator (simulator.asm) | |
2201 tstfsz lo ; lo holds 0=OC, 1=CC, 2=Gauge, 3=Apnea, 4=pSCR | |
582 | 2202 bra TFT_display_decotype_surface1_2 |
604 | 2203 bra TFT_display_decotype_surface0 ; OC |
116
737d6f488729
show decomode in logbook and simulator w/o sensor type
heinrichsweikamp
parents:
113
diff
changeset
|
2204 TFT_display_decotype_surface1_2: |
582 | 2205 decfsz lo,F |
2206 bra TFT_display_decotype_surface1_3 | |
604 | 2207 STRCAT_TEXT_PRINT tDvCC ; CC |
2208 bra TFT_display_decotype_exit | |
116
737d6f488729
show decomode in logbook and simulator w/o sensor type
heinrichsweikamp
parents:
113
diff
changeset
|
2209 TFT_display_decotype_surface1_3: |
582 | 2210 decfsz lo,F |
2211 bra TFT_display_decotype_surface1_4 | |
604 | 2212 bra TFT_display_decotype_surface3_1 ; Gauge |
480
ad8acade5567
NEW: PSCR mode (Passive semi-closed rebreather)
heinrichsweikamp
parents:
477
diff
changeset
|
2213 TFT_display_decotype_surface1_4: |
582 | 2214 decfsz lo,F |
604 | 2215 bra TFT_display_decotype_surface5 ; pSCR |
2216 bra TFT_display_decotype_surface4_1 ; Apnea | |
116
737d6f488729
show decomode in logbook and simulator w/o sensor type
heinrichsweikamp
parents:
113
diff
changeset
|
2217 |
0 | 2218 ;============================================================================= |
2219 | |
604 | 2220 global TFT_splist_surfmode ; show setpoint list |
0 | 2221 TFT_splist_surfmode: |
604 | 2222 bsf short_gas_decriptions ; =1: Use short versions of gaslist_strcat_gas_cd and gaslist_strcat_setpoint |
2223 bcf better_gas_hint ; do not mark the best gas/diluent (to be used in dive mode only) | |
582 | 2224 ;SP 1 |
2225 WIN_SMALL surf_gaslist_column,surf_gaslist_row | |
2226 clrf PRODL | |
604 | 2227 call gaslist_strcat_setpoint ; show SP#+1 of PRODL# |
582 | 2228 STRCAT_PRINT "" |
2229 ;SP 2 | |
2230 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.1) | |
2231 movlw .1 | |
2232 movwf PRODL | |
604 | 2233 call gaslist_strcat_setpoint ; show SP#+1 of PRODL# |
582 | 2234 STRCAT_PRINT "" |
2235 ;SP 3 | |
2236 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.2) | |
2237 movlw .2 | |
2238 movwf PRODL | |
604 | 2239 call gaslist_strcat_setpoint ; show SP#+1 of PRODL# |
582 | 2240 STRCAT_PRINT "" |
2241 ;SP 4 | |
2242 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.3) | |
2243 movlw .3 | |
2244 movwf PRODL | |
604 | 2245 call gaslist_strcat_setpoint ; show SP#+1 of PRODL# |
582 | 2246 STRCAT_PRINT "" |
2247 ;SP 5 | |
2248 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.4) | |
2249 movlw .4 | |
2250 movwf PRODL | |
604 | 2251 call gaslist_strcat_setpoint ; show SP#+1 of PRODL# |
582 | 2252 STRCAT_PRINT "" |
2253 bcf leftbind | |
2254 return | |
0 | 2255 |
2256 global TFT_gaslist_surfmode | |
604 | 2257 TFT_gaslist_surfmode: ; displays gas list |
2258 bsf short_gas_decriptions ; =1: Use short versions of gaslist_strcat_gas_cd and gaslist_strcat_setpoint | |
2259 bcf better_gas_hint ; do not mark the best gas/diluent (to be used in dive mode only) | |
582 | 2260 ;Gas 1 |
2261 WIN_SMALL surf_gaslist_column,surf_gaslist_row | |
2262 clrf PRODL | |
604 | 2263 call gaslist_strcat_gas_cd ; append gas description of gas #PRODL (0-4) to current string |
582 | 2264 STRCAT_PRINT "" |
2265 ;Gas 2 | |
2266 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.1) | |
2267 movlw .1 | |
2268 movwf PRODL | |
604 | 2269 call gaslist_strcat_gas_cd ; append gas description of gas #PRODL (0-4) to current string |
582 | 2270 STRCAT_PRINT "" |
2271 ;Gas 3 | |
2272 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.2) | |
2273 movlw .2 | |
2274 movwf PRODL | |
604 | 2275 call gaslist_strcat_gas_cd ; append gas description of gas #PRODL (0-4) to current string |
582 | 2276 STRCAT_PRINT "" |
2277 ;Gas 4 | |
2278 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.3) | |
2279 movlw .3 | |
2280 movwf PRODL | |
604 | 2281 call gaslist_strcat_gas_cd ; append gas description of gas #PRODL (0-4) to current string |
582 | 2282 STRCAT_PRINT "" |
2283 ;Gas 5 | |
2284 WIN_SMALL surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.4) | |
2285 movlw .4 | |
2286 movwf PRODL | |
604 | 2287 call gaslist_strcat_gas_cd ; append gas description of gas #PRODL (0-4) to current string |
582 | 2288 STRCAT_PRINT "" |
2289 bcf leftbind | |
604 | 2290 bcf win_invert ; clear flag for inverted output |
582 | 2291 return |
0 | 2292 |
2293 global TFT_dillist_surfmode | |
604 | 2294 TFT_dillist_surfmode: ; displays diluent list |
2295 bsf FLAG_diluent_setup ; use CCR diluents... | |
2296 rcall TFT_gaslist_surfmode ; use OC/BAIL routine | |
2297 bcf FLAG_diluent_setup ; clear flag | |
582 | 2298 return |
0 | 2299 |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2300 ;================================================================== |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2301 |
0 | 2302 global TFT_depth |
2303 TFT_depth: | |
582 | 2304 bcf FLAG_TFT_depth |
2305 SAFE_2BYTE_COPY rel_pressure, lo | |
2306 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
604 | 2307 call TFT_color_code_depth ; color-code the output |
582 | 2308 rcall TFT_depth_blink |
2309 WIN_LARGE dm_depth_column, dm_depth_row | |
2310 TSTOSS opt_units ; 0=m, 1=ft | |
2311 bra TFT_depth_metric | |
0 | 2312 ;TFT_depth_imperial |
604 | 2313 clrf sub_a+1 ; display 0ft if lower then 30cm |
0 | 2314 movlw d'30' |
2315 movwf sub_a+0 | |
2316 movff hi,sub_b+1 | |
2317 movff lo,sub_b+0 | |
582 | 2318 call subU16 ; sub_c = sub_a - sub_b |
604 | 2319 btfss neg_flag ; depth lower then 0.4m? |
2320 bra depth_less_0.3mtr_feet ; YES - show 0ft manually | |
2321 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
0 | 2322 bsf leftbind |
582 | 2323 output_16 ; feet in Big font |
2324 bcf leftbind | |
2325 movlw .3 ; limit to three chars | |
604 | 2326 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) |
2327 STRCAT_PRINT "" ; display feet | |
2328 bcf win_invert ; reset invert flag | |
582 | 2329 return |
126 | 2330 |
0 | 2331 depth_less_0.3mtr_feet: |
582 | 2332 STRCAT_PRINT "0 " ; manual zero |
604 | 2333 bcf win_invert ; reset invert flag |
0 | 2334 return |
2335 | |
2336 TFT_depth_metric: | |
2337 movlw .039 | |
2338 cpfslt hi | |
582 | 2339 bra depth_greater_99_84mtr |
2340 | |
604 | 2341 btfsc depth_greater_100m ; was depth > 100m during last call? |
2342 rcall TFT_clear_depth ; YES - clear depth area | |
2343 bcf depth_greater_100m ; do this once only... | |
0 | 2344 |
11 | 2345 movlw .039 |
2346 cpfslt hi | |
582 | 2347 bra depth_greater_99_84mtr |
11 | 2348 |
0 | 2349 movlw HIGH d'1000' |
2350 movwf sub_a+1 | |
2351 movlw LOW d'1000' | |
2352 movwf sub_a+0 | |
2353 movff hi,sub_b+1 | |
2354 movff lo,sub_b+0 | |
2355 incf sub_b+0,F | |
2356 movlw d'0' | |
604 | 2357 addwfc sub_b+1,F ; add 1mbar offset |
0 | 2358 call sub16 ; sub_c = sub_a - sub_b |
582 | 2359 movlw ' ' |
604 | 2360 btfss neg_flag ; depth lower then 10m? |
2361 movwf POSTINC2 ; YES - add extra space | |
582 | 2362 |
2363 clrf sub_a+1 | |
0 | 2364 movlw d'99' |
2365 movwf sub_a+0 | |
2366 movff hi,sub_b+1 | |
2367 movff lo,sub_b+0 | |
2368 call subU16 ; sub_c = sub_a - sub_b | |
604 | 2369 btfss neg_flag ; depth lower then 1m? |
2370 bra tft_depth2 ; YES - display manual Zero | |
0 | 2371 |
2372 bsf leftbind | |
2373 bsf ignore_digit4 | |
604 | 2374 output_16 ; full meters in big font |
0 | 2375 bcf leftbind |
2376 bra tft_depth3 | |
2377 | |
2378 tft_depth2: | |
582 | 2379 STRCAT "0" ; manual zero |
0 | 2380 |
2381 tft_depth3: | |
604 | 2382 STRCAT_PRINT "" ; display full meters |
0 | 2383 |
2384 ; .1m in MEDIUM font | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2385 WIN_MEDIUM dm_depth_dm_column, dm_depth_dm_row |
560 | 2386 |
582 | 2387 SAFE_2BYTE_COPY rel_pressure, lo |
2388 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
604 | 2389 ;call TFT_color_code_depth ; color-code the output - not needed, furthermore: seems to cause problems if not commented out... |
582 | 2390 |
2391 PUTC "." | |
604 | 2392 movlw HIGH d'30' ; display 0.0m if lower then 30cm |
0 | 2393 movwf sub_a+1 |
582 | 2394 movlw LOW d'30' |
0 | 2395 movwf sub_a+0 |
2396 movff hi,sub_b+1 | |
2397 movff lo,sub_b+0 | |
2398 call subU16 ; sub_c = sub_a - sub_b | |
604 | 2399 btfss neg_flag ; depth lower then 0.3m? |
2400 bra depth_less_0.3mtr ; YES - show ".0" manually | |
0 | 2401 |
2402 movlw d'4' | |
2403 movwf ignore_digits | |
604 | 2404 bsf ignore_digit5 ; (flag will be cleared by output_16) |
2405 output_16dp d'0' | |
2406 STRCAT_PRINT "" ; display decimeters | |
2407 bcf win_invert ; reset invert flag | |
582 | 2408 WIN_FONT FT_SMALL |
0 | 2409 return |
2410 | |
2411 depth_less_0.3mtr: | |
604 | 2412 STRCAT_PRINT "0" ; display 0.0m manually |
2413 bcf win_invert ; reset invert flag | |
582 | 2414 WIN_FONT FT_SMALL |
0 | 2415 return |
2416 | |
604 | 2417 depth_greater_99_84mtr: ; display only in full meters |
2418 btfss depth_greater_100m ; is depth > 100m already? | |
2419 rcall TFT_clear_depth ; NO - clear depth area and set flag | |
582 | 2420 call TFT_color_code_depth |
0 | 2421 ; Depth is already in hi:lo |
2422 ; Show depth in Full meters | |
560 | 2423 ; That means ignore digit 4 and 5 |
582 | 2424 lfsr FSR2,buffer |
0 | 2425 bsf ignore_digit4 |
2426 bsf leftbind | |
2427 output_16 | |
2428 bcf leftbind | |
604 | 2429 STRCAT_PRINT "" ; display full meters only |
2430 bcf win_invert ; reset invert flag | |
582 | 2431 WIN_FONT FT_SMALL |
0 | 2432 return |
2433 | |
604 | 2434 TFT_clear_depth: ; NO - clear depth area and set flag |
582 | 2435 WIN_BOX_BLACK dm_depth_row, dm_depth_bot, dm_depth_column, dm_depth_rgt ;top, bottom, left, right |
604 | 2436 bsf depth_greater_100m ; set flag |
0 | 2437 return |
2438 | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2439 TFT_depth_blink: |
582 | 2440 TSTOSS opt_modwarning ; 0=standard, 1=blink |
2441 return | |
2442 | |
2443 ; check if previous cycle had the blinking warning or not | |
604 | 2444 btfsc blinking_depth_prev ; did we have warning previously? |
2445 bra TFT_depth_blink_prevwarn; YES | |
2446 | |
2447 ; NO - check if it's set now | |
582 | 2448 btfsc blinking_depth_warning ; do we have warning set now? |
608 | 2449 bra TFT_depth_blink_warn ; YES - so we have warning now but not previously |
604 | 2450 btfsc blinking_depth_attention; do we have attention set now? |
608 | 2451 bra TFT_depth_blink_warn ; YES - so we have attention now but not previously |
582 | 2452 |
2453 ; no warning in previous cycle, no warning now, reset all flags | |
604 | 2454 bcf blinking_depth_prev ; reset previous flag |
582 | 2455 bcf blinking_depth_toggle ; reset toggle |
2456 bcf win_invert | |
604 | 2457 return ; all done |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2458 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2459 TFT_depth_blink_prevwarn: |
582 | 2460 ; ...we had warning in previous cycle, check if we still have the warning set |
604 | 2461 btfsc blinking_depth_warning ; do we still have the warning? |
2462 bra TFT_depth_blink_prevwarn_1 ; YES | |
2463 btfss blinking_depth_attention ; do we still have the attention? | |
2464 bra TFT_depth_blink_prevwarn_nowarn ; NO - clear the depth area | |
2465 TFT_depth_blink_prevwarn_1: | |
582 | 2466 ; we still have the warning, set previous flag for next cycle... |
2467 bsf blinking_depth_prev ; set prev flag | |
2468 ; and set toggle and invert if required | |
2469 btfss blinking_depth_toggle ; do we have the toggle set? | |
604 | 2470 bra TFT_depth_blink_set ; NO - set inverse, do color_box, set flag |
2471 bra TFT_depth_blink_reset ; Yes - clear inverse, do black box, reset flag | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2472 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2473 TFT_depth_blink_prevwarn_nowarn: |
582 | 2474 ; we had warning, but not now... (e.g. ascended or switched to better gas) |
2475 ; reset the previous cycle flag for the next cycle... | |
2476 bcf blinking_depth_prev ; reset prev flag | |
2477 ; clear it - just in case if we had a blinked before | |
604 | 2478 bra TFT_depth_blink_reset ; clear inverse, do black box, reset flag |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2479 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2480 TFT_depth_blink_warn: |
582 | 2481 ; new blinking warning activated (had no warning in previous cycle) |
2482 bsf blinking_depth_prev ; set prev flag | |
608 | 2483 ;bra TFT_depth_blink_set ; set toggle and invert |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2484 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2485 TFT_depth_blink_set: |
582 | 2486 ; clear the area with color |
608 | 2487 call TFT_attention_color_dive ; default background to attention color |
604 | 2488 btfsc blinking_depth_warning ; in warning mode? |
608 | 2489 call TFT_warnings_color_dive ; overwrite background color with warning color |
582 | 2490 WIN_BOX_COLOR dm_depth_row, dm_depth_bot, dm_depth_column, dm_depth_rgt ;top, bottom, left, right |
608 | 2491 bsf win_invert ;set the invert color |
2492 bsf blinking_depth_toggle ; set the toggle | |
2493 return ; all done | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2494 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2495 TFT_depth_blink_reset: |
582 | 2496 ; clear the area with black |
2497 WIN_BOX_BLACK dm_depth_row, dm_depth_bot, dm_depth_column, dm_depth_rgt ;top, bottom, left, right | |
608 | 2498 bcf win_invert ; reset the invert color |
2499 bcf blinking_depth_toggle ; reset the toggle | |
2500 call TFT_attention_color ; default to attention color | |
2501 btfsc blinking_depth_warning ; do we have a warning? | |
2502 call TFT_warnings_color ; YES - overwrite with warning color | |
2503 return ; all done | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2504 |
0 | 2505 ;============================================================================= |
2506 | |
582 | 2507 global TFT_custom_text |
604 | 2508 TFT_custom_text: ; show the custom text |
2509 call TFT_standard_color | |
2510 lfsr FSR0, opt_name ; source | |
2511 WIN_SMALL surf_customtext_column,surf_customtext_row1 ; 1st row | |
2512 rcall TFT_custom_text_2 ; show up to 12 chars and print | |
2513 incfsz lo,F ; was lo=255? | |
2514 return ; NO - all done | |
2515 lfsr FSR0, opt_name+.12 ; source | |
2516 WIN_SMALL surf_customtext_column,surf_customtext_row2 ; 2nd row | |
2517 rcall TFT_custom_text_2 ; show up to 12 chars and print | |
2518 incfsz lo,F ; was lo=255? | |
2519 return ; NO - all done | |
2520 lfsr FSR0, opt_name+.24 ; source | |
2521 WIN_SMALL surf_customtext_column,surf_customtext_row3 ; 3rd row | |
2522 rcall TFT_custom_text_2 ; show up to 12 chars and print | |
2523 incfsz lo,F ; was lo=255? | |
2524 return ; NO - all done | |
2525 lfsr FSR0, opt_name+.36 ; source | |
2526 WIN_SMALL surf_customtext_column,surf_customtext_row4 ; 4th row | |
2527 rcall TFT_custom_text_2 ; show up to 12 chars and print | |
2528 incfsz lo,F ; was lo=255? | |
2529 return ; NO - all done | |
2530 lfsr FSR0, opt_name+.48 ; source | |
2531 WIN_SMALL surf_customtext_column,surf_customtext_row5 ; 5th row | |
2532 bra TFT_custom_text_2 ; show up to 12 chars, print and return... | |
560 | 2533 |
0 | 2534 |
2535 TFT_custom_text_2: | |
582 | 2536 lfsr FSR2, buffer ; destination |
2537 movlw .12 | |
2538 movwf lo ; length/line | |
0 | 2539 TFT_custom_text_3: |
604 | 2540 movf POSTINC0,W ; get byte |
2541 bz TFT_custom_text_4 ; end if NULL | |
2542 movwf POSTINC2 ; NO - copy | |
2543 decfsz lo,F ; max length reached ? | |
2544 bra TFT_custom_text_3 ; NO - loop | |
582 | 2545 setf lo ; lo=255 -> more to come |
0 | 2546 TFT_custom_text_4: |
604 | 2547 clrf POSTINC2 ; mark end of string |
582 | 2548 goto aa_wordprocessor ; print and return |
0 | 2549 |
2550 | |
2551 ;============================================================================= | |
560 | 2552 |
0 | 2553 global TFT_update_surf_press |
2554 TFT_update_surf_press: | |
604 | 2555 WIN_SMALL surf_press_column+.8,surf_press_row |
0 | 2556 call TFT_standard_color |
582 | 2557 SAFE_2BYTE_COPY amb_pressure, lo |
0 | 2558 movff lo,sub_a+0 |
2559 movff hi,sub_a+1 | |
2560 movff last_surfpressure_30min+0,sub_b+0 | |
2561 movff last_surfpressure_30min+1,sub_b+1 | |
560 | 2562 call subU16 ; sub_c = sub_a - sub_b |
604 | 2563 btfsc neg_flag ; pressure lower? |
2564 rcall update_surf_press2 ; YES - test threshold | |
2565 tstfsz sub_c+1 ; >255 mbar difference? | |
2566 bra update_surf_press_common ; YES - display | |
560 | 2567 movlw d'11' ; 10mbar noise suppression |
0 | 2568 subwf sub_c+0,W |
2569 btfsc STATUS,C | |
604 | 2570 bra update_surf_press_common ; YES - display |
2571 SAFE_2BYTE_COPY last_surfpressure_30min, lo ; overwrite with stable value... | |
0 | 2572 update_surf_press_common: |
560 | 2573 movff lo,int_I_pres_surface+0 ; copy displayed value to C code to have pressure displayed |
2574 movff hi,int_I_pres_surface+1 ; and pressure used for desaturation & no-fly time in sync | |
0 | 2575 output_16 |
560 | 2576 ; Show only 4 digits |
0 | 2577 movff buffer+1,buffer+0 |
2578 movff buffer+2,buffer+1 | |
2579 movff buffer+3,buffer+2 | |
2580 movff buffer+4,buffer+3 | |
2581 movlw 0x00 | |
2582 movff WREG,buffer+4 | |
582 | 2583 STRCAT_PRINT "" |
2584 call TFT_divemask_color | |
604 | 2585 WIN_SMALL surf_press_column+(4+1)*8,surf_press_row |
2586 STRCPY_TEXT_PRINT tMBAR ; mbar (hPa) | |
0 | 2587 return |
2588 | |
2589 update_surf_press2: | |
2590 movff lo,sub_b+0 | |
2591 movff hi,sub_b+1 | |
2592 movff last_surfpressure_30min+0,sub_a+0 | |
2593 movff last_surfpressure_30min+1,sub_a+1 | |
604 | 2594 goto subU16 ; sub_c = sub_a - sub_b and return... |
0 | 2595 |
2596 ;============================================================================= | |
2597 | |
2598 global TFT_update_batt_voltage | |
2599 TFT_update_batt_voltage: | |
604 | 2600 movff batt_percent,lo ; get battery percent |
2601 clrf hi | |
2602 call TFT_color_code_battery ; color-code battery percent | |
582 | 2603 ; Setup charge indicator |
2604 btfsc cc_active | |
2605 bsf win_invert | |
2606 btfsc cc_active | |
2607 movlw color_yellow | |
2608 btfsc cv_active | |
2609 movlw color_green | |
2610 btfsc cc_active | |
2611 call TFT_set_color | |
604 | 2612 |
2613 IFDEF _ostc_logo | |
2614 WIN_TINY batt_percent_column,batt_percent_row | |
2615 ELSE | |
2616 WIN_SMALL batt_percent_column+.2,batt_percent_row | |
2617 ENDIF | |
2618 | |
2619 output_16_3 ; display only last three digits from a 16 bit value (0-999) | |
2620 STRCAT_PRINT "% " | |
582 | 2621 bcf win_invert |
0 | 2622 call TFT_standard_color |
604 | 2623 |
2624 IFDEF _ostc_logo | |
0 | 2625 WIN_TINY batt_voltage_column,batt_voltage_row |
604 | 2626 ELSE |
2627 WIN_TINY batt_voltage_column+.15,batt_voltage_row | |
2628 ENDIF | |
2629 | |
2630 movff battery_type,lo ; =0: 1.5V, =1: 3.6V Saft, =2: LiIon 3.7V/0.8Ah, =3: LiIon 3.7V/3.1Ah, =4: LiIon 3.7V/2.3Ah | |
477
44b8a826b314
NEW: Show battery type in surface mode next to battery voltage
heinrichsweikamp
parents:
475
diff
changeset
|
2631 PUTC "T" |
582 | 2632 bsf leftbind |
2633 output_8 | |
2634 PUTC ":" | |
0 | 2635 movff batt_voltage+0,lo |
2636 movff batt_voltage+1,hi | |
582 | 2637 output_16dp .2 |
0 | 2638 bcf leftbind |
2639 PUTC 'V' | |
477
44b8a826b314
NEW: Show battery type in surface mode next to battery voltage
heinrichsweikamp
parents:
475
diff
changeset
|
2640 movff buffer+8,buffer+6 |
0 | 2641 movlw 0x00 |
604 | 2642 movff WREG,buffer+7 ; only "x.yV" |
582 | 2643 STRCAT_PRINT "" |
0 | 2644 return |
2645 | |
2646 ;update_battery_debug: | |
2647 ; call TFT_standard_color | |
2648 ; WIN_TINY .70,.0 | |
2649 ; movff battery_gauge+5,xC+3 | |
2650 ; movff battery_gauge+4,xC+2 | |
2651 ; movff battery_gauge+3,xC+1 | |
2652 ; movff battery_gauge+2,xC+0 | |
2653 ; ; battery_gauge:6 is nAs | |
2654 ; ; devide through 65536 | |
2655 ; ; devide through 152 | |
2656 ; ; Result is 0.01Ah in xC+1:xC+0 | |
2657 ; movlw LOW .152 | |
2658 ; movwf xB+0 | |
2659 ; movlw HIGH .152 | |
2660 ; movwf xB+1 | |
604 | 2661 ; call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder |
0 | 2662 ; bsf leftbind |
2663 ; movff xC+0,lo | |
2664 ; movff xC+1,hi | |
2665 ; output_16 | |
2666 ; STRCAT_PRINT "x.01Ah" | |
2667 ; WIN_FONT FT_SMALL | |
2668 ; bcf leftbind | |
2669 ; return | |
582 | 2670 |
0 | 2671 ;============================================================================= |
2672 | |
2673 global TFT_convert_signed_16bit | |
2674 TFT_convert_signed_16bit: | |
604 | 2675 bcf neg_flag ; positive temperature |
2676 btfss hi,7 ; negative temperature ? | |
2677 return ; NO - return | |
2678 ; YES - negative temperature | |
2679 bsf neg_flag ; negative temperature | |
2680 PUTC '-' ; display "-" | |
2681 comf hi ; 16 bit sign change | |
582 | 2682 negf lo |
2683 btfsc STATUS,C | |
2684 incf hi | |
604 | 2685 return ; done |
0 | 2686 |
2687 ;============================================================================= | |
2688 | |
2689 global TFT_convert_date | |
604 | 2690 TFT_convert_date: ; converts into "DD/MM/YY" or "MM/DD/YY" or "YY/MM/DD" in postinc2 |
2691 movff opt_dateformat,WREG ; =0:MMDDYY, =1:DDMMYY, =2:YYMMDD | |
2692 movwf EEDATA ; used as temp here | |
0 | 2693 tstfsz EEDATA |
604 | 2694 bra TFT_convert_date_1 ; opt_dateformat is 1 or 2 |
2695 ; opt_dateformat is 0 | |
2696 ; use MMDDYY | |
2697 movff lo,lo_temp ; incoming: lo = day, hi = month | |
2698 movff hi,lo ; swap | |
2699 movff lo_temp,hi ; now: lo = month, hi = day | |
582 | 2700 bra TFT_convert_date_common |
2701 | |
2702 TFT_convert_date_1: | |
2703 decfsz EEDATA,F | |
604 | 2704 bra TFT_convert_date_2 ; opt_dateformat is 2 |
2705 ; opt_dateformat is 1 | |
2706 ; use DDMMYY | |
582 | 2707 TFT_convert_date_common: |
0 | 2708 bsf leftbind |
604 | 2709 output_99x ; with lo = month or day or year |
582 | 2710 PUTC '.' |
604 | 2711 movff hi,lo ; now lo = day or month or month |
0 | 2712 output_99x |
582 | 2713 PUTC '.' |
604 | 2714 movff up,lo ; now lo = year or year or day |
0 | 2715 output_99x |
2716 bcf leftbind | |
2717 return | |
2718 | |
582 | 2719 TFT_convert_date_2: |
604 | 2720 ; opt_dateformat is 2 |
2721 ; use YYMMDD | |
2722 movff lo,lo_temp ; incoming: lo = day, up = year | |
2723 movff up,lo ; swap | |
2724 movff lo_temp,up ; now : lo = year, up = day | |
582 | 2725 bra TFT_convert_date_common |
0 | 2726 |
2727 ;============================================================================= | |
2728 | |
2729 global TFT_convert_date_short | |
604 | 2730 TFT_convert_date_short: ; converts into "DD/MM" or "MM/DD" or "MM/DD" in postinc2 |
2731 movff opt_dateformat,WREG ; =0:MMDDYY, =1:DDMMYY, =2:YYMMDD | |
2732 movwf EEDATA ; used as temp here | |
0 | 2733 tstfsz EEDATA |
582 | 2734 bra TFT_convert_date_short_1 |
604 | 2735 ; opt_dateformat is 0 |
2736 ; use MMDD(YY) | |
582 | 2737 TFT_convert_date_short_0: |
604 | 2738 movff lo,lo_temp ; incoming: lo = day, hi = month |
2739 movff hi,lo ; swap | |
2740 movff lo_temp,hi ; now: lo = month, hi = day | |
582 | 2741 bra TFT_convert_date_short_common |
2742 | |
2743 TFT_convert_date_short_1: | |
2744 decfsz EEDATA,F | |
604 | 2745 bra TFT_convert_date_short_0 ; opt_dateformat is 2 -> use (YY)MMDD |
2746 ; opt_dateformat is 1 | |
2747 ; use DDMM(YY) | |
0 | 2748 TFT_convert_date_short_common: |
2749 bsf leftbind | |
604 | 2750 output_99x ; with lo = month or day |
582 | 2751 PUTC '.' |
604 | 2752 movff hi,lo ; now lo = day or month |
0 | 2753 output_99x |
2754 bcf leftbind | |
2755 return | |
2756 | |
2757 ;============================================================================= | |
2758 | |
2759 global TFT_date | |
2760 TFT_date: | |
604 | 2761 WIN_SMALL surf_date_column,surf_date_row ; init new wordprocessor |
0 | 2762 call TFT_standard_color |
582 | 2763 movff day,lo |
2764 movff month,hi | |
2765 movff year,up | |
560 | 2766 call TFT_convert_date ; converts into "DD/MM/YY" or "MM/DD/YY" or "YY/MM/DD" in postinc2 |
0 | 2767 STRCAT_PRINT "" |
2768 return | |
2769 | |
2770 ;============================================================================= | |
2771 | |
560 | 2772 global TFT_max_depth_alternative |
582 | 2773 TFT_max_depth_alternative: |
604 | 2774 bcf FLAG_TFT_max_depth |
560 | 2775 ; The "mask" |
582 | 2776 call TFT_divemask_color |
2777 WIN_TINY dm_mask_depth_column, dm_max_alt_row-.14 | |
604 | 2778 btfsc FLAG_apnoe_mode ; in Apnea mode? |
2779 bra TFT_max_depth_alternative2 ; YES - always draw max depth | |
2780 TSTOSS opt_2ndDepthDisp ; draw avg depth instead of max depth? | |
2781 bra TFT_max_depth_alternative2 ; NO - draw max depth | |
2782 STRCAT_TEXT_PRINT tAvgDepth ; YES - print avg depth mask | |
2783 movff avg_rel_pressure_total+0,lo ; - get avg depth, low byte | |
2784 movff avg_rel_pressure_total+1,hi ; - high byte | |
2785 bra TFT_max_depth_alternative3 | |
2786 TFT_max_depth_alternative2: | |
2787 STRCAT_TEXT_PRINT tMaxDepth ; print max depth mask | |
2788 SAFE_2BYTE_COPY max_pressure, lo ; get max depth into hi:lo | |
2789 TFT_max_depth_alternative3: | |
2790 call adjust_depth_with_salinity ; compute salinity setting into lo:hi [mbar] | |
2791 call TFT_memo_color | |
2792 WIN_LARGE dm_max_alt_column,dm_max_alt_row | |
2793 TSTOSS opt_units ; 0=m or 1=ft? | |
2794 bra TFT_max_depth_alt_metric ; 0 - use alternative metric version | |
2795 bra TFT_max_depth_imperial ; 1 - use common imperial version | |
560 | 2796 TFT_max_depth_alt_metric: |
604 | 2797 movff hi,sub_b+1 ; backup hi in sub_b+1 |
2798 movff lo,sub_b+0 ; backup lo in sub_b+0 | |
2799 bsf ignore_digit4 ; no 0.1 m | |
560 | 2800 output_16 |
2801 STRCAT_PRINT "" | |
604 | 2802 WIN_MEDIUM dm_max_dm_alt_column,dm_max_alt_row+.25 |
2803 bra TFT_max_depth_metric3 ; continue with normal metric version for decimal | |
582 | 2804 |
2805 | |
560 | 2806 global TFT_max_depth |
2807 TFT_max_depth: | |
604 | 2808 bcf FLAG_TFT_max_depth |
2809 btfsc FLAG_apnoe_mode ; in Apnoe mode? | |
2810 bra TFT_max_depth1 ; YES - different handling in Apnoe mode | |
2811 TSTOSS opt_2ndDepthDisp ; draw avg depth instead of max depth? | |
2812 bra TFT_max_depth2 ; NO - show max depth | |
2813 movff avg_rel_pressure_total+0,lo ; YES - get avg depth, low byte | |
2814 movff avg_rel_pressure_total+1,hi ; - high byte | |
2815 bra TFT_max_depth3 | |
2816 TFT_max_depth1: | |
2817 btfss FLAG_active_descent ; are we descending? | |
2818 bra TFT_max_depth2 ; NO - show normal max | |
2819 SAFE_2BYTE_COPY apnoe_max_pressure,lo ; YES - get apnoe_max_pressure | |
2820 bra TFT_max_depth3 | |
560 | 2821 TFT_max_depth2: |
604 | 2822 SAFE_2BYTE_COPY max_pressure,lo ; get the "normal" max depth |
560 | 2823 TFT_max_depth3: |
2824 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
604 | 2825 movlw .039 ; load encoding for 99.84 m |
2826 cpfslt hi ; is depth to show > 99.84 m ? | |
2827 bra TFT_max_depth3a ; YES | |
2828 btfss max_depth_greater_100m ; NO - was depth > 100 m during last call? | |
2829 bra TFT_max_depth3c ; NO | |
2830 bcf max_depth_greater_100m ; YES - clear flag, last depth shown now not > 100 m anymore | |
2831 bra TFT_max_depth3b ; - clear depth area | |
2832 TFT_max_depth3a: | |
2833 btfsc max_depth_greater_100m ; YES - was depth > 100 m during last call? | |
2834 bra TFT_max_depth3c ; YES | |
2835 bsf max_depth_greater_100m ; NO - set flag, last depth shown now > 100 m | |
2836 ;bra TFT_max_depth3b ; - clear depth area | |
2837 TFT_max_depth3b: | |
2838 WIN_BOX_BLACK dm_max_depth_row, dm_max_depth_bot, dm_max_depth_column, dm_max_depth_rgt ; top, bottom, left, right | |
2839 TFT_max_depth3c: | |
2840 call TFT_memo_color ; set output color | |
582 | 2841 WIN_MEDIUM dm_max_depth_column_nvsi, dm_max_depth_row |
604 | 2842 TSTOSS opt_vsigraph ; graphical VSI bar enabled? |
2843 bra TFT_max_depth4 ; NO | |
2844 WIN_MEDIUM dm_max_depth_column, dm_max_depth_row ; YES - adopt output position | |
2845 TFT_max_depth4: | |
2846 TSTOSS opt_units ; 0=m or 1=ft ? | |
2847 bra TFT_max_depth_metric ; 0 - use metric version | |
2848 TFT_max_depth_imperial: ; 1 - use imperial version | |
2849 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
2850 output_16_3 | |
2851 bra TFT_max_depth_exit | |
2852 TFT_max_depth_metric: | |
2853 btfss max_depth_greater_100m ; depth to show > 100 m ? | |
2854 bra TFT_max_depth_metric0 ; NO - show meters and decimeters | |
2855 bsf ignore_digit4 ; YES - show full meters only, i.e. ignore digits 4 and 5 | |
2856 bsf leftbind | |
2857 output_16 | |
2858 bra TFT_max_depth_exit | |
2859 TFT_max_depth_metric0: | |
2860 movff hi,sub_b+1 ; copy hi to sub_b+1, will also be used to back-up hi | |
2861 movff lo,sub_b+0 ; copy lo to sub_b+0, will also be used to back-up lo | |
2862 | |
2863 movlw HIGH d'999' | |
11 | 2864 movwf sub_a+1 |
604 | 2865 movlw LOW d'999' |
11 | 2866 movwf sub_a+0 |
604 | 2867 call sub16 ; sub_c = sub_a - sub_b |
582 | 2868 movlw ' ' |
604 | 2869 btfss neg_flag ; depth lower than 10m ? |
2870 movwf POSTINC2 ; YES - add extra space | |
582 | 2871 |
2872 clrf sub_a+1 | |
11 | 2873 movlw d'99' |
2874 movwf sub_a+0 | |
604 | 2875 call subU16 ; sub_c = sub_a - sub_b |
2876 btfss neg_flag ; depth lower than 1m ? | |
2877 bra TFT_max_depth_metric1 ; YES - manually display a zero | |
2878 bsf ignore_digit4 ; NO - no 0.1 m | |
2879 bsf leftbind ; - align left | |
2880 output_16 ; - display full meters | |
2881 bra TFT_max_depth_metric2 | |
2882 TFT_max_depth_metric1: | |
2883 STRCAT "0" ; display a zero | |
2884 TFT_max_depth_metric2: | |
2885 STRCAT_PRINT "" | |
2886 ; .1 m in SMALL font | |
2887 WIN_SMALL dm_max_depth_dm_column_nvsi, dm_max_depth_dm_row | |
2888 TSTOSS opt_vsigraph ; graphical VSI bar enabled? | |
2889 bra TFT_max_depth_metric3 ; NO | |
2890 WIN_SMALL dm_max_depth_dm_column, dm_max_depth_dm_row ; YES - adopt position | |
2891 TFT_max_depth_metric3: | |
2892 movff sub_b+1,hi ; restore hi | |
2893 movff sub_b+0,lo ; restore lo | |
2894 PUTC "." ; print decimal point | |
11 | 2895 movlw d'4' |
2896 movwf ignore_digits | |
604 | 2897 bsf ignore_digit5 ; no 0.01 m, flag will be cleared by output_16 |
582 | 2898 bsf leftbind |
604 | 2899 output_16dp d'0' |
2900 TFT_max_depth_exit: | |
2901 STRCAT_PRINT "" | |
11 | 2902 bcf leftbind |
604 | 2903 goto TFT_standard_color ; and return... |
0 | 2904 |
2905 ;============================================================================= | |
560 | 2906 |
0 | 2907 global TFT_divemins |
2908 TFT_divemins: | |
604 | 2909 bcf FLAG_TFT_divemins ; clear flag |
0 | 2910 movff divemins+0,lo |
2911 movff divemins+1,hi | |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2912 |
582 | 2913 ; Already showing divemins > 99min |
604 | 2914 btfsc no_more_divesecs ; ignore seconds? |
2915 bra TFT_divemins2 ; show minutes only | |
582 | 2916 |
2917 tstfsz hi ; hi = 0? | |
604 | 2918 bra TFT_divemins_clr ; NO - show mins only |
405
08fea401be24
BUGFIX: Divetime >99mins was not displayed (Only OSTC2 with serial >= )
heinrichsweikamp
parents:
399
diff
changeset
|
2919 |
0 | 2920 movlw .99 |
582 | 2921 cpfsgt lo ; bigger than 99? |
604 | 2922 bra TFT_divemins1 ; NO - show mins:secs |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2923 |
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2924 TFT_divemins_clr: |
604 | 2925 ; YES - remove second display for the rest of the dive and clear seconds |
2926 bsf no_more_divesecs ; - set flag | |
2927 ; - clear rest of seconds | |
582 | 2928 WIN_BOX_BLACK dm_divetime_row, dm_divetime_bot, dm_divetime_column, dm_divetime_rgt ;top, bottom, left, right |
604 | 2929 bra TFT_divemins2 ; - show minutes only |
0 | 2930 |
2931 TFT_divemins1: | |
604 | 2932 ; Print out the minutes, up to 99 minutes, only 2 chars! |
2933 call TFT_memo_color | |
582 | 2934 WIN_MEDIUM dm_divetime_column, dm_divetime_row |
604 | 2935 output_99 ; displays only last two figures from a 8 bit value (0-99) |
2936 STRCAT_PRINT "" ; show minutes in large font | |
582 | 2937 |
2938 ; Print out the seconds | |
604 | 2939 WIN_SMALL dm_divetime_secs_column, dm_divetime_secs_row ; left position for two sec figures |
582 | 2940 PUTC ':' |
2941 movff divesecs,lo | |
604 | 2942 bsf leftbind |
2943 output_99x ; displays only last two figures from a 8 bit value with leading zero (00-99) | |
2944 bra TFT_divemins_exit ; and return... | |
0 | 2945 |
2946 TFT_divemins2: | |
405
08fea401be24
BUGFIX: Divetime >99mins was not displayed (Only OSTC2 with serial >= )
heinrichsweikamp
parents:
399
diff
changeset
|
2947 ; Full minutes only |
604 | 2948 call TFT_memo_color |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
2949 WIN_MEDIUM dm_divetime_minsonly_column, dm_divetime_row |
582 | 2950 bcf leftbind |
2951 output_16_4 | |
604 | 2952 bra TFT_divemins_exit ; and return... |
2953 | |
582 | 2954 |
560 | 2955 global TFT_divemins_alternative |
2956 TFT_divemins_alternative: | |
604 | 2957 bcf FLAG_TFT_divemins ; clear flag |
2958 call TFT_memo_color | |
582 | 2959 ; Print out the minutes (0-999) in large |
2960 WIN_LARGE dm_divetime_alt_column, dm_divetime_alt_row | |
2961 movff divemins+0,lo | |
2962 movff divemins+1,hi | |
2963 output_16_3 ; limit to 999 and display only (0-999) | |
604 | 2964 STRCAT_PRINT "" ; show minutes |
582 | 2965 ; Print out the seconds in medium |
2966 WIN_MEDIUM dm_divetime_alt_column+.60, dm_divetime_alt_row+.25 | |
2967 PUTC ":" | |
604 | 2968 movff divesecs,lo |
582 | 2969 bsf leftbind |
2970 output_99x ; displays only last two figures from a 8Bit value with leading zero (00-99) | |
604 | 2971 TFT_divemins_exit: |
2972 STRCAT_PRINT "" | |
582 | 2973 bcf leftbind |
604 | 2974 goto TFT_standard_color ; and return... |
0 | 2975 |
2976 ;============================================================================= | |
560 | 2977 |
0 | 2978 global TFT_display_apnoe_surface |
2979 TFT_display_apnoe_surface: | |
604 | 2980 btfsc menuview ; is the options menu shown? |
2981 bra TFT_display_apnoe_surface_1 ; YES - skip title | |
582 | 2982 call TFT_divemask_color |
2983 WIN_TINY dm_apnoe_surface_time_text_col, dm_apnoe_surface_time_text_row | |
2984 STRCPY_TEXT_PRINT tApnoeSurface | |
604 | 2985 TFT_display_apnoe_surface_1: |
2986 call TFT_memo_color | |
582 | 2987 WIN_MEDIUM dm_apnoe_surface_time_column, dm_apnoe_surface_time_row |
0 | 2988 movff apnoe_surface_mins,lo |
2989 output_8 | |
582 | 2990 PUTC ':' |
0 | 2991 movff apnoe_surface_secs,lo |
2992 output_99x | |
604 | 2993 bra TFT_display_apnoe_exit ; and return... |
2994 | |
2995 | |
2996 global TFT_display_apnoe_last_max | |
2997 TFT_display_apnoe_last_max: | |
2998 call TFT_divemask_color | |
2999 WIN_TINY dm_apnoe_last_max_depth_text_col, dm_apnoe_last_max_depth_text_row | |
3000 STRCPY_TEXT_PRINT tApnoeMax | |
3001 call TFT_memo_color | |
3002 SAFE_2BYTE_COPY max_pressure, lo | |
3003 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
3004 TSTOSS opt_units ; 0=m, 1=ft | |
3005 bra TFT_display_apnoe_last_m_metric | |
3006 TFT_display_apnoe_last_max_imp: | |
3007 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
3008 WIN_MEDIUM dm_apnoe_last_max_depth_column, dm_apnoe_last_max_depth_row | |
3009 output_16 | |
3010 bra TFT_max_depth_exit | |
3011 TFT_display_apnoe_last_m_metric: | |
3012 WIN_MEDIUM dm_apnoe_last_max_depth_column, dm_apnoe_last_max_depth_row | |
3013 bsf ignore_digit5 ; do not display 1cm depth (flag will be cleared by output_16) | |
3014 output_16dp d'3' | |
3015 bra TFT_max_depth_exit | |
3016 | |
0 | 3017 |
3018 global TFT_display_apnoe_descent | |
604 | 3019 TFT_display_apnoe_descent: ; descent divetime |
0 | 3020 movff apnoe_mins,lo |
582 | 3021 clrf hi |
300
5ad479f2a868
Merged Screen layout mod #1 into Screen layout work #3
Janos Kovacs <kovjanos@gmail.com>
parents:
275
diff
changeset
|
3022 WIN_MEDIUM dm_divetime_apnoe_column, dm_divetime_apnoe_row |
582 | 3023 output_16_3 ; displays only last three figures from a 16Bit value (0-999) |
604 | 3024 call TFT_memo_color |
3025 STRCAT_PRINT "" ; show minutes in large font | |
3026 WIN_SMALL dm_divetime_apnoe_secs_column, dm_divetime_apnoe_secs_row ; left position for two sec figures | |
582 | 3027 PUTC ':' |
0 | 3028 bsf leftbind |
3029 movff apnoe_secs,lo | |
3030 output_99x | |
604 | 3031 STRCAT_PRINT "" ; show seconds in small font |
582 | 3032 call TFT_divemask_color |
3033 WIN_TINY dm_total_apnoe_text_column,dm_total_apnoe_text_row | |
3034 STRCPY_TEXT_PRINT tApnoeTotal | |
604 | 3035 call TFT_memo_color |
38 | 3036 movff divemins,lo |
582 | 3037 clrf hi |
3038 WIN_MEDIUM dm_apnoe_total_divetime_column, dm_apnoe_total_divetime_row | |
604 | 3039 bcf leftbind |
582 | 3040 output_16_3 ; displays only last three figures from a 16Bit value (0-999) |
604 | 3041 call TFT_memo_color |
3042 STRCAT_PRINT "" ; show minutes in large font | |
3043 WIN_SMALL dm_apnoe_total_divetime_secs_col, dm_apnoe_total_divetime_secs_row ; left position for two sec figures | |
582 | 3044 PUTC ':' |
38 | 3045 bsf leftbind |
3046 movff divesecs,lo | |
3047 output_99x | |
604 | 3048 TFT_display_apnoe_exit: |
3049 STRCAT_PRINT "" | |
582 | 3050 bcf leftbind |
604 | 3051 goto TFT_standard_color ; and return... |
3052 | |
3053 | |
3054 global TFT_apnoe_clear_surface | |
3055 TFT_apnoe_clear_surface: | |
3056 ; clear surface timer (TODO: partly wipes out options menu, too) | |
3057 WIN_BOX_BLACK dm_apnoe_surface_time_text_row, .239, dm_apnoe_surface_time_text_col, .159 ; top, bottom, left, right | |
0 | 3058 return |
582 | 3059 |
0 | 3060 |
3061 ;============================================================================= | |
604 | 3062 ; append firmware version to current string, including color-coding |
582 | 3063 |
3064 global TFT_cat_firmware | |
0 | 3065 TFT_cat_firmware: |
582 | 3066 movlw softwareversion_x |
3067 movwf lo | |
3068 bsf leftbind | |
3069 output_8 | |
3070 PUTC '.' | |
3071 movlw softwareversion_y | |
3072 movwf lo | |
604 | 3073 output_8 |
582 | 3074 bcf leftbind |
604 | 3075 rcall check_expiry |
3076 btfss aux_flag | |
582 | 3077 return |
604 | 3078 bsf win_invert |
3079 goto TFT_attention_color | |
3080 | |
3081 ;============================================================================= | |
3082 ; check if firmware is within expiry period, will return aux_flag set if not | |
3083 | |
3084 check_expiry: ; check if it is time for a firmware update | |
3085 bsf aux_flag ; set firmware as expired by default | |
3086 movlw firmware_expire_year ; start with checking year | |
3087 cpfsgt year ; current year > expiry year ? | |
3088 bra check_expiry_Y ; NO - continue checks | |
3089 return ; YES - expired | |
3090 check_expiry_Y: | |
3091 cpfseq year ; current year = expiry year ? | |
3092 bra check_expiry_ok ; NO - must be < then, OK whatever month & day | |
3093 movlw firmware_expire_month ; YES - continue checking month | |
3094 cpfsgt month ; current month > expiry month ? | |
3095 bra check_expiry_M ; NO - continue checks | |
3096 return ; YES - expired | |
3097 check_expiry_M: | |
3098 cpfseq month ; current month = expiry month ? | |
3099 bra check_expiry_ok ; NO - must be < then, OK whatever day | |
3100 movlw firmware_expire_day ; YES - continue checking day | |
3101 cpfsgt day ; current day > expiry day ? | |
3102 bra check_expiry_ok ; NO - must be <= then, OK | |
3103 return ; YES - expired | |
3104 check_expiry_ok: | |
3105 bcf aux_flag | |
582 | 3106 return |
604 | 3107 |
3108 ;============================================================================= | |
3109 ; append firmware BETA status to current string, including color-coding | |
3110 | |
3111 global TFT_cat_beta_rel | |
3112 global TFT_cat_beta_release | |
3113 TFT_cat_beta_release: ; entry point for printing "Release" / "Beta #" | |
3114 bsf aux_flag | |
3115 bra TFT_cat_beta_common | |
3116 TFT_cat_beta_rel: ; entry point for printing "Rel." / "B. #" | |
3117 bcf aux_flag | |
3118 TFT_cat_beta_common: | |
3119 IFDEF __DEBUG | |
3120 STRCAT "DEBUG" | |
3121 goto TFT_warnings_color | |
3122 ELSE | |
3123 movlw softwareversion_beta ; =0: release, =1: beta 1, =2: beta 2, ... | |
3124 movwf lo ; copy to lo | |
3125 tstfsz lo ; release version? | |
3126 bra TFT_cat_beta_1 ; NO - must be beta version then | |
3127 btfss aux_flag ; YES - shall show long version? | |
3128 bra TFT_cat_beta_2 ; NO - show short version | |
3129 rcall check_expiry ; YES - check expiry date | |
3130 btfsc aux_flag ; - within expiry date? | |
3131 bra TFT_cat_beta_4 ; NO - give update cue | |
3132 STRCAT "Release" ; YES - print "Release" | |
3133 return ; - done | |
3134 TFT_cat_beta_1: | |
3135 btfss aux_flag ; shall show long version? | |
3136 bra TFT_cat_beta_3 ; NO - show short version | |
3137 STRCAT "Beta " ; YES - show long version | |
3138 TFT_cat_beta_1a: | |
3139 bsf leftbind | |
3140 output_8 ; print beta version number | |
3141 bcf leftbind | |
3142 goto TFT_attention_color ; and return | |
3143 TFT_cat_beta_2 | |
3144 STRCAT "Rel." ; short version for "Release" | |
582 | 3145 return |
604 | 3146 TFT_cat_beta_3 |
3147 STRCAT "B." ; short version for "Beta" | |
3148 bra TFT_cat_beta_1a ; append beta version number | |
3149 TFT_cat_beta_4 | |
3150 STRCAT "update!" ; print update cue | |
3151 goto TFT_attention_color ; and return | |
3152 ENDIF | |
3153 | |
3154 ;============================================================================= | |
3155 ; For the Information menu: firmware version | |
3156 | |
3157 global info_menu_firmware | |
3158 info_menu_firmware: | |
3159 lfsr FSR1,tFirmware | |
3160 call strcat_text | |
3161 rcall TFT_cat_firmware | |
3162 PUTC " " | |
3163 rcall TFT_cat_beta_rel | |
3164 STRCAT_PRINT "" ; print buffer to screen | |
3165 return | |
3166 | |
3167 ;============================================================================= | |
3168 ; For the Information menu: firmware version of the RX processor | |
3169 | |
3170 IFDEF _rx_functions | |
3171 global info_menu_firmware_rx | |
3172 info_menu_firmware_rx: | |
3173 lfsr FSR1,tFirmware_rx | |
3174 call strcat_text | |
3175 ; bra TFT_cat_firmware_rx ;(and return) | |
3176 ;TFT_cat_firmware_rx: | |
3177 movff rx_firmware+0,lo | |
3178 bsf leftbind | |
3179 output_8 | |
3180 PUTC '.' | |
3181 movff rx_firmware+1,lo | |
3182 output_8 | |
3183 bcf leftbind | |
3184 return | |
3185 ENDIF | |
0 | 3186 |
3187 ;----------------------------------------------------------------------------- | |
604 | 3188 ; For the Information menu: append serial number |
560 | 3189 |
582 | 3190 global info_menu_serial |
0 | 3191 info_menu_serial: |
582 | 3192 lfsr FSR1,tSerial |
3193 call strcat_text | |
3194 global TFT_cat_serial | |
0 | 3195 TFT_cat_serial: |
582 | 3196 clrf EEADRH |
604 | 3197 clrf EEADR ; get serial number LOW |
582 | 3198 call read_eeprom ; read byte |
3199 movff EEDATA,lo | |
604 | 3200 incf EEADR,F ; get serial number HIGH |
582 | 3201 call read_eeprom ; read byte |
3202 movff EEDATA,hi | |
3203 | |
3204 bsf leftbind | |
3205 output_16 | |
3206 bcf leftbind | |
3207 return | |
0 | 3208 |
3209 ;----------------------------------------------------------------------------- | |
604 | 3210 ; For the Information menu: append total dives |
560 | 3211 |
582 | 3212 global info_menu_total_dives |
0 | 3213 info_menu_total_dives: |
582 | 3214 lfsr FSR1,tTotalDives |
3215 call strcat_text | |
0 | 3216 TFT_cat_total_dives: |
3217 read_int_eeprom .2 | |
3218 movff EEDATA,lo | |
3219 read_int_eeprom .3 | |
3220 movff EEDATA,hi | |
3221 bsf leftbind | |
3222 output_16 | |
582 | 3223 bcf leftbind |
3224 return | |
0 | 3225 |
604 | 3226 ; For the Information menu: append battery voltage |
582 | 3227 global info_menu_battery_volts |
62 | 3228 info_menu_battery_volts: |
582 | 3229 lfsr FSR1,tBatteryV |
3230 call strcat_text | |
3231 movff batt_voltage+1,hi | |
3232 movff batt_voltage+0,lo | |
62 | 3233 bsf leftbind |
582 | 3234 output_16dp .2 ; x.xxx |
3235 STRCAT "V(T" | |
604 | 3236 movff battery_type,lo ; =0:1.5V, =1:3.6V Saft, =2:LiIon 3.7V/0.8Ah, =3:LiIon 3.7V/3.1Ah, =4: LiIon 3.7V/2.3Ah |
582 | 3237 output_8 |
3238 bcf leftbind | |
3239 PUTC ")" | |
3240 return | |
3241 | |
604 | 3242 ; For the Information menu: append uptime |
582 | 3243 global info_menu_uptime |
453
b4f28ab23b87
NEW: Show Uptime (Time since last firmware boot) in information menu
heinrichsweikamp
parents:
444
diff
changeset
|
3244 info_menu_uptime: |
582 | 3245 lfsr FSR1,tUptime |
3246 call strcat_text | |
3247 movff uptime+0,xC+0 | |
3248 movff uptime+1,xC+1 | |
3249 movff uptime+2,xC+2 | |
3250 movff uptime+3,xC+3 | |
3251 movlw LOW .3600 | |
3252 movwf xB+0 | |
3253 movlw HIGH .3600 | |
604 | 3254 movwf xB+1 ; one day = 3600s |
582 | 3255 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder |
3256 ;xC+0:xC+1 -> Full hours | |
3257 movff xC+1,xA+1 | |
3258 movff xC+0,xA+0 | |
3259 clrf xB+1 | |
3260 movlw .24 | |
3261 movwf xB+0 | |
604 | 3262 call div16x16 ; xC = xA / xB with xA as remainder |
582 | 3263 movff xC+0,lo |
604 | 3264 movff xC+1,hi ; full days |
582 | 3265 bsf leftbind |
3266 output_16 | |
3267 PUTC "d" | |
604 | 3268 movff xA+0,lo ; full hours |
582 | 3269 output_8 |
3270 PUTC "h" | |
3271 bcf leftbind | |
604 | 3272 return ; done |
3273 | |
3274 | |
582 | 3275 global menu_cal_x |
3276 menu_cal_x: | |
604 | 3277 lfsr FSR0,compass_CX_f |
582 | 3278 lfsr FSR1,tCalX |
604 | 3279 bra menu_cal_common |
582 | 3280 |
3281 global menu_cal_y | |
3282 menu_cal_y: | |
604 | 3283 lfsr FSR0,compass_CY_f |
582 | 3284 lfsr FSR1,tCalY |
604 | 3285 bra menu_cal_common |
3286 | |
582 | 3287 global menu_cal_z |
3288 menu_cal_z: | |
604 | 3289 lfsr FSR0,compass_CZ_f |
582 | 3290 lfsr FSR1,tCalZ |
604 | 3291 menu_cal_common: |
582 | 3292 call strcat_text |
604 | 3293 movff POSTINC0,lo |
3294 movff POSTINC0,hi | |
582 | 3295 call TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required |
3296 bsf leftbind | |
3297 output_16 | |
3298 bcf leftbind | |
3299 return | |
544
64a45f203144
NEW: Show Compass calibration results in Compass menu
heinrichsweikamp
parents:
535
diff
changeset
|
3300 |
453
b4f28ab23b87
NEW: Show Uptime (Time since last firmware boot) in information menu
heinrichsweikamp
parents:
444
diff
changeset
|
3301 |
0 | 3302 ;----------------------------------------------------------------------------- |
3303 ; ppO2 menu | |
560 | 3304 |
0 | 3305 global divesets_ppo2_min |
3306 divesets_ppo2_min: | |
582 | 3307 lfsr FSR1,tPPO2MIN |
3308 call strcat_text | |
560 | 3309 movff char_I_ppO2_min,lo |
582 | 3310 movlw ppo2_warning_low_default |
3311 bra divesets_ppo2_common | |
560 | 3312 |
3313 global divesets_ppo2_min_cc | |
3314 divesets_ppo2_min_cc: | |
3315 lfsr FSR1,tPPO2MINCC | |
3316 call strcat_text | |
3317 movff char_I_ppO2_min_loop,lo | |
582 | 3318 movlw ppo2_warning_loop_default |
3319 bra divesets_ppo2_common | |
3320 | |
3321 global divesets_ppo2_max | |
3322 divesets_ppo2_max: | |
3323 lfsr FSR1,tPPO2Max | |
3324 call strcat_text | |
3325 movff char_I_ppO2_max,lo | |
3326 movlw ppo2_warning_high_default | |
560 | 3327 bra divesets_ppo2_common |
582 | 3328 |
3329 global divesets_ppo2_max_deco | |
3330 divesets_ppo2_max_deco: | |
3331 lfsr FSR1,tPPO2DECO | |
3332 call strcat_text | |
3333 movff char_I_ppO2_max_deco,lo | |
3334 movlw ppo2_warning_deco_default | |
3335 ;bra divesets_ppo2_common | |
3336 | |
3337 divesets_ppo2_common: | |
604 | 3338 movwf up ; save default value |
582 | 3339 clrf hi |
3340 bsf leftbind | |
3341 output_16dp d'3' | |
3342 bcf leftbind | |
3343 lfsr FSR1,tbar | |
3344 call strcat_text | |
604 | 3345 movf up,W ; default value |
3346 cpfseq lo ; current value | |
3347 bra divesets_ppo2_common2 ; not default, add * | |
3348 return ; default, done | |
582 | 3349 divesets_ppo2_common2: |
3350 PUTC "*" | |
604 | 3351 return ; done |
560 | 3352 |
3353 ;============================================================================= | |
582 | 3354 |
3355 global TFT_clear_warning_text | |
3356 TFT_clear_warning_text: | |
3357 btfss divemode ; in divemode? | |
604 | 3358 bra TFT_clear_warning_text2 ; NO - setup for surface mode |
3359 bcf FLAG_TFT_dive_warning_text_clear ; clear flag | |
582 | 3360 btfsc alternative_divelayout |
604 | 3361 bra TFT_clear_warning_text_2nd_row ; in alt. mode, clear only row 2 |
582 | 3362 WIN_BOX_BLACK dm_warning_row, dm_warning_bot, dm_warning_column, dm_warning_rgt ; top, bottom, left, right |
3363 return | |
3364 TFT_clear_warning_text2: | |
3365 WIN_BOX_BLACK surf_warning1_row, surf_warning2_row+.24, surf_warning1_column, surf_warning1_column+.76 ; top, bottom, left, right | |
3366 return | |
3367 | |
3368 global TFT_clear_warning_text_2nd_row | |
3369 TFT_clear_warning_text_2nd_row: | |
3370 btfss divemode ; in divemode? | |
604 | 3371 bra TFT_clear_warning_text_2nd_2 ; NO - setup for surface mode |
3372 bcf FLAG_TFT_dive_warning_text_clr2 ; clear flag | |
582 | 3373 WIN_BOX_BLACK dm_warning2_row, dm_warning2_bot, dm_warning2_column, dm_warning2_rgt ; top, bottom, left, right |
3374 return | |
3375 TFT_clear_warning_text_2nd_2: | |
3376 WIN_BOX_BLACK surf_warning2_row, surf_warning2_row+.24, surf_warning2_column, surf_warning2_column+.76 ; top, bottom, left, right | |
3377 return | |
3378 | |
3379 global TFT_fillup_with_spaces | |
604 | 3380 TFT_fillup_with_spaces: ; fill up FSR2 with spaces (total string length in #WREG) |
582 | 3381 movwf lo ; save max. string length into lo |
604 | 3382 movf FSR2L,W ; get current string length |
582 | 3383 subwf lo,F ; lo-WREG |
3384 btfsc STATUS,N ; longer then #lo already? | |
604 | 3385 return ; YES - done |
3386 tstfsz lo ; zero? | |
3387 bra TFT_fillup_with_spaces2 ; NO | |
3388 return ; YES - done | |
582 | 3389 TFT_fillup_with_spaces2: |
604 | 3390 PUTC " " ; add one space |
3391 decfsz lo,F ; all done? | |
3392 bra TFT_fillup_with_spaces2 ; NO - loop | |
3393 return ; YES - done | |
582 | 3394 |
3395 ;============================================================================= | |
3396 | |
0 | 3397 global TFT_desaturation_time |
3398 TFT_desaturation_time: | |
604 | 3399 rcall TFT_warning_set_window ; set the row and column for the current message |
3400 tstfsz WREG ; is there room for the message? | |
3401 return ; NO | |
3402 call TFT_memo_color | |
0 | 3403 STRCPY "Desat:" |
560 | 3404 movff int_O_desaturation_time+0,lo |
3405 movff int_O_desaturation_time+1,hi | |
604 | 3406 call convert_time ; converts hi:lo in minutes to hours (up:hi) and minutes (lo) |
3407 ; bsf leftbind | |
560 | 3408 movf lo,W |
3409 movff hi,lo | |
3410 movwf hi ; exchange lo and hi... | |
604 | 3411 output_99x ; hours |
560 | 3412 PUTC ':' |
604 | 3413 movff hi,lo ; minutes |
0 | 3414 output_99x |
604 | 3415 ; bcf leftbind |
3416 movlw surf_warning_length ; only use surface string length | |
3417 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3418 ; movlw .0 ; not needed | |
3419 ; movff WREG,buffer+11 ; not needed | |
560 | 3420 STRCAT_PRINT "" |
0 | 3421 return |
3422 | |
560 | 3423 |
0 | 3424 global TFT_nofly_time |
3425 TFT_nofly_time: | |
604 | 3426 rcall TFT_warning_set_window ; set the row and column for the current message |
3427 tstfsz WREG ; is there room for the message? | |
3428 return ; NO | |
3429 call TFT_memo_color | |
560 | 3430 movff char_I_altitude_wait,WREG |
3431 tstfsz WREG | |
3432 bra TFT_nofly_time_1 | |
0 | 3433 STRCPY "NoFly:" |
560 | 3434 bra TFT_nofly_time_2 |
3435 TFT_nofly_time_1: | |
3436 STRCPY "NoAlt:" | |
3437 TFT_nofly_time_2: | |
3438 movff int_O_nofly_time+0,lo | |
3439 movff int_O_nofly_time+1,hi | |
604 | 3440 call convert_time ; converts hi:lo in minutes to hours (up:hi) and minutes (lo) |
3441 ; bsf leftbind | |
560 | 3442 movf lo,W |
3443 movff hi,lo | |
582 | 3444 movwf hi ; exchange lo and hi... |
604 | 3445 output_99x ; hours |
560 | 3446 PUTC ':' |
604 | 3447 movff hi,lo ; minutes |
0 | 3448 output_99x |
604 | 3449 ; bcf leftbind |
3450 movlw surf_warning_length ; only use surface string length | |
3451 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3452 ; movlw .0 ; not needed | |
3453 ; movff WREG,buffer+11 ; not needed | |
582 | 3454 STRCAT_PRINT "" |
0 | 3455 return |
3456 | |
560 | 3457 ;============================================================================= |
3458 | |
582 | 3459 global TFT_warning_agf |
0 | 3460 TFT_warning_agf: |
604 | 3461 rcall TFT_warning_set_window ; set the row and column for the current message |
3462 tstfsz WREG ; is there room for the message? | |
3463 return ; NO | |
582 | 3464 call TFT_attention_color |
3465 STRCPY_TEXT tDiveaGF_active ; "aGF!" | |
604 | 3466 movlw dm_warning_length ; divemode string length |
3467 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3468 STRCAT_PRINT "" |
604 | 3469 bra TFT_warn_att_info_exit ; and return... |
3470 | |
0 | 3471 |
582 | 3472 global TFT_warning_fallback |
604 | 3473 TFT_warning_fallback: ; show fallback warning |
3474 rcall TFT_warning_set_window ; set the row and column for the current message | |
3475 tstfsz WREG ; is there room for the message? | |
3476 return ; NO | |
582 | 3477 call TFT_warnings_color |
560 | 3478 STRCPY_TEXT tDiveFallback ; "Fallback!" |
604 | 3479 movlw dm_warning_length ; divemode string length |
3480 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3481 STRCAT_PRINT "" | |
3482 bra TFT_warn_att_info_exit ; and return... | |
3483 | |
3484 | |
3485 IFDEF _rx_functions | |
3486 | |
3487 global TFT_advice_switch | |
3488 TFT_advice_switch: | |
3489 rcall TFT_warning_set_window ; set the row and column for the current message | |
3490 tstfsz WREG ; is there room for the message? | |
3491 return ; NO | |
3492 call TFT_advice_color | |
3493 STRCPY_TEXT tswap ; "Swap Tank" | |
3494 movlw dm_warning_length ; divemode string length | |
3495 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3496 STRCAT_PRINT "" | |
3497 bra TFT_warn_att_info_exit ; and return... | |
3498 | |
3499 global TFT_attention_transmitter | |
3500 TFT_attention_transmitter: | |
3501 rcall TFT_warning_set_window ; set the row and column for the current message | |
3502 tstfsz WREG ; is there room for the message? | |
3503 return ; NO | |
3504 call TFT_attention_color | |
3505 STRCPY_TEXT tTransmitter ; "P.Transm." | |
3506 movlw dm_warning_length ; divemode string length | |
3507 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3508 STRCAT_PRINT "" |
604 | 3509 bra TFT_warn_att_info_exit ; and return... |
3510 | |
3511 global TFT_attention_pres_reading | |
3512 global TFT_warning_pres_reading | |
3513 TFT_attention_pres_reading: ; entry point for attention | |
3514 call TFT_attention_color ; use attention color | |
3515 bra TFT_common_pres_reading ; continue with common code | |
3516 TFT_warning_pres_reading: ; entry point for warning | |
3517 call TFT_warnings_color ; use warnings color | |
3518 ;bra TFT_common_pres_reading ; continue with common code | |
3519 TFT_common_pres_reading: | |
3520 rcall TFT_warning_set_window ; set the row and column for the current message | |
3521 tstfsz WREG ; is there room for the message? | |
3522 return ; NO - done | |
3523 STRCPY_TEXT tPressure ; "Tank Pres" | |
3524 movlw dm_warning_length ; divemode string length | |
3525 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3526 STRCAT_PRINT "" | |
3527 bra TFT_warn_att_info_exit ; and return... | |
3528 | |
3529 global TFT_attention_sac | |
3530 TFT_attention_sac: | |
3531 rcall TFT_warning_set_window ; set the row and column for the current message | |
3532 tstfsz WREG ; is there room for the message? | |
3533 return ; NO | |
3534 movff int_O_sac_rate+0,lo ; copy SAC rate to hi:lo | |
3535 movff int_O_sac_rate+1,hi ; ... | |
3536 call TFT_color_code_tank_pres_sac; color-code the output | |
3537 STRCPY_TEXT tSAC ; "SAC", needs to be exactly 3 chars long | |
3538 STRCAT ": " ; ": " | |
3539 output_16_3 ; print as xxx | |
3540 PUTC " " ; print a dummy char to have string termination at the correct place | |
3541 movff buffer+.7,buffer+.8 ; move decimal digit one position to the right | |
3542 movlw "." ; load coding of a decimal point | |
3543 movff WREG,buffer+.7 ; place it before decimal digit | |
3544 STRCAT_PRINT "" ; dump buffer to screen | |
3545 bra TFT_warn_att_info_exit ; and return... | |
3546 | |
3547 ENDIF | |
560 | 3548 |
3549 | |
3550 global TFT_info_deco | |
604 | 3551 TFT_info_deco ; show info when decompression obligation is decreasing |
3552 rcall TFT_warning_set_window ; sets the row and column for the current message | |
3553 tstfsz WREG ; is there room for the message? | |
3554 return ; NO - return | |
3555 call TFT_advice_color ; actually it is a memo, but we break the rules here and display in advice color (green) | |
3556 STRCPY_TEXT tDecoInfo ; write "Deco Zone" | |
3557 movlw dm_warning_length ; select divemode string length | |
3558 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3559 STRCAT_PRINT "" ; print buffer | |
3560 bra TFT_warn_att_info_exit ; and return... | |
3561 | |
3562 | |
3563 IFDEF _cave_mode | |
3564 | |
3565 global TFT_info_cave_mode | |
3566 TFT_info_cave_mode: | |
3567 rcall TFT_warning_set_window ; sets the row and column for the current warning | |
3568 tstfsz WREG ; is there room for the message? | |
582 | 3569 return ; NO - return |
604 | 3570 call TFT_memo_color ; YES - set memo color |
3571 STRCPY_TEXT tCaveMode ; write "Cave Mode" | |
3572 movlw dm_warning_length ; select divemode string length | |
3573 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3574 STRCAT_PRINT "" ; print buffer |
604 | 3575 bra TFT_warn_att_info_exit ; and return... |
3576 | |
3577 global TFT_info_dive_turned | |
3578 TFT_info_dive_turned: | |
3579 rcall TFT_warning_set_window ; sets the row and column for the current warning | |
3580 tstfsz WREG ; is there room for the message? | |
3581 return ; NO - return | |
3582 call TFT_attention_color ; YES - set attention color | |
3583 STRCPY_TEXT tDiveTurned ; write "Dv.turned" | |
3584 movlw dm_warning_length ; select divemode string length | |
3585 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3586 STRCAT_PRINT "" ; print buffer | |
3587 bra TFT_warn_att_info_exit ; and return... | |
3588 | |
3589 global TFT_warn_cave_shutdown | |
3590 TFT_warn_cave_shutdown: | |
3591 rcall TFT_warning_set_window ; sets the row and column for the current warning | |
3592 tstfsz WREG ; is there room for the message? | |
3593 return ; NO - return | |
3594 call TFT_warnings_color ; YES - set warning color | |
3595 STRCPY_TEXT tCaveModeShutdown ; write "X-Cave-X" | |
3596 movlw dm_warning_length ; select divemode string length | |
3597 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3598 STRCAT_PRINT "" ; print buffer | |
3599 bra TFT_warn_att_info_exit ; and return... | |
3600 | |
3601 ENDIF | |
582 | 3602 |
3603 | |
3604 global TFT_warning_gf | |
3605 TFT_warning_gf: ; GF | |
604 | 3606 rcall TFT_warning_set_window ; set the row and column for the current message |
3607 tstfsz WREG ; is there room for the message? | |
3608 return ; NO | |
560 | 3609 movff int_O_gradient_factor+0,lo ; bank-safe copy gradient factor |
3610 movff int_O_gradient_factor+1,hi ; | |
604 | 3611 call TFT_color_code_gf ; color-code output |
582 | 3612 STRCPY "GF: " ; the two spaces are on purpose to align the output with other warnings' outputs |
3613 bsf leftbind | |
560 | 3614 output_8 ; print value of lo only, int_O_gradient_factor is limited to 255 |
582 | 3615 PUTC "%" |
604 | 3616 movlw dm_warning_length ; divemode string length |
3617 btfss divemode ; in divemode? | |
3618 movlw surf_warning_length ; NO - use surface string length | |
3619 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3620 STRCAT_PRINT "" |
3621 bcf leftbind | |
3622 bcf win_invert | |
604 | 3623 TFT_warn_att_info_exit: |
582 | 3624 goto TFT_standard_color ; and return... |
560 | 3625 |
3626 | |
3627 global TFT_warning_mbubbles | |
3628 TFT_warning_mbubbles: | |
3629 rcall TFT_warning_set_window ; sets the row and column for the current warning | |
604 | 3630 tstfsz WREG ; is there room for the message? |
582 | 3631 return ; NO |
560 | 3632 call TFT_attention_color ; set attention color as default |
3633 movff char_O_deco_warnings,WREG ; bank-safe copy for deco warnings | |
3634 btfsc WREG,mbubble_warning ; are we in the microbubbles zone right now? | |
3635 call TFT_warnings_color ; YES - reconfigure to warning color | |
3636 STRCPY_TEXT tMicroBubbles | |
582 | 3637 movlw dm_warning_length ; divemode string length |
604 | 3638 btfss divemode ; in divemode? |
582 | 3639 movlw surf_warning_length ; NO - use surface string length |
604 | 3640 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) |
582 | 3641 STRCAT_PRINT "" |
604 | 3642 bra TFT_warn_att_info_exit ; and return... |
560 | 3643 |
3644 | |
3645 global TFT_warning_outside | |
3646 TFT_warning_outside: | |
3647 rcall TFT_warning_set_window ; sets the row and column for the current warning | |
604 | 3648 tstfsz WREG ; is there room for the message? |
582 | 3649 return ; NO |
560 | 3650 call TFT_attention_color |
3651 movff char_O_deco_warnings,WREG ; bank-safe copy for deco warnings | |
3652 btfsc WREG,outside_warning ; are we outside the ZH-L16 model right now? | |
3653 call TFT_warnings_color ; YES - reconfigure to warning color | |
582 | 3654 STRCPY "X-ZHL16-X" |
3655 movlw dm_warning_length ; divemode string length | |
604 | 3656 btfss divemode ; in divemode? |
582 | 3657 movlw surf_warning_length ; NO - use surface string length |
604 | 3658 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) |
582 | 3659 STRCAT_PRINT "" |
604 | 3660 bra TFT_warn_att_info_exit ; and return... |
560 | 3661 |
3662 | |
3663 global TFT_warning_gas_needs_warn | |
3664 global TFT_warning_gas_needs_att | |
3665 TFT_warning_gas_needs_warn: | |
3666 rcall TFT_warning_gas_needs_war_helper | |
604 | 3667 rcall TFT_warning_set_window ; set the row and column for the current message |
3668 tstfsz WREG ; is there room for the message? | |
3669 return ; NO | |
560 | 3670 call TFT_warnings_color |
3671 bra TFT_warning_gas_needs_com | |
3672 TFT_warning_gas_needs_att: | |
3673 rcall TFT_warning_gas_needs_att_helper | |
604 | 3674 rcall TFT_warning_set_window ; set the row and column for the current message |
3675 tstfsz WREG ; is there room for the message? | |
3676 return ; NO | |
560 | 3677 call TFT_attention_color |
3678 TFT_warning_gas_needs_com: | |
3679 STRCPY_TEXT tGasNeedsWarn ; "Gas Needs" | |
604 | 3680 movlw dm_warning_length ; divemode string length |
3681 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3682 STRCAT_PRINT "" |
604 | 3683 bra TFT_warn_att_info_exit ; and return... |
560 | 3684 |
3685 TFT_warning_gas_needs_war_helper: | |
604 | 3686 incf message_counter,F ; increase counter |
560 | 3687 btfsc gas_needs_warning ; is it a new warning? |
3688 return ; NO - do not show the gas needs custom view again | |
604 | 3689 bsf gas_needs_warning ; YES - memorize it's an old now |
560 | 3690 bra TFT_warning_gas_needs_helper_com |
3691 TFT_warning_gas_needs_att_helper: | |
604 | 3692 incf message_counter,F ; increase counter |
560 | 3693 btfsc gas_needs_attention ; is it a new attention? |
3694 return ; NO - do not show the gas needs custom view again | |
604 | 3695 bsf gas_needs_attention ; YES - memorize it's an old now |
560 | 3696 TFT_warning_gas_needs_helper_com: |
604 | 3697 btfsc alternative_divelayout ; in alternative layout? |
3698 call switch_layout_to_normal ; YES - switch to normal layout | |
3699 movlw index_gas_needs_ascent-1 ; custom view number one below gas needs view | |
3700 movwf menupos3 ; set custom view number | |
3701 bsf toggle_customview ; initiate toggle to desired custom view -> gas needs view will be shown | |
582 | 3702 return |
560 | 3703 |
3704 | |
3705 global TFT_warning_IBCD | |
3706 TFT_warning_IBCD: | |
604 | 3707 rcall TFT_warning_set_window ; set the row and column for the current message |
3708 tstfsz WREG ; is there room for the message? | |
3709 return ; NO | |
560 | 3710 call TFT_attention_color ; select attention color as default |
3711 STRCPY_TEXT tIBCD ; "IBCD N2He" | |
604 | 3712 movlw dm_warning_length ; divemode string length |
3713 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3714 STRCAT_PRINT "" |
604 | 3715 bra TFT_warn_att_info_exit ; and return... |
3716 | |
3717 | |
3718 global TFT_warning_no_BO_gas | |
3719 TFT_warning_no_BO_gas: | |
3720 rcall TFT_warning_set_window ; set the row and column for the current message | |
3721 tstfsz WREG ; is there room for the message? | |
3722 return ; NO | |
3723 call TFT_attention_color ; select attention color as default | |
3724 STRCPY_TEXT tnoBOgas ; "B/O Gas X" | |
3725 movlw dm_warning_length ; divemode string length | |
3726 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3727 STRCAT_PRINT "" | |
3728 bra TFT_warn_att_info_exit ; and return... | |
3729 | |
3730 | |
3731 global TFT_advice_gas_change | |
3732 TFT_advice_gas_change: | |
3733 rcall TFT_warning_set_window ; set the row and column for the current message | |
3734 tstfsz WREG ; is there room for the message? | |
3735 return ; NO | |
3736 call TFT_advice_color ; set advice color | |
3737 STRCPY_TEXT tgaschange ; "Change?" | |
3738 movlw dm_warning_length ; divemode string length | |
3739 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
3740 STRCAT_PRINT "" | |
3741 bra TFT_warn_att_info_exit ; and return... | |
582 | 3742 |
3743 | |
3744 global TFT_warning_sensor_disagree | |
604 | 3745 TFT_warning_sensor_disagree: ; show sensor disagree warning |
560 | 3746 rcall TFT_warning_sensor_dis_helper |
604 | 3747 rcall TFT_warning_set_window ; set the row and column for the current message |
3748 tstfsz WREG ; is there room for the message? | |
3749 return ; NO | |
582 | 3750 call TFT_warnings_color |
3751 STRCPY_TEXT tSensorDisagree ; "Sensors<>" | |
604 | 3752 movlw dm_warning_length ; divemode string length |
3753 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3754 STRCAT_PRINT "" |
604 | 3755 bra TFT_warn_att_info_exit ; and return... |
560 | 3756 |
3757 TFT_warning_sensor_dis_helper: | |
3758 btfsc sensor_warning ; is it a new warning? | |
3759 return ; NO - do not show the gas needs custom view again | |
604 | 3760 bsf sensor_warning ; YES - memorize it's an old warning now |
3761 btfsc alternative_divelayout ; in alternative layout? | |
3762 call switch_layout_to_normal ; YES - switch to normal layout | |
3763 movlw index_ppo2_sensors-1 ; custom view number one below ppO2 sensors | |
3764 movwf menupos3 ; set custom view number | |
3765 bsf toggle_customview ; initiate toggle to desired custom view -> ppO2 sensors | |
560 | 3766 return |
582 | 3767 |
560 | 3768 ;============================================================================= |
582 | 3769 |
604 | 3770 TFT_warning_set_window: ; set the row and column for the current message |
582 | 3771 ; ignore warning (now)? |
604 | 3772 decf message_counter,W ; -1 |
582 | 3773 bcf STATUS,C |
604 | 3774 btfss alternative_divelayout ; in alternative layout, do not divide... |
3775 rrcf WREG,W ; (message_counter-1)/2 | |
3776 cpfseq message_page | |
582 | 3777 retlw .255 ; WREG <> 0 -> Warning window not defined |
3778 btfss divemode ; in divemode? | |
604 | 3779 bra TFT_warning_set_window3 ; NO - setup for surface mode |
582 | 3780 btfss alternative_divelayout |
3781 bra TFT_warning_set_window3a ; standard layout | |
3782 bra TFT_warning_set_window2a ; alternative layout (Only lower row used) | |
604 | 3783 TFT_warning_set_window3a: |
3784 btfss message_counter,0 ; toggle with each warning | |
582 | 3785 bra TFT_warning_set_window2 |
3786 WIN_SMALL dm_warning1_column, dm_warning1_row | |
3787 bcf second_row_warning ; =1: The second row contains a warning | |
3788 retlw .0 ; WREG=0 -> Warning window defined | |
0 | 3789 TFT_warning_set_window2: |
582 | 3790 bsf second_row_warning ; =1: The second row contains a warning |
3791 TFT_warning_set_window2a: | |
3792 WIN_SMALL dm_warning2_column, dm_warning2_row | |
3793 retlw .0 ; WREG=0 -> Warning window defined | |
0 | 3794 TFT_warning_set_window3: |
604 | 3795 btfss message_counter,0 ; toggle with each warning |
582 | 3796 bra TFT_warning_set_window4 |
3797 WIN_SMALL surf_warning1_column,surf_warning1_row | |
3798 bcf second_row_warning ; =1: The second row contains a warning | |
3799 retlw .0 ; WREG=0 -> Warning window defined | |
0 | 3800 TFT_warning_set_window4: |
582 | 3801 WIN_SMALL surf_warning2_column,surf_warning2_row |
3802 bsf second_row_warning ; =1: The second row contains a warning | |
3803 retlw .0 ; WREG=0 -> Warning window defined | |
560 | 3804 |
309
efb53af0d62a
VSIbar #1: layout position changes
janos_kovacs <kovjanos@gmail.com>
parents:
307
diff
changeset
|
3805 |
0 | 3806 global TFT_update_batt_percent_divemode |
3807 TFT_update_batt_percent_divemode: | |
604 | 3808 rcall TFT_warning_set_window ; set the row and column for the current message |
3809 tstfsz WREG ; is there room for the message? | |
3810 return ; NO | |
3811 movff batt_percent,lo ; get battery percent | |
3812 call TFT_color_code_battery ; color-code battery percent | |
582 | 3813 STRCPY "Batt:" |
0 | 3814 bsf leftbind |
3815 output_8 | |
3816 bcf leftbind | |
582 | 3817 PUTC "%" |
604 | 3818 movlw dm_warning_length ; divemode string length |
3819 btfss divemode ; in divemode? | |
3820 movlw surf_warning_length ; NO - use surface string length | |
3821 rcall TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
582 | 3822 STRCAT_PRINT "" |
3823 bcf win_invert | |
604 | 3824 bra TFT_custview_exit1 ; and return... |
3825 | |
3826 | |
3827 global TFT_gf_factors_mask ; mask for GF factors | |
3828 TFT_gf_factors_mask: | |
582 | 3829 call TFT_divemask_color |
608 | 3830 WIN_TINY dm_custom_gf_column1,dm_custom_gf_title_row |
582 | 3831 STRCPY_TEXT_PRINT tGFactors |
608 | 3832 WIN_TINY dm_custom_gf_column3,dm_custom_gf_title_row |
582 | 3833 STRCPY_TEXT_PRINT taGFactors |
608 | 3834 ; Show GF (static) |
3835 call TFT_disabled_color ; default to disabled color | |
3836 btfss use_agf ; shall use alternative GF factors? | |
3837 call TFT_memo_color ; NO - switch to memo color | |
604 | 3838 WIN_STD dm_custom_gf_column1, dm_custom_gf_row |
582 | 3839 bsf leftbind |
608 | 3840 movff opt_GF_low,lo ; get normal GF low |
3841 output_8 ; print normal GF low | |
3842 PUTC "/" ; print "/" | |
3843 movff opt_GF_high,lo ; get normal GF high | |
3844 output_8 ; print normal GF high | |
3845 STRCAT_PRINT "" ; finish output | |
3846 ; Show aGF (static) | |
3847 call TFT_memo_color ; default to memo color | |
3848 TSTOSS opt_enable_aGF ; are alternative GF factors enabled? | |
3849 bra TFT_gf_factors_mask_3 ; NO - show "---" and return | |
3850 ; YES - show aGF and which one is active | |
604 | 3851 WIN_STD dm_custom_gf_column2, dm_custom_gf_row |
608 | 3852 btfss use_agf ; shall use aGF? |
3853 bra TFT_gf_factors_mask_1 ; NO - print "<- " | |
3854 STRCPY_PRINT " ->" ; YES - print " ->" | |
3855 bra TFT_gf_factors_mask_2 ; - continue with common part | |
3856 TFT_gf_factors_mask_1: | |
3857 STRCPY_PRINT "<- " ; (NO) - print "<- " | |
3858 TFT_gf_factors_mask_2: ; common part | |
3859 btfss use_agf ; shall use aGF? | |
3860 call TFT_disabled_color ; NO - switch to disabled color | |
3861 WIN_STD dm_custom_gf_column3, dm_custom_gf_row | |
3862 movff opt_aGF_low,lo ; get aGF low | |
3863 output_8 ; print | |
3864 PUTC "/" ; print "/" | |
3865 movff opt_aGF_high,lo ; get aGF high | |
3866 output_8 ; print | |
3867 STRCAT_PRINT "" ; finish output | |
3868 bra TFT_custview_exit1 ; done | |
3869 TFT_gf_factors_mask_3: | |
3870 WIN_STD dm_custom_gf_column3+.10, dm_custom_gf_row | |
582 | 3871 STRCPY_PRINT "---" |
608 | 3872 bra TFT_custview_exit1 ; done |
604 | 3873 |
3874 | |
3875 global TFT_ceiling_GF_tissue_mask ; mask for ceiling, current GF and tissues | |
3876 TFT_ceiling_GF_tissue_mask: | |
3877 call TFT_divemask_color | |
3878 WIN_TINY dm_custom_ceiling_column+.2,dm_custom_ceiling_title_row | |
3879 STRCPY_TEXT_PRINT tCeiling | |
3880 WIN_TINY dm_custom_tissue_title_column, dm_custom_tissue_title_row | |
3881 STRCPY_TEXT_PRINT tDiveTissues | |
3882 ; collides with ceiling output and not really needed, too | |
3883 ; WIN_TINY dm_custom_tissue_N2_column, dm_custom_tissue_N2_row | |
3884 ; STRCPY_TEXT_PRINT tN2 | |
3885 ; WIN_TINY dm_custom_tissue_He_column, dm_custom_tissue_He_row | |
3886 ; STRCPY_TEXT_PRINT tHe | |
608 | 3887 WIN_TINY dm_custom_gf_column1+.5, dm_custom_gf_title_row |
604 | 3888 STRCPY_TEXT_PRINT tGFInfo |
3889 bra TFT_custview_exit1 ; and return... | |
3890 | |
3891 | |
3892 global TFT_ceiling_GF_tissue ; data for ceiling, current GF and tissues | |
3893 TFT_ceiling_GF_tissue: | |
3894 WIN_MEDIUM dm_custom_ceiling_column,dm_custom_ceiling_row | |
3895 movff int_O_ceiling+0,lo | |
3896 movff int_O_ceiling+1,hi | |
3897 call TFT_color_code_ceiling ; color-code the output | |
3898 call adjust_depth_with_salinity ; computes salinity setting into lo:hi [mbar] | |
3899 bsf leftbind | |
3900 TSTOSS opt_units ; 0=m, 1=ft | |
3901 bra TFT_ceiling_tissue_cGF_m | |
3902 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet | |
3903 output_16 ; yxz | |
3904 bra TFT_ceiling_tissue_cGF0 | |
3905 TFT_ceiling_tissue_cGF_m: | |
3906 bsf ignore_digit5 ; no cm (flag will be cleared by output_16) | |
3907 output_16dp .3 ; yxz.a | |
3908 TFT_ceiling_tissue_cGF0: | |
582 | 3909 bcf leftbind |
604 | 3910 STRCAT_PRINT " " |
3911 ; Show tissue diagram | |
3912 call DISP_tissue_saturation_graph; show char_O_tissue_N2_saturation and char_O_tissue_He_saturation | |
608 | 3913 ; Show current tissue supersaturation |
604 | 3914 WIN_MEDIUM dm_custom_clock_column+.3, dm_custom_gf_row |
3915 movff int_O_gradient_factor+0,lo ; gradient factor absolute, 100% = on M-line of straight Buhlmann | |
3916 movff int_O_gradient_factor+1,hi ; hi byte holds flags | |
3917 call TFT_color_code_gf ; color-code output | |
3918 output_8 ; need to print lo only, int_O_gradient_factor value is limited to 255 | |
3919 STRCAT_PRINT "" | |
3920 WIN_STD dm_custom_clock_column+.40, dm_custom_gf_row+.5 | |
3921 STRCAT_PRINT "%" ; % is printed in color set by TFT_color_code_gf, too | |
3922 TFT_custview_exit1: | |
3923 bcf leftbind | |
3924 goto TFT_standard_color ; and return... | |
3925 | |
3926 | |
3927 global TFT_clock_batt_surfpress_mask ; mask for clock, battery and surface pressure | |
3928 TFT_clock_batt_surfpress_mask: | |
582 | 3929 call TFT_divemask_color |
3930 WIN_TINY dm_custom_clock_column, dm_custom_clock_title_row | |
604 | 3931 STRCPY_TEXT_PRINT tTime ; "Time" |
3932 WIN_TINY dm_custom_battery_column, dm_custom_battery_title_row | |
3933 STRCPY_TEXT_PRINT tBattery ; "Battery" | |
3934 WIN_TINY dm_custom_surfpres_column+.8, dm_custom_surfpres_title_row | |
3935 STRCPY_TEXT_PRINT tSurface ; "Surface" | |
3936 ; Show Surface Pressure (done in mask, because it's static during the dive) | |
3937 call TFT_standard_color | |
3938 WIN_SMALL dm_custom_surfpres_column, dm_custom_surfpres_row | |
3939 movff last_surfpressure_30min+0,lo | |
3940 movff last_surfpressure_30min+1,hi | |
3941 output_16 | |
3942 PUTC ' ' | |
3943 STRCAT_TEXT_PRINT tMBAR ; mbar (hPa) | |
3944 bra TFT_custview_exit1 ; and return... | |
3945 | |
3946 | |
3947 global TFT_clock_batt_surfpress ; data for clock, battery and surface pressure | |
3948 TFT_clock_batt_surfpress: | |
3949 ; Update Clock | |
582 | 3950 WIN_SMALL dm_custom_clock_column, dm_custom_clock_row |
604 | 3951 call TFT_standard_color |
3952 movff hours,lo | |
3953 output_99 | |
3954 PUTC ':' | |
3955 movff mins,lo | |
3956 output_99x | |
3957 PUTC ":" | |
3958 movff secs,lo | |
3959 output_99x | |
3960 STRCAT_PRINT "" | |
3961 ; Show Battery Info | |
3962 WIN_SMALL dm_custom_battery_column, dm_custom_battery_percent_row | |
3963 movff batt_percent,lo ; get battery percent | |
3964 call TFT_color_code_battery ; color-code battery percent | |
3965 ; bsf leftbind | |
582 | 3966 output_8 |
604 | 3967 ; bcf leftbind |
582 | 3968 STRCAT "% " |
3969 movlw 0x00 | |
604 | 3970 movff WREG,buffer+4 ; only "xxx%" |
582 | 3971 STRCAT_PRINT "" |
3972 bcf win_invert | |
604 | 3973 call TFT_memo_color |
3974 WIN_SMALL dm_custom_battery_column, dm_custom_battery_volt_row | |
582 | 3975 movff batt_voltage+0,lo |
3976 movff batt_voltage+1,hi | |
3977 bsf leftbind | |
3978 output_16dp .2 | |
3979 PUTC 'V' | |
3980 movff buffer+5,buffer+4 | |
3981 movlw 0x00 | |
604 | 3982 movff WREG,buffer+5 ; only "x.yzV" |
582 | 3983 STRCAT_PRINT "" |
604 | 3984 ; Surface pressure is shown in mask because it is static |
3985 bra TFT_custview_exit1 ; and return... | |
3986 | |
3987 | |
3988 global TFT_pscr_info_mask ; mask for pSCR info | |
3989 TFT_pscr_info_mask: | |
582 | 3990 rcall TFT_mask_ppo2 |
3991 call TFT_divemask_color | |
604 | 3992 WIN_TINY dm_custom_pscr_drop_column, dm_custom_pscr_title_row |
582 | 3993 STRCPY_TEXT_PRINT tPSCR_O2_drop |
604 | 3994 WIN_TINY dm_custom_pscr_ratio_column, dm_custom_pscr_title_row |
582 | 3995 STRCPY_TEXT_PRINT tPSCR_lungratio |
604 | 3996 bra TFT_custview_exit1 ; and return... |
3997 | |
3998 global TFT_pscr_info ; data for pSCR info | |
482
c0ee33f1f399
New customview #12 for PSCR mode shows ppO2, O2 drop and lung ratio
heinrichsweikamp
parents:
480
diff
changeset
|
3999 TFT_pscr_info: |
582 | 4000 ;show ppO2 |
604 | 4001 WIN_MEDIUM dm_custom_ppo2_column,dm_custom_ppo2_row |
4002 movff int_O_pSCR_ppO2+0,lo ; copy pSCR ppO2 to hi:lo | |
560 | 4003 movff int_O_pSCR_ppO2+1,hi |
604 | 4004 call TFT_color_code_ppo2 ; color-code output |
560 | 4005 bsf leftbind |
604 | 4006 output_16dp .3 ; x.xx bar |
582 | 4007 bcf leftbind |
4008 STRCAT_PRINT "" | |
604 | 4009 ; Show drop |
4010 WIN_STD dm_custom_pscr_drop_column+.11,dm_custom_pscr_row | |
4011 call TFT_memo_color | |
560 | 4012 movff char_I_PSCR_drop,lo |
582 | 4013 bsf leftbind |
4014 output_8 | |
4015 STRCAT_PRINT "%" | |
4016 ; Show lung ratio | |
604 | 4017 WIN_STD dm_custom_pscr_ratio_column+.5,dm_custom_pscr_row |
582 | 4018 movff char_I_PSCR_lungratio,lo |
4019 bsf leftbind | |
4020 STRCPY "1/" | |
4021 output_8 | |
4022 STRCAT_PRINT "" | |
604 | 4023 bra TFT_custview_exit1 ; and return... |
4024 | |
4025 | |
4026 global TFT_gas_needs_ascent_mask ; mask for gas needs ascent | |
4027 TFT_gas_needs_ascent_mask: | |
4028 WIN_TINY dm_custom_gas_column_title, dm_custom_gas_mask_row | |
582 | 4029 call TFT_divemask_color |
604 | 4030 IFDEF _cave_mode |
4031 movff char_O_deco_info,WREG ; get the deco info vector | |
4032 btfss WREG,gas_needs_cave ; are the gas needs calculated for cave mode? | |
4033 bra TFT_gas_needs_mask_ascent_1 ; NO - show as direct ascent needs | |
4034 bsf gas_needs_mode_last ; YES - remember last results were for cave mode | |
4035 STRCPY_TEXT tGasNeedsCaveMode ; - "Gas Needs Cave Mode" | |
4036 bra TFT_gas_needs_mask_ascent_2 | |
4037 TFT_gas_needs_mask_ascent_1: | |
4038 bcf gas_needs_mode_last ; remember last results were for direct ascent | |
4039 STRCPY_TEXT tGasNeedsAscent ; "Gas Needs Ascent" | |
4040 TFT_gas_needs_mask_ascent_2: | |
4041 ELSE | |
4042 STRCPY_TEXT tGasNeedsAscent ; "Gas Needs Ascent" | |
4043 ENDIF | |
4044 STRCAT_PRINT " (bar)" ; " (bar)" | |
4045 bra TFT_custview_exit1 ; and return... | |
4046 | |
4047 | |
4048 global TFT_gas_needs_ascent ; data for gas needs ascent | |
4049 TFT_gas_needs_ascent: ; LIMITATION: there is only space for 4 gases on the screen - if 5 gases have a pres_need > 0, then only the first 4 will be shown! | |
4050 IFDEF _cave_mode | |
4051 movff char_O_deco_info,WREG ; get deco info vector | |
4052 btfss WREG,gas_needs_cave ; are the gas needs calculated for cave mode? | |
4053 bra TFT_gas_needs_ascent_1 ; NO - continue below... | |
4054 btfsc gas_needs_mode_last ; YES - were the last results calculated for cave mode? | |
4055 bra TFT_gas_needs_ascent_3 ; YES - mask still valid | |
4056 bra TFT_gas_needs_ascent_2 ; NO - redraw mask | |
4057 TFT_gas_needs_ascent_1: | |
4058 btfss gas_needs_mode_last ; NO - were the last results calculated for direct ascent? | |
4059 bra TFT_gas_needs_ascent_3 ; YES - mask still valid | |
4060 ;bra TFT_gas_needs_ascent_2 ; NO - redraw mask | |
4061 TFT_gas_needs_ascent_2: | |
4062 rcall TFT_gas_needs_ascent_mask ; redraw mask | |
4063 TFT_gas_needs_ascent_3: | |
4064 ENDIF | |
4065 clrf up ; initialize gas index (0-4) | |
4066 WIN_SMALL dm_custom_gas_column1+.5,dm_custom_gas_row1 | |
4067 rcall TFT_gas_needs_helper | |
4068 WIN_SMALL dm_custom_gas_column1+.5,dm_custom_gas_row2 | |
4069 rcall TFT_gas_needs_helper | |
4070 WIN_SMALL dm_custom_gas_column2+.5,dm_custom_gas_row1 | |
4071 rcall TFT_gas_needs_helper | |
4072 WIN_SMALL dm_custom_gas_column2+.5,dm_custom_gas_row2 | |
4073 rcall TFT_gas_needs_helper | |
560 | 4074 return |
4075 | |
4076 TFT_gas_needs_helper: | |
604 | 4077 call TFT_memo_color |
560 | 4078 movlw .5 ; number of gases |
4079 cpfslt up ; check if all gases have been processed | |
604 | 4080 bra TFT_gas_needs_helper_1 ; YES - clear display area |
4081 movf up,W ; NO - get gas number and check if need of that gas is > 0 | |
4082 rlncf WREG,W ; multiply by 2 | |
4083 incf WREG,W ; add 1 to address high byte | |
4084 lfsr FSR1,int_O_ascent_pres_need ; load base of ascent press needs | |
4085 movff PLUSW1,hi ; read HIGH(int_O_ascent_pres_need[up]) | |
560 | 4086 btfss hi,int_is_zero ; check flag for pres_need == 0 |
604 | 4087 bra TFT_gas_needs_helper_2 ; NO - print gas type and pressure needed |
4088 incf up,F ; YES - increment to next gas... | |
560 | 4089 bra TFT_gas_needs_helper ; ...and try the next gas |
4090 TFT_gas_needs_helper_1: ; no gases to show anymore, clear display area from potential remains of last invocation | |
582 | 4091 STRCAT_PRINT " ---- " ; overwrite outdated stuff if screen position is not needed |
560 | 4092 return |
4093 TFT_gas_needs_helper_2: ; output gas type and pressure needed | |
582 | 4094 movf up,W ; get gas number (0-4) to WREG |
4095 lfsr FSR1,opt_gas_O2_ratio ; read opt_gas_O2_ratio[WREG] | |
4096 movff PLUSW1,lo ; copy result to lo | |
4097 lfsr FSR1,opt_gas_He_ratio ; read opt_gas_He_ratio[WREG] | |
4098 movff PLUSW1,hi ; copy result to hi | |
4099 call customview_show_mix ; print "Air", "O2", "21/35", etc. | |
604 | 4100 PUTC ':' ; ":" |
582 | 4101 movf up,W ; get gas number (0-4) to WREG |
604 | 4102 rlncf WREG,W ; multiply by 2 |
4103 lfsr FSR1,int_O_ascent_pres_need ; load base of ascent press needs (default) | |
4104 movff PLUSW1,lo ; read LOW(int_O_ascent_pres_need[up]) | |
4105 incf WREG,W ; add 1 to address high byte | |
4106 movff PLUSW1,hi ; read HIGH(int_O_ascent_pres_need[up]) | |
582 | 4107 btfsc hi,int_attention_flag ; check if attention flag is set (pres_need > pres_fill * threshold) |
604 | 4108 call TFT_attention_color ; YES - print gas need in yellow |
4109 btfsc hi,int_warning_flag ; check if warning flag is set (pres_need > pres_fill) | |
4110 call TFT_warnings_color ; YES - print gas need in red | |
4111 movff int_O_ascent_pres_need+1,WREG ; get HIGH(int_O_ascent_pres_need[0]) which holds flag for invalid data | |
560 | 4112 btfsc WREG,int_invalid_flag ; check if invalid data flag is set |
604 | 4113 call TFT_disabled_color ; YES - print gas need in disabled color |
582 | 4114 bcf hi,int_attention_flag ; clear attention flag for attention color |
604 | 4115 bcf hi,int_warning_flag ; clear warning flag for warning color |
4116 bcf hi,int_invalid_flag ; clear flag for invalid data (will actually only be set with 1st gas) | |
582 | 4117 output_16_3 ; limit to 999 and display only (0-999) |
560 | 4118 STRCAT_PRINT " " ; adds a space to overwrite any potential remains of earlier outputs |
4119 incf up,F ; increment to next gas | |
604 | 4120 bra TFT_custview_exit2 ; and return... |
582 | 4121 |
4122 | |
4123 global TFT_mask_ppo2 ; helper function for several custom views | |
560 | 4124 TFT_mask_ppo2: |
582 | 4125 call TFT_divemask_color |
4126 btfss FLAG_ccr_mode ; in CCR mode? | |
4127 bra TFT_mask_ppo2a ; NO - continue checking for pSCR and OC | |
604 | 4128 btfsc FLAG_bailout_mode ; in bailout? |
582 | 4129 bra TFT_mask_ppo2b ; YES |
604 | 4130 WIN_TINY dm_custom_ppo2_column-.2,dm_custom_ppo2_title_row ; tuned position for longer text (-8 = on leftmost edge of display) |
582 | 4131 STRCPY_TEXT_PRINT tppO2Dil ; print "ppO2(Dil)" |
604 | 4132 bra TFT_custview_exit2 ; and return... |
560 | 4133 TFT_mask_ppo2a: |
582 | 4134 btfss FLAG_pscr_mode ; in pSCR mode? |
4135 bra TFT_mask_ppo2b ; NO - continue with OC mode (or bailout) | |
604 | 4136 btfsc FLAG_bailout_mode ; in bailout? |
582 | 4137 bra TFT_mask_ppo2b ; YES |
604 | 4138 WIN_TINY dm_custom_ppo2_column-.2,dm_custom_ppo2_title_row ; tuned position for longer text (-8 = on leftmost edge of display) |
582 | 4139 STRCPY_TEXT_PRINT tppO2Mix ; print "ppO2(Mix)" |
604 | 4140 bra TFT_custview_exit2 ; and return... |
560 | 4141 TFT_mask_ppo2b: ; OC mode or bailout |
604 | 4142 WIN_TINY dm_custom_ppo2_column-.2, dm_custom_ppo2_title_row ; normal position |
582 | 4143 STRCPY_TEXT_PRINT tppO2 ; in all other modes |
604 | 4144 bra TFT_custview_exit2 ; and return... |
582 | 4145 |
4146 | |
604 | 4147 global TFT_ppo2_ead_end_cns_mask ; mask for ppO2, END/EAD and CNS |
560 | 4148 TFT_ppo2_ead_end_cns_mask: |
582 | 4149 rcall TFT_mask_ppo2 |
4150 call TFT_divemask_color | |
4151 WIN_TINY dm_custom_ead_column, dm_custom_eadend_title_row | |
4152 STRCPY_TEXT_PRINT tDiveEAD_END | |
604 | 4153 WIN_TINY dm_custom_cns_column, dm_custom_cns_title_row |
582 | 4154 STRCPY_TEXT_PRINT tCNS2 |
604 | 4155 bra TFT_custview_exit2 ; and return... |
4156 | |
4157 | |
4158 global TFT_ppo2_ead_end_cns ; data for ppO2, END/EAD and CNS | |
471
9edb1359ce43
NEW: New Customview 11 in dive mode shows ppO2, EAD/END and CNS
heinrichsweikamp
parents:
466
diff
changeset
|
4159 TFT_ppo2_ead_end_cns: |
608 | 4160 ; Show ppO2 |
4161 WIN_MEDIUM dm_custom_ppo2_column, dm_custom_ppo2_row | |
4162 movff int_O_breathed_ppO2+0,lo ; copy ppO2 of the currently breathed gas to hi:lo | |
4163 movff int_O_breathed_ppO2+1,hi | |
4164 call TFT_color_code_ppo2 ; color-code output | |
4165 bsf leftbind | |
4166 output_16dp .3 ; x.xx bar | |
4167 bcf leftbind | |
4168 STRCAT_PRINT "" | |
4169 call TFT_standard_color | |
582 | 4170 ; Show END/EAD |
4171 WIN_SMALL dm_custom_ead_column, dm_custom_ead_row | |
4172 STRCPY_TEXT tEAD ; EAD: | |
4173 movff char_O_EAD,lo | |
4174 rcall TFT_end_ead_common ; print "lo m" (or ft) and limit to 8 chars | |
4175 WIN_SMALL dm_custom_end_column, dm_custom_end_row | |
4176 STRCPY_TEXT tEND ; END: | |
4177 movff char_O_END,lo | |
4178 rcall TFT_end_ead_common ; print "lo m" (or ft) and limit to 8 chars | |
4179 ; Show CNS | |
604 | 4180 WIN_STD dm_custom_cns_column+.3, dm_custom_cns_row |
582 | 4181 movff int_O_CNS_fraction+0,lo |
4182 movff int_O_CNS_fraction+1,hi | |
604 | 4183 call TFT_color_code_cns ; color-code CNS output |
582 | 4184 bsf leftbind |
604 | 4185 output_16_3 ; displays only 0...999 |
582 | 4186 bcf leftbind |
4187 STRCAT_PRINT "%" | |
604 | 4188 TFT_custview_exit2: |
582 | 4189 goto TFT_standard_color ; and return... |
4190 TFT_end_ead_common: ; print "lo m" (or ft) and limit to 8 chars | |
4191 bsf leftbind | |
4192 TSTOSS opt_units ; 0=Meters, 1=Feets | |
0 | 4193 bra TFT_end_ead_common_metric |
604 | 4194 TFT_end_ead_common_imperial: |
4195 movf lo,W ; with lo in m | |
582 | 4196 mullw .100 ; PRODL:PRODH = mbar/min |
0 | 4197 movff PRODL,lo |
4198 movff PRODH,hi | |
604 | 4199 call convert_mbar_to_feet ; convert value in hi:lo from mbar to feet |
582 | 4200 output_16_3 |
4201 STRCAT_TEXT tFeets | |
4202 clrf WREG | |
4203 movff WREG,buffer+.8 ; limit string length to 8 | |
604 | 4204 bra TFT_end_ead_common_exit |
0 | 4205 TFT_end_ead_common_metric: |
582 | 4206 output_8 |
4207 STRCAT_TEXT tMeters | |
0 | 4208 TFT_end_ead_common_exit: |
582 | 4209 bcf leftbind |
4210 movlw .8 | |
604 | 4211 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) |
582 | 4212 STRCAT_PRINT "" |
4213 return | |
4214 | |
4215 | |
604 | 4216 global TFT_sensor_check_mask ; mask for sensor check |
413
12e85930d95c
NEW: New Customview shows ppO2(O2) and ppO2(Diluent) during CCR mode
heinrichsweikamp
parents:
412
diff
changeset
|
4217 TFT_sensor_check_mask: |
582 | 4218 call TFT_divemask_color |
604 | 4219 WIN_TINY dm_custom_s_check_title_column, dm_custom_s_check_title_row |
582 | 4220 STRCPY_TEXT_PRINT tSensorCheck |
604 | 4221 WIN_TINY dm_custom_ppO2_column, dm_custom_s_check_title_row |
582 | 4222 STRCPY_TEXT_PRINT tppO2O2 |
604 | 4223 WIN_TINY dm_custom_ppDil_column, dm_custom_s_check_title_row |
582 | 4224 STRCPY_TEXT_PRINT tppO2Dil |
604 | 4225 bra TFT_sensor_check_exit ; and return... |
4226 | |
4227 | |
4228 global TFT_sensor_check ; data for sensor check | |
413
12e85930d95c
NEW: New Customview shows ppO2(O2) and ppO2(Diluent) during CCR mode
heinrichsweikamp
parents:
412
diff
changeset
|
4229 TFT_sensor_check: |
582 | 4230 ; Show ppO2 of O2 in this depth |
604 | 4231 WIN_MEDIUM dm_custom_ppO2_column, dm_custom_s_check_row |
560 | 4232 movff int_O_O2_ppO2+0,lo ; copy ppO2 of pure O2 to hi:lo |
4233 movff int_O_O2_ppO2+1,hi | |
582 | 4234 call TFT_color_code_ppo2 ; color-code output |
560 | 4235 bsf leftbind |
582 | 4236 output_16dp .3 ; x.xx bar |
4237 bcf leftbind | |
4238 STRCAT_PRINT "" | |
4239 ; Show ppO2 of the diluent in this depth | |
604 | 4240 WIN_MEDIUM dm_custom_ppDil_column, dm_custom_s_check_row |
560 | 4241 movff int_O_pure_ppO2+0,lo ; copy ppO2 of pure gas to hi:lo |
4242 movff int_O_pure_ppO2+1,hi | |
582 | 4243 call TFT_color_code_ppo2 ; color-code output |
560 | 4244 bsf leftbind |
582 | 4245 output_16dp .3 ; x.xx bar |
4246 bcf leftbind | |
4247 STRCAT_PRINT "" | |
604 | 4248 TFT_sensor_check_exit: |
4249 bra TFT_custview_exit2 ; and return... | |
560 | 4250 |
4251 ;============================================================================= | |
413
12e85930d95c
NEW: New Customview shows ppO2(O2) and ppO2(Diluent) during CCR mode
heinrichsweikamp
parents:
412
diff
changeset
|
4252 |
582 | 4253 global TFT_surface_lastdive |
503
4542d03f748a
NEW: Last Dive customviews in surface mode with divetime, depth and interval
heinrichsweikamp
parents:
490
diff
changeset
|
4254 TFT_surface_lastdive: |
608 | 4255 call TFT_divemask_color |
582 | 4256 WIN_TINY surf_gaslist_column,surf_gaslist_row+.5 |
604 | 4257 STRCAT_TEXT_PRINT tLastDive ; "Last Dive:" |
582 | 4258 WIN_TINY surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.1)+.5 |
604 | 4259 STRCAT_TEXT_PRINT tDivetime ; "Divetime:" |
582 | 4260 WIN_TINY surf_gaslist_column,surf_gaslist_row+(surf_gaslist_spacing*.2)+.5 |
604 | 4261 STRCAT_TEXT_PRINT tMaxDepth ; "Max. Depth" |
608 | 4262 call TFT_standard_color |
582 | 4263 WIN_SMALL surf_gaslist_column+.48,surf_gaslist_row |
560 | 4264 movff int_O_desaturation_time+0,lo ; bank-safe copies |
4265 movff int_O_desaturation_time+1,WREG | |
4266 iorwf lo,W ; check if desaturation time is zero | |
582 | 4267 bz TFT_surface_lastdive_1 ; YES - show last dive time |
560 | 4268 movff surface_interval+0,lo ; NO - show dive interval |
4269 movff surface_interval+1,hi | |
604 | 4270 call convert_time ; converts hi:lo in minutes to hours (up:hi) and minutes (lo) |
560 | 4271 movf hi,W |
4272 movff lo,hi | |
582 | 4273 movwf lo ; exchange lo and hi |
4274 bsf leftbind | |
560 | 4275 output_99x |
582 | 4276 PUTC 'h' |
560 | 4277 movff hi,lo |
4278 output_99x | |
4279 STRCAT_PRINT "m " | |
4280 bra TFT_surface_lastdive_2 | |
4281 TFT_surface_lastdive_1: | |
582 | 4282 movff lastdive_time+0,xC+0 |
4283 movff lastdive_time+1,xC+1 | |
4284 movff lastdive_time+2,xC+2 | |
4285 movff lastdive_time+3,xC+3 | |
4286 movlw LOW .3600 | |
4287 movwf xB+0 | |
4288 movlw HIGH .3600 | |
604 | 4289 movwf xB+1 ; one day = 3600s |
582 | 4290 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder |
604 | 4291 ;xC+0:xC+1 -> full hours |
582 | 4292 movff xC+1,xA+1 |
4293 movff xC+0,xA+0 | |
4294 clrf xB+1 | |
4295 movlw .24 | |
4296 movwf xB+0 | |
604 | 4297 call div16x16 ; xC = xA / xB with xA as remainder |
582 | 4298 movff xC+0,lo |
604 | 4299 movff xC+1,hi ; full days |
582 | 4300 bsf leftbind |
4301 output_16 | |
4302 PUTC "d" | |
604 | 4303 movff xA+0,lo ; full hours |
582 | 4304 output_8 |
560 | 4305 STRCAT_PRINT "h " |
4306 TFT_surface_lastdive_2: | |
582 | 4307 WIN_SMALL surf_gaslist_column+.48,surf_gaslist_row+(surf_gaslist_spacing*.1) |
4308 movff lastdive_duration+0,lo | |
4309 movff lastdive_duration+1,hi | |
4310 output_16 ; divetime minutes | |
4311 PUTC ":" | |
4312 movff lastdive_duration+2,lo | |
4313 output_99x ; divetime seconds | |
4314 STRCAT_PRINT "" | |
4315 WIN_SMALL surf_gaslist_column+.48,surf_gaslist_row+(surf_gaslist_spacing*.2) | |
4316 movff lastdive_maxdepth+0,lo | |
4317 movff lastdive_maxdepth+1,hi | |
4318 TSTOSS opt_units ; 0=Meters, 1=Feets | |
4319 bra TFT_surface_lastdive_metric | |
503
4542d03f748a
NEW: Last Dive customviews in surface mode with divetime, depth and interval
heinrichsweikamp
parents:
490
diff
changeset
|
4320 ;imperial |
604 | 4321 rcall convert_mbar_to_feet ; convert value in hi:lo from mbar to feet |
582 | 4322 output_16_3 ; limit to 999 and display only (0-999) |
4323 STRCAT_TEXT tFeets1 | |
4324 bra TFT_surface_lastdive2 | |
503
4542d03f748a
NEW: Last Dive customviews in surface mode with divetime, depth and interval
heinrichsweikamp
parents:
490
diff
changeset
|
4325 |
4542d03f748a
NEW: Last Dive customviews in surface mode with divetime, depth and interval
heinrichsweikamp
parents:
490
diff
changeset
|
4326 TFT_surface_lastdive_metric: |
604 | 4327 bsf ignore_digit5 ; no cm (flag will be cleared by output_16) |
582 | 4328 movlw d'1' ; +1 |
4329 movff WREG,ignore_digits ; no 1000m | |
4330 output_16dp .3 ; xxx.y | |
4331 STRCAT_TEXT tMeters | |
503
4542d03f748a
NEW: Last Dive customviews in surface mode with divetime, depth and interval
heinrichsweikamp
parents:
490
diff
changeset
|
4332 TFT_surface_lastdive2: |
582 | 4333 STRCAT_PRINT "" |
4334 bcf leftbind | |
604 | 4335 return ; done. |
560 | 4336 |
4337 ;============================================================================= | |
582 | 4338 |
4339 global TFT_surface_tissues | |
604 | 4340 TFT_surface_tissues: ; show Tissue diagram in surface mode |
582 | 4341 WIN_SMALL surf_tissue_N2_column,surf_tissue_N2_row |
4342 STRCPY_TEXT_PRINT tN2 | |
4343 WIN_SMALL surf_tissue_He_column,surf_tissue_He_row | |
4344 STRCPY_TEXT_PRINT tHe | |
4345 | |
4346 movlw color_deepblue | |
604 | 4347 call TFT_set_color ; make this configurable? |
582 | 4348 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.29,.29 |
4349 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.37,.37 | |
4350 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.45,.45 | |
4351 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.53,.53 | |
4352 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.61,.61 | |
4353 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.69,.69 | |
4354 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.77,.77 | |
4355 WIN_FRAME_COLOR16 surf_tissue_diagram_top+.23,surf_tissue_diagram_bottom-.4,.85,.85 | |
4356 WIN_FRAME_STD surf_tissue_diagram_top, surf_tissue_diagram_bottom, surf_tissue_diagram_left, surf_tissue_diagram_right ; outer frame | |
0 | 4357 |
4358 movlw .1 | |
604 | 4359 movwf win_height ; row bottom (0-239) |
582 | 4360 |
4361 ;---- Draw N2 Tissues ---------------------------------------------------- | |
4362 | |
4363 movlw surf_tissue_diagram_left+.4 ; start position for N2 bars | |
604 | 4364 movwf win_leftx2 ; column left (0-159) |
4365 movlw surf_tissue_diagram_right-surf_tissue_diagram_left-.4 ; max width for N2 bars | |
4366 movwf win_width | |
0 | 4367 |
4368 lfsr FSR2, char_O_tissue_N2_saturation | |
4369 movlw d'16' | |
582 | 4370 movwf lo ; 16 tissues |
4371 clrf hi ; row offset | |
0 | 4372 surf_tissue_saturation_graph_N2: |
582 | 4373 movlw surf_tissue_diagram_top+.23 ; surface mode |
4374 addwf hi,W | |
604 | 4375 movwf win_top ; row top (0-239) |
582 | 4376 rcall surf_tissue_saturation_loop ; show one tissue |
4377 decfsz lo,F | |
0 | 4378 bra surf_tissue_saturation_graph_N2 |
4379 | |
582 | 4380 ;---- Draw He Tissues ---------------------------------------------------- |
4381 | |
604 | 4382 movlw surf_tissue_diagram_left+.24 ; start position for He bars (.15 without x2) |
4383 movwf win_leftx2 ; column left (0-159) | |
4384 movlw surf_tissue_diagram_right-surf_tissue_diagram_left-.24 ; max width for He bars | |
4385 movwf win_width | |
582 | 4386 |
0 | 4387 lfsr FSR2, char_O_tissue_He_saturation |
4388 movlw d'16' | |
582 | 4389 movwf lo ; 16 tissues |
604 | 4390 clrf hi ; row offset |
0 | 4391 surf_tissue_saturation_graph_He: |
582 | 4392 movlw surf_tissue_diagram_top+.23+.57 ; surface mode |
4393 addwf hi,W | |
604 | 4394 movwf win_top ; row top (0-239) |
582 | 4395 rcall surf_tissue_saturation_loop ; show one tissue |
4396 decfsz lo,F | |
0 | 4397 bra surf_tissue_saturation_graph_He |
582 | 4398 |
4399 WIN_SMALL surf_tissue_He_column+.22,surf_tissue_He_row ; position in-between tissue bars | |
560 | 4400 movff int_O_CNS_fraction+0,lo |
4401 movff int_O_CNS_fraction+1,hi | |
582 | 4402 call TFT_color_code_cns |
4403 STRCPY_TEXT tCNS2 ; CNS: | |
560 | 4404 bsf leftbind |
604 | 4405 output_16_3 ; displays only 0...999 |
560 | 4406 bcf leftbind |
4407 STRCAT_PRINT "%" | |
582 | 4408 goto TFT_standard_color ; and return... |
0 | 4409 |
4410 surf_tissue_saturation_loop: | |
582 | 4411 call TFT_standard_color |
4412 movlw .2 ; row spacing | |
4413 addwf hi,F | |
4414 movf POSTINC2,W ; get tissue load | |
560 | 4415 bcf WREG,7 ; clear flag bit for sat/desat info (not used in surface mode) |
4416 rlncf WREG,W ; multiply with 2 (previously cleared bit 7 will be rotated to bit 0) | |
4417 incf WREG,W ; add 1 for a minimum visible bar (He-bars could be invisible else-wise) | |
582 | 4418 movwf up |
604 | 4419 movf win_width+0,W ; get max window width (win_width) |
582 | 4420 cpfslt up ; skip if WREG < win_width |
4421 movwf up ; crop length to win_width | |
560 | 4422 ; no need to be able to draw longer bars – |
4423 ; we are at the surface and if bars would | |
4424 ; even touch the max length possible here, | |
4425 ; the diver would be in severe decompression | |
4426 ; issues if not dead already... | |
582 | 4427 movff up,win_bargraph |
4428 clrf win_width+1 | |
4429 goto TFT_box ; and return... | |
0 | 4430 |
4431 ;============================================================================= | |
604 | 4432 ; Draw saturation graph in dive mode |
560 | 4433 |
0 | 4434 DISP_tissue_saturation_graph: |
582 | 4435 ;---- Draw Frame |
4436 call TFT_standard_color | |
604 | 4437 WIN_FRAME_COLOR16 dm_custom_tissue_diagram_top, dm_custom_tissue_diagram_bottom, dm_custom_tissue_diagram_left, .159 ; outer frame |
4438 | |
4439 ;---- clear area showing leading tissue number as it may not be printed over | |
4440 WIN_BOX_BLACK dm_custom_tissue_diagram_top+.16, dm_custom_tissue_diagram_top+.16+.10, dm_custom_tissue_diagram_left+.32, dm_custom_tissue_diagram_left+.32+.8 ; top, bottom, left, right | |
0 | 4441 |
4442 movlw .1 | |
604 | 4443 movwf win_height ; row bottom (0-239) |
582 | 4444 |
4445 ;---- Draw N2 Tissues ---------------------------------------------------- | |
4446 | |
604 | 4447 movlw dm_custom_tissue_diagram_left+.3 ; divemode |
4448 movwf win_leftx2 ; column left (0-159) | |
4449 movlw .159-dm_custom_tissue_diagram_left-.4 ; width | |
4450 movwf win_width | |
0 | 4451 |
4452 lfsr FSR2, char_O_tissue_N2_saturation | |
4453 movlw d'16' | |
582 | 4454 movwf lo ; 16 tissues |
4455 clrf hi ; row offset | |
0 | 4456 tissue_saturation_graph_N2: |
582 | 4457 movlw dm_custom_tissue_diagram_top+.3 ; divemode |
4458 rcall tissue_saturation_graph_loop ; show one tissue | |
4459 decfsz lo,F | |
0 | 4460 bra tissue_saturation_graph_N2 |
4461 | |
582 | 4462 ;---- Draw He Tissues ---------------------------------------------------- |
4463 | |
604 | 4464 movlw dm_custom_tissue_diagram_left+.8 ; divemode |
4465 movwf win_leftx2 ; column left (0-159) | |
4466 movlw .159-dm_custom_tissue_diagram_left-.14 ; width | |
4467 movwf win_width | |
582 | 4468 |
0 | 4469 lfsr FSR2, char_O_tissue_He_saturation |
4470 movlw d'16' | |
582 | 4471 movwf lo ; 16 tissues |
4472 clrf hi ; row offset | |
0 | 4473 tissue_saturation_graph_He: |
582 | 4474 movlw dm_custom_tissue_diagram_top+.3+.22 ; divemode |
4475 rcall tissue_saturation_graph_loop ; show one tissue | |
4476 decfsz lo,F | |
0 | 4477 bra tissue_saturation_graph_He |
604 | 4478 |
4479 ;---- Print Number of leading Tissue ------------------------------------- | |
4480 | |
4481 ; TODO: some flicker due to overwriting by tissue bars | |
4482 | |
4483 movff int_O_gradient_factor+0,WREG ; get current gradient factor (only low byte used for value) | |
4484 tstfsz WREG ; current gradient factor = 0 ? | |
4485 bra tissue_saturation_graph_0 ; NO - print number of leading tissue | |
4486 movff char_O_deco_info,WREG ; YES - get deco info vector | |
4487 btfss WREG,deco_ceiling ; - do we have a ceiling obligation? | |
4488 goto TFT_standard_color ; NO - can ascent directly, don't print number, set standard color and return | |
4489 ; YES - print number of leading tissue | |
4490 tissue_saturation_graph_0: | |
4491 movff char_O_lead_number,lo ; get number of leading tissue as 0-15 | |
4492 incf lo,F ; adjust to 1-16 | |
4493 movlw .10 | |
4494 cpfsgt lo ; is it > 10 ? | |
4495 bra tissue_saturation_graph_1 ; NO - will output a single digit number | |
4496 ; start position for a 2 digit number | |
4497 WIN_TINY dm_custom_tissue_diagram_left+.32,dm_custom_tissue_diagram_top+.16 | |
4498 bra tissue_saturation_graph_2 | |
4499 tissue_saturation_graph_1: | |
4500 ; start position for a 1 digit number | |
4501 WIN_TINY dm_custom_tissue_diagram_left+.32+.4,dm_custom_tissue_diagram_top+.16 | |
4502 tissue_saturation_graph_2: | |
4503 call TFT_standard_color ; set output color | |
4504 bsf leftbind | |
4505 output_8 ; print number in leftbind, i.e. without leading zeros or spaces | |
4506 bcf leftbind | |
4507 STRCAT_PRINT "" ; finalize output | |
4508 return | |
0 | 4509 |
4510 tissue_saturation_graph_loop: | |
582 | 4511 addwf hi,W |
604 | 4512 movwf win_top ; row top (0-239) |
582 | 4513 movlw color_cyan ; preset color for tissues with decreasing pressure |
4514 call TFT_set_color | |
4515 incf hi,F | |
0 | 4516 movf POSTINC2,W |
604 | 4517 btfss WREG,7 ; check if flag for increasing tissue pressure set |
560 | 4518 bra tissue_saturation_graph_loop_1 ; NO - keep color |
582 | 4519 movwf up ; YES - buffer WREG |
4520 movlw color_orange ; select color for tissues with increasing pressure | |
4521 call TFT_set_color ; change color | |
4522 movf up,W ; restore WREG | |
560 | 4523 tissue_saturation_graph_loop_1: |
4524 bcf WREG,7 ; clear flag bit | |
582 | 4525 bcf STATUS,C |
4526 rrcf WREG ; divide by 2 | |
560 | 4527 incf WREG,W ; add a bit for a minimum visible bar |
582 | 4528 movwf up |
4529 movf win_width,W ; get max window width (win_width) | |
4530 cpfslt up ; skip if WREG < win_width | |
4531 movwf up | |
4532 movff up,win_bargraph | |
4533 clrf win_width+1 | |
4534 goto TFT_box ; and return... | |
560 | 4535 |
4536 ;============================================================================= | |
55 | 4537 |
0 | 4538 global TFT_display_cns |
4539 TFT_display_cns: | |
604 | 4540 call TFT_warning_set_window ; set the row and column for the current message |
4541 tstfsz WREG ; is there room for the message? | |
4542 return ; NO | |
582 | 4543 STRCPY_TEXT tCNS ; CNS: |
4544 movff int_O_CNS_fraction+0,lo | |
4545 movff int_O_CNS_fraction+1,hi | |
604 | 4546 call TFT_color_code_cns ; color-code CNS output |
582 | 4547 bsf leftbind |
604 | 4548 output_16_3 ; displays only 0...999 |
582 | 4549 bcf leftbind |
4550 PUTC "%" | |
604 | 4551 movlw dm_warning_length ; divemode string length |
4552 btfss divemode ; In divemode? | |
4553 movlw surf_warning_length ; NO - use surface string length | |
4554 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
560 | 4555 STRCAT_PRINT "" |
4556 bcf win_invert | |
604 | 4557 bra TFT_custview_exit3 ; and return... |
560 | 4558 |
4559 | |
4560 global TFT_display_eod_cns | |
4561 TFT_display_eod_cns: | |
604 | 4562 call TFT_warning_set_window ; set the row and column for the current message |
4563 tstfsz WREG ; is there room for the message? | |
4564 return ; NO | |
560 | 4565 call TFT_warnings_color ; switch to warnings (red) text color |
4566 STRCPY_TEXT tCNSeod ; end-of-dive CNS warning text | |
604 | 4567 movlw dm_warning_length ; divemode string length |
4568 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
0 | 4569 STRCAT_PRINT "" |
604 | 4570 bra TFT_custview_exit3 ; and return... |
4571 | |
4572 | |
4573 global TFT_display_ppo2_warning | |
4574 TFT_display_ppo2_warning: ; with ppO2 including attention/warning flags in hi:lo | |
4575 call TFT_warning_set_window ; set the row and column for the current message | |
4576 tstfsz WREG ; is there room for the message? | |
4577 return ; NO | |
4578 call TFT_color_code_ppo2 ; color-code output | |
4579 btfsc FLAG_bailout_mode ; in bailout? | |
4580 bra TFT_display_diluent_2 ; YES | |
582 | 4581 btfss FLAG_ccr_mode ; in CCR mode? |
4582 bra TFT_display_diluent_1 ; NO - continue with pSCR or OC | |
604 | 4583 STRCPY_TEXT tdil ; YES - print "Dil:" |
582 | 4584 bra TFT_display_diluent_3 |
560 | 4585 TFT_display_diluent_1: |
582 | 4586 btfss FLAG_pscr_mode ; in pSCR mode? |
604 | 4587 bra TFT_display_diluent_2 ; NO - continue with OC |
4588 STRCPY_TEXT tmix ; YES - print "Mix:" | |
582 | 4589 bra TFT_display_diluent_3 |
560 | 4590 TFT_display_diluent_2: |
604 | 4591 STRCPY_TEXT tppO2 ; bailout or OC mode, print "ppO2:" |
560 | 4592 TFT_display_diluent_3: |
4593 bsf leftbind | |
582 | 4594 output_16dp .3 ; x.xx bar |
4595 bcf leftbind | |
604 | 4596 movlw dm_warning_length ; divemode string length |
4597 call TFT_fillup_with_spaces ; fill up FSR2 with spaces (total string length in #WREG) | |
560 | 4598 STRCAT_PRINT "" |
604 | 4599 TFT_custview_exit3: |
560 | 4600 goto TFT_standard_color ; and return... |
582 | 4601 |
604 | 4602 |
4603 global TFT_surf_set_bearing | |
4604 TFT_surf_set_bearing: | |
4605 btfsc premenu | |
4606 return ; already shown, return | |
4607 bsf premenu ; set flag | |
4608 WIN_BOX_BLACK surf_compass_bear_row,surf_warning1_row-1, surf_compass_bear_column, surf_decotype_column-.1 ; top, bottom, left, right | |
4609 WIN_SMALL surf_compass_bear_column,surf_compass_bear_row | |
4610 WIN_COLOR color_yellow | |
4611 bsf win_invert | |
4612 STRCPY_TEXT_PRINT tSetHeading ; 7 chars | |
4613 bcf win_invert | |
4614 return | |
4615 | |
560 | 4616 ;============================================================================= |
582 | 4617 |
0 | 4618 global TFT_LogOffset_Logtitle |
4619 TFT_LogOffset_Logtitle: | |
4620 STRCPY_TEXT tLogOffset | |
4621 PUTC ":" | |
604 | 4622 call do_logoffset_common_read ; offset into lo:hi |
0 | 4623 bsf leftbind |
535
cf68fe0c3002
NEW: Show a warning for each sensor if the sensor is end-of-life after calibration (Less then 8mV in Air at sea level)
heinrichsweikamp
parents:
533
diff
changeset
|
4624 output_16_4 |
0 | 4625 bcf leftbind |
4626 PUTC " " | |
604 | 4627 return ; no "_PRINT" here... |
582 | 4628 |
560 | 4629 ;============================================================================= |
604 | 4630 ; RX Functions |
4631 | |
4632 IFDEF _rx_functions | |
4633 | |
4634 global TFT_pressures_SAC_mask ; mask for pressures and SAC | |
4635 TFT_pressures_SAC_mask: | |
4636 call TFT_divemask_color | |
4637 ; pressure reading 1 | |
4638 WIN_TINY dm_custom_tankdata_pres1_col, dm_custom_tankdata_mask_row | |
4639 movff char_I_pressure_gas+0,WREG ; =0: disabled, =1..10: gases/dils | |
4640 bcf aux_flag ; selector for disabled / need set to disabled | |
4641 call TFT_pressures_SAC_mask_helper ; print gas composition or " ---" if disabled | |
4642 ; pressure reading 2 | |
4643 WIN_TINY dm_custom_tankdata_pres2_col, dm_custom_tankdata_mask_row | |
4644 movff char_I_pressure_gas+1,WREG ; =0: need to reading 1, =1..10: gases/dils | |
4645 bsf aux_flag ; selector for disabled / need set to need | |
4646 call TFT_pressures_SAC_mask_helper ; print gas composition or "Need " if 0 | |
4647 ; SAC rate | |
4648 WIN_TINY dm_custom_tankdata_SAC_col, dm_custom_tankdata_mask_row | |
4649 STRCPY_TEXT tSAC ; "SAC | |
4650 STRCAT " (" ; ( | |
4651 STRCAT_TEXT tLitersMinute ; l/min | |
4652 STRCAT_PRINT ")" ; )" | |
4653 bra TFT_custview_exit3 ; and return... | |
4654 | |
4655 TFT_pressures_SAC_mask_helper: | |
4656 tstfsz WREG ; pressure reading assigned? | |
4657 bra TFT_dive_tankdata_mask_helper_1 ; YES - print gas composition | |
4658 btfsc aux_flag ; NO - check auxiliary flag | |
4659 bra TFT_dive_tankdata_mask_helper_2 ; 1 - print "Need " | |
4660 STRCAT_PRINT " ---" ; 0 - print " ---" | |
4661 return ; - done | |
4662 TFT_dive_tankdata_mask_helper_1: | |
4663 decf WREG,W ; (1..10) -> (0..9) | |
4664 bsf short_gas_decriptions ; just "Air", "O2" or "xx/yy" | |
4665 call gaslist_strcat_gas_WREG ; print composition of gas/dil in WREG (0..9) | |
4666 bra TFT_dive_tankdata_mask_helper_3 ; finish with adding "(bar)" | |
4667 TFT_dive_tankdata_mask_helper_2: | |
4668 STRCPY_TEXT tNeed ; "Need" | |
4669 TFT_dive_tankdata_mask_helper_3: | |
4670 STRCAT_PRINT "(bar)" | |
4671 return | |
4672 | |
4673 | |
4674 global TFT_pressures_SAC ; data for pressures and SAC | |
4675 TFT_pressures_SAC: | |
4676 ; check mode for second reading | |
4677 bcf aux_flag ; clear auxiliary flag by default (reading 2 is pressure) | |
4678 movff char_I_pressure_gas+1,WREG ; =0: need to reading 1, =1..10: gases/dils | |
4679 addlw .0 ; dummy operation to set status register flags | |
4680 btfsc STATUS,Z ; gas selected = 0 (i.e. no 2nd pressure reading) ? | |
4681 bsf aux_flag ; YES - set auxiliary flag (display position of reading 2 shall show need to reading 1) | |
4682 ; get data of reading 1 | |
4683 movff int_IO_pressure_value+0,lo ; copy pressure 1 to hi:lo | |
4684 movff int_IO_pressure_value+1,hi | |
4685 movff char_I_pressure_stat+0,ex ; copy status data | |
4686 ; pressure of reading 1 | |
4687 WIN_STD dm_custom_tankdata_pres1_col+.4,dm_custom_tankdata_row | |
4688 rcall TFT_pressures_SAC_helper_1 ; print pressure if available, else " ---" | |
4689 ; battery status of reading 1 | |
4690 WIN_SMALL dm_custom_hud_sensor1_column+.4+.36,dm_custom_tankdata_row | |
4691 rcall TFT_pressures_SAC_helper_2 ; print or clear down arrow as low bat indicator | |
4692 ; get data for reading 2 | |
4693 btfsc aux_flag ; shall reading 2 show need to reading 1 ? | |
4694 bra TFT_pressures_SAC_1 ; YES | |
4695 movff int_IO_pressure_value+2,lo ; NO - copy pressure 2 to hi:lo | |
4696 movff int_IO_pressure_value+3,hi ; | |
4697 movff char_I_pressure_stat+1,ex ; - copy status data | |
4698 bra TFT_pressures_SAC_2 | |
4699 TFT_pressures_SAC_1: | |
4700 movff int_O_pressure_need+0,lo ; YES - copy need to pressure 1 to hi:lo | |
4701 movff int_O_pressure_need+1,hi ; | |
4702 clrf ex ; - set status data to 0 | |
4703 TFT_pressures_SAC_2: | |
4704 ; pressure of reading 2 | |
4705 WIN_STD dm_custom_tankdata_pres2_col+.2,dm_custom_tankdata_row | |
4706 rcall TFT_pressures_SAC_helper_1 ; print pressure if available, else " ---" | |
4707 ; battery status of reading 2 | |
4708 WIN_SMALL dm_custom_tankdata_pres2_col+.2+.36,dm_custom_tankdata_row | |
4709 rcall TFT_pressures_SAC_helper_2 ; print or clear down arrow as low bat indicator | |
4710 ; SAC | |
4711 WIN_STD dm_custom_tankdata_SAC_col+.6,dm_custom_tankdata_row | |
4712 movff int_O_sac_rate+0,lo ; copy SAC rate to hi:lo | |
4713 movff int_O_sac_rate+1,hi | |
4714 btfsc hi,int_not_avail_flag ; SAC rate available? | |
4715 bra TFT_pressures_SAC_4 ; NO - print " --.-" | |
4716 call TFT_color_code_tank_pres_sac ; color-code the output | |
4717 output_16_3 ; print as xxx | |
4718 PUTC " " ; print a dummy char to have the string termination at the correct place | |
4719 movff buffer+.2,buffer+.3 ; move the decimal digit one position to the right | |
4720 movlw "." ; load coding of a decimal point | |
4721 movff WREG,buffer+.2 ; place it before decimal digit | |
4722 movlw " " ; load coding of a space character | |
4723 movff buffer+.1,up ; get the character in front of the decimal point | |
4724 cpfseq up ; is it a space? | |
4725 bra TFT_pressures_SAC_3 ; NO - continue | |
4726 movlw "0" ; YES - load coding of a zero | |
4727 movff WREG,buffer+.1 ; - place a zero in front of the decimal point | |
4728 TFT_pressures_SAC_3: | |
4729 STRCAT_PRINT "" ; dump buffer to screen | |
4730 bra TFT_custview_exit3 ; and return... | |
4731 TFT_pressures_SAC_4: | |
4732 call TFT_disabled_color | |
4733 STRCAT_PRINT "--.-" ; output for no SAC data available | |
4734 bra TFT_custview_exit3 ; and return... | |
4735 | |
4736 TFT_pressures_SAC_helper_1: | |
4737 btfss hi,int_not_avail_flag ; pressure available? | |
4738 bra TFT_pressures_SAC_helper_1a ; YES - print pressure | |
4739 call TFT_disabled_color ; NO - use disabled color as default | |
4740 btfsc ex,char_transmitter_lost ; - transmitter lost? | |
4741 call TFT_attention_color ; YES - use attention color | |
4742 STRCAT_PRINT " ---" ; - print " ---" | |
4743 return | |
4744 TFT_pressures_SAC_helper_1a: | |
4745 btfsc hi,int_warning_flag ; out of range (signaled by warning flag)? | |
4746 bra TFT_pressures_SAC_helper_1c ; YES - special treatment | |
4747 call TFT_color_code_tank_pres_sac ; NO - color-code the output | |
4748 bsf ignore_digit5 ; - no 0.1 bar (flag will be cleared by output_16) | |
4749 movf lo,W ; | |
4750 iorwf hi,W ; - pressure value = 0 ? | |
4751 bnz TFT_pressures_SAC_helper_1b ; NO - print value | |
4752 STRCPY_PRINT " 0" ; YES - print a zero manually | |
4753 return ; - done | |
4754 TFT_pressures_SAC_helper_1b: | |
4755 output_16 ; print hi:lo | |
4756 STRCAT_PRINT "" ; dump buffer to screen | |
4757 return ; done | |
4758 TFT_pressures_SAC_helper_1c: | |
4759 call TFT_color_code_tank_pres_sac ; color-code the output (clears all flags) | |
4760 STRCPY_PRINT ">400" ; print ">400" | |
4761 return ; done | |
4762 | |
4763 TFT_pressures_SAC_helper_2: | |
4764 btfss ex,char_transmitter_low_bat ; low battery flag set? | |
4765 bra TFT_pressures_SAC_helper_2a ; NO - wipe out down arrow (low bat indicator) | |
4766 call TFT_attention_color ; YES - use attention color | |
4767 STRCPY_PRINT "\xb8" ; - print down arrow as bat low indication | |
4768 return | |
4769 TFT_pressures_SAC_helper_2a: | |
4770 STRCPY_PRINT " " ; wipe out down arrow (low bat indicator) | |
4771 return | |
4772 | |
4773 | |
4774 global TFT_menu_tank_pres | |
4775 TFT_menu_tank_pres: ; imprinting function for main menu / tank setup | |
4776 call TFT_standard_color | |
4777 ; get ID | |
4778 lfsr FSR1,opt_transmitter_id_1 ; load base address of opt_transmitter_id | |
4779 movf gaslist_gas,W ; get current gas | |
4780 rlncf WREG,W ; multiply by 2 because IDs are 2 byte in size | |
4781 movff PLUSW1,lo ; copy opt_transmitter_id+0[gaslist_gas] to lo | |
4782 incf WREG,W ; increment index | |
4783 movff PLUSW1,hi ; copy opt_transmitter_id+1[gaslist_gas] to hi | |
4784 ; show pressure | |
4785 WIN_SMALL .90, .61 ; column, row (+/- 27 per row) | |
4786 call get_pres_by_transmitter_id ; get pressure into hi:lo | |
4787 tstfsz WREG ; do we have valid tank data (WREG=0) ? | |
4788 bra TFT_menu_tank_pres_1 ; NO - transmitter not found | |
4789 call TFT_color_code_tank_pres_sac ; set output color according to flags | |
4790 bsf ignore_digit5 ; no 0.1 bar (flag will be cleared by output_16) | |
4791 output_16 | |
4792 bra TFT_menu_tank_pres_2 | |
4793 TFT_menu_tank_pres_1: | |
4794 call TFT_disabled_color | |
4795 STRCAT " ---" ; output for no pressure data available | |
4796 TFT_menu_tank_pres_2: | |
4797 STRCAT_TEXT_PRINT tbar ; " bar" | |
4798 bra TFT_custview_exit3 ; and return... | |
4799 | |
4800 | |
4801 global TFT_surface_tank_pres | |
4802 TFT_surface_tank_pres: ; show pressure reading above surface pressure | |
4803 WIN_SMALL surf_decotype_column+.6,surf_decotype_row+.30+.47 | |
4804 movff int_IO_pressure_value+0,lo ; copy pressure from 1st reading, low byte | |
4805 movff int_IO_pressure_value+1,hi ; copy pressure from 1st reading, high byte | |
4806 btfss hi,int_not_avail_flag ; pressure reading 1 available? | |
4807 bra TFT_surface_tank_pres_0 ; YES | |
4808 movff int_IO_pressure_value+2,lo ; NO - copy pressure from 2nd reading, low byte | |
4809 movff int_IO_pressure_value+3,hi ; - copy pressure from 2nd reading, high byte | |
4810 btfsc hi,int_not_avail_flag ; - pressure reading 2 available? | |
4811 bra TFT_surface_tank_pres_1 ; NO - show not avail message | |
4812 TFT_surface_tank_pres_0: ; YES - show pressure | |
4813 call TFT_color_code_tank_pres_sac ; set output color according to flags | |
4814 bsf ignore_digit5 ; no 0.1 bar (flag will be cleared by output_16) | |
4815 output_16 | |
4816 STRCAT_PRINT "" | |
4817 bra TFT_surface_tank_pres_2 | |
4818 TFT_surface_tank_pres_1: | |
4819 call TFT_disabled_color | |
4820 STRCAT_PRINT " ---" ; output for no pressure data available | |
4821 TFT_surface_tank_pres_2: | |
4822 WIN_SMALL surf_decotype_column+.38,surf_decotype_row+.30+.47 | |
4823 call TFT_divemask_color | |
4824 STRCAT_PRINT "bar" ; can not use tbar because it has a leading space | |
4825 bra TFT_custview_exit3 ; and return... | |
4826 | |
4827 | |
4828 global TFT_surface_tankdata | |
4829 TFT_surface_tankdata: | |
4830 lfsr FSR1,rx_buffer ; load base address of RX buffer | |
4831 ; bra TFT_surface_tankdata_debug ; comment in for +++ debug version +++ | |
4832 WIN_SMALL surf_customtext_column,surf_customtext_row1 | |
4833 rcall TFT_surface_tankdata_print | |
4834 WIN_SMALL surf_customtext_column,surf_customtext_row2 | |
4835 rcall TFT_surface_tankdata_print | |
4836 WIN_SMALL surf_customtext_column,surf_customtext_row3 | |
4837 rcall TFT_surface_tankdata_print | |
4838 WIN_SMALL surf_customtext_column,surf_customtext_row4 | |
4839 rcall TFT_surface_tankdata_print | |
4840 WIN_SMALL surf_customtext_column,surf_customtext_row5 | |
4841 rcall TFT_surface_tankdata_print | |
4842 return | |
4843 | |
4844 TFT_surface_tankdata_print: ; max 12 char | |
4845 call TFT_standard_color | |
4846 movff POSTINC1,hi ; ID high (+0) | |
4847 movff POSTINC1,lo ; ID low (+1) | |
4848 tstfsz hi ; ID high = 0 ? | |
4849 bra TFT_surface_tankdata_print_1 ; NO - slot in use | |
4850 tstfsz lo ; ID low = 0? | |
4851 bra TFT_surface_tankdata_print_1 ; NO - slot in use | |
4852 STRCAT_PRINT "---- " ; YES - mark as unused and clear rest of line from previous remains | |
4853 movf POSTINC1,W ; - dummy read (+2) to advance index | |
4854 movf POSTINC1,W ; - dummy read (+3) to advance index | |
4855 movf POSTINC1,W ; - dummy read (+4) to advance index | |
4856 bra TFT_surface_tankdata_print_3 | |
4857 TFT_surface_tankdata_print_1: | |
4858 movf hi,W ; copy ID high to WREG | |
4859 output_hex ; 2 chars | |
4860 movf lo,W ; copy ID low to WREG | |
4861 output_hex ; 2 chars (4 in total) | |
4862 movff POSTINC1,hi ; pressure high (+2) | |
4863 movff POSTINC1,lo ; pressure low (+3) | |
4864 call TFT_color_code_tank_pres_sac ; needed to clear the status flags before output | |
4865 bsf ignore_digit5 ; no 0.1 bar (flag will be cleared by output_16) | |
4866 output_16 ; 4 chars (8 in total) | |
4867 PUTC " " ; 1 char (9 in total) | |
4868 movf POSTINC1,W ; status (+4) | |
4869 andlw .7 ; mask out battery voltage | |
4870 bnz TFT_surface_tankdata_2 ; branch if battery is not completely drained | |
4871 call TFT_warnings_color ; output in red | |
4872 STRCAT_PRINT "XXX" ; "XXX" for low | |
4873 bra TFT_surface_tankdata_print_3 | |
4874 TFT_surface_tankdata_2: | |
4875 addlw .28 ; add offset of 2.8 Volt | |
4876 movff WREG,lo ; | |
4877 output_99 ; 2 chars (11 in total) | |
4878 PUTC " " ; dummy char 1 char (12 in total) | |
4879 movff buffer+.10,buffer+.11 ; move decimal digit of battery voltage one position to the right | |
4880 movlw "." ; decimal point | |
4881 movff WREG,buffer+.10 ; place it before decimal digit | |
4882 STRCAT_PRINT "" ; print buffer to screen | |
4883 TFT_surface_tankdata_print_3: | |
4884 movf POSTINC1,W ; dummy read (+5) to advance index | |
4885 return | |
4886 | |
4887 | |
4888 ; TFT_surface_tankdata_debug: ; surface custom view debug output | |
4889 ; call TFT_standard_color | |
4890 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*0 | |
4891 ; rcall TFT_surface_tankdata_debug_print | |
4892 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*1 | |
4893 ; rcall TFT_surface_tankdata_debug_print | |
4894 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*2 | |
4895 ; rcall TFT_surface_tankdata_debug_print | |
4896 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*3 | |
4897 ; rcall TFT_surface_tankdata_debug_print | |
4898 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*4 | |
4899 ; rcall TFT_surface_tankdata_debug_print | |
4900 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*5 | |
4901 ; rcall TFT_surface_tankdata_debug_print | |
4902 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*6 | |
4903 ; rcall TFT_surface_tankdata_debug_print | |
4904 ; WIN_TINY surf_customtext_column,surf_customtext_row1+.14*7 | |
4905 ; rcall TFT_surface_tankdata_debug_print | |
4906 ; return | |
4907 | |
4908 ; TFT_surface_tankdata_debug_print: | |
4909 ; movff POSTINC1,hi ; ID high (+0) | |
4910 ; movff POSTINC1,lo ; ID low (+1) | |
4911 ; output_16 | |
4912 ; PUTC "," | |
4913 ; movff POSTINC1,hi ; pressure high (+2) | |
4914 ; movff POSTINC1,lo ; pressure low (+3) | |
4915 ; call TFT_color_code_tank_pres_sac; needed to clear the status flags before output | |
4916 ; output_16 | |
4917 ; PUTC "," | |
4918 ; movff POSTINC1,lo ; status (+4) | |
4919 ; output_8 | |
4920 ; PUTC "," | |
4921 ; movff POSTINC1,lo ; date (+5) | |
4922 ; output_8 | |
4923 ; STRCAT_PRINT "" | |
4924 ; return | |
4925 | |
4926 ENDIF | |
4927 | |
4928 ;============================================================================= | |
582 | 4929 |
0 | 4930 global adjust_depth_with_salinity |
582 | 4931 global adjust_depth_with_salinity_log |
0 | 4932 adjust_depth_with_salinity: ; computes salinity setting into lo:hi [mbar] |
604 | 4933 btfsc simulatormode_active ; do not apply salinity in simulator mode |
0 | 4934 return |
582 | 4935 movff opt_salinity,WREG ; 0-5% |
560 | 4936 adjust_depth_with_salinity_log: ; computes salinity setting (FROM WREG!) into lo:hi [mbar] |
582 | 4937 addlw d'100' ; 1.00kg/l |
4938 movwf up | |
4939 | |
0 | 4940 movlw d'105' ; 105% ? |
604 | 4941 cpfslt up ; salinity upper limit |
4942 return ; out of limit, do not adjust lo:hi | |
0 | 4943 movlw d'99' ; 99% ? |
604 | 4944 cpfsgt up ; salinity lower limit |
4945 return ; out of limit, do not adjust lo:hi | |
0 | 4946 |
4947 movff lo,xA+0 | |
4948 movff hi,xA+1 | |
4949 | |
604 | 4950 movlw d'102' ; 0.98 bar / 10 meter |
0 | 4951 movwf xB+0 |
4952 clrf xB+1 | |
604 | 4953 call mult16x16 ; xC:4 = xA:2 * xB:2 |
4954 movff up,xB+0 ; salinity | |
0 | 4955 clrf xB+1 |
604 | 4956 call div32x16 ; xC:4 = xC:4 / xB:2 with xA as remainder |
0 | 4957 movff xC+0,lo |
604 | 4958 movff xC+1,hi ; copy corrected values back to lo and hi |
0 | 4959 return |
4960 | |
560 | 4961 ;============================================================================= |
582 | 4962 |
604 | 4963 global convert_mbar_to_feet |
4964 convert_mbar_to_feet: ; convert value in hi:lo from mbar to feet | |
0 | 4965 movff lo,xA+0 |
4966 movff hi,xA+1 | |
4967 | |
582 | 4968 movlw LOW d'328' ; 328feet/100m |
0 | 4969 movwf xB+0 |
582 | 4970 movlw HIGH d'328' |
0 | 4971 movwf xB+1 |
4972 | |
582 | 4973 call mult16x16 ; xA*xB=xC (lo:hi * 328) |
4974 | |
4975 movlw d'50' ; round up | |
0 | 4976 addwf xC+0,F |
4977 movlw 0 | |
4978 addwfc xC+1,F | |
4979 addwfc xC+2,F | |
4980 addwfc xC+3,F | |
4981 | |
582 | 4982 movlw LOW .10000 |
4983 movwf xB+0 | |
4984 movlw HIGH .10000 | |
4985 movwf xB+1 | |
4986 | |
4987 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder | |
0 | 4988 |
4989 movff xC+0,lo | |
582 | 4990 movff xC+1,hi ; restore lo and hi with updated value |
0 | 4991 return |
4992 | |
560 | 4993 ;============================================================================= |
4994 | |
604 | 4995 global convert_celsius_to_fahrenheit ; convert value in lo:hi from Celsius to Fahrenheit |
4996 convert_celsius_to_fahrenheit: ; convert value in lo:hi from Celsius to Fahrenheit | |
582 | 4997 movff lo,xA+0 ; temperature in 1/10 of °C |
4998 movff hi,xA+1 | |
4999 | |
5000 movlw LOW d'1000' ; offset °C value by 1000 to get out of any negative numbers | |
5001 addwf xA+0,F | |
5002 movlw HIGH d'1000' | |
5003 addwfc xA+1,F | |
5004 | |
5005 movlw d'18' ; adjust scaling: 1°C = 1.8°F | |
5006 movwf xB+0 | |
5007 clrf xB+1 | |
5008 | |
5009 call mult16x16 ; xA*xB=xC (lo:hi * 18) | |
5010 | |
5011 movlw d'10' | |
5012 movwf xB+0 | |
5013 clrf xB+1 | |
5014 | |
5015 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder | |
5016 | |
5017 movlw LOW d'1480' ; adjust offset: subtract above offset of 1000 * 1.8 = 1800 now and add 320 => subtract 1480 | |
5018 subwf xC+0,F | |
5019 movlw HIGH d'1480' | |
5020 subwfb xC+1,F | |
5021 | |
5022 movff xC+0,lo | |
5023 movff xC+1,hi ; restore lo and hi with updated value | |
5024 return | |
560 | 5025 |
480
ad8acade5567
NEW: PSCR mode (Passive semi-closed rebreather)
heinrichsweikamp
parents:
477
diff
changeset
|
5026 ;============================================================================= |
560 | 5027 |
0 | 5028 END |