annotate src/logbook.asm @ 455:85b533b7a18c

NEW: Store more battery info into logbook memory
author heinrichsweikamp
date Tue, 27 Sep 2016 16:40:14 +0200
parents 23b58c4bc6aa
children 8dfb93e80338
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
heinrichsweikamp
parents:
diff changeset
1 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
2 ;
heinrichsweikamp
parents:
diff changeset
3 ; File logbook.asm
heinrichsweikamp
parents:
diff changeset
4 ;
heinrichsweikamp
parents:
diff changeset
5 ; Logbook
heinrichsweikamp
parents:
diff changeset
6 ;
heinrichsweikamp
parents:
diff changeset
7 ; Copyright (c) 2011, JD Gascuel, HeinrichsWeikamp, all right reserved.
heinrichsweikamp
parents:
diff changeset
8 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
9 ; HISTORY
heinrichsweikamp
parents:
diff changeset
10 ; 2011-11-12 : [mH] moving from OSTC code
heinrichsweikamp
parents:
diff changeset
11
heinrichsweikamp
parents:
diff changeset
12 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
13 ; Temp data, local to this module, moved to ACCES0 area.
heinrichsweikamp
parents:
diff changeset
14 ;
heinrichsweikamp
parents:
diff changeset
15
275
653a3ab08062 rename into hwOS
heinrichsweikamp
parents: 255
diff changeset
16 #include "hwos.inc" ; Mandatory header
0
heinrichsweikamp
parents:
diff changeset
17 #include "tft.inc"
heinrichsweikamp
parents:
diff changeset
18 #include "external_flash.inc"
heinrichsweikamp
parents:
diff changeset
19 #include "math.inc"
heinrichsweikamp
parents:
diff changeset
20 #include "strings.inc"
heinrichsweikamp
parents:
diff changeset
21 #include "convert.inc"
heinrichsweikamp
parents:
diff changeset
22 #include "tft_outputs.inc"
heinrichsweikamp
parents:
diff changeset
23 #include "eeprom_rs232.inc"
heinrichsweikamp
parents:
diff changeset
24 #include "menu_processor.inc"
heinrichsweikamp
parents:
diff changeset
25 #include "wait.inc"
heinrichsweikamp
parents:
diff changeset
26 #include "start.inc"
heinrichsweikamp
parents:
diff changeset
27 #include "surfmode.inc"
heinrichsweikamp
parents:
diff changeset
28 #include "divemode.inc"
heinrichsweikamp
parents:
diff changeset
29 #include "ghostwriter.inc"
heinrichsweikamp
parents:
diff changeset
30
66
00636132cca6 BUGFIX: Maintain last selected customview in surface mode
heinrichsweikamp
parents: 50
diff changeset
31 extern do_main_menu2,comm_mode
0
heinrichsweikamp
parents:
diff changeset
32
418
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
33 CBLOCK tmp+0x36 ; Keep space for menu processor.
0
heinrichsweikamp
parents:
diff changeset
34 count_temperature ; Current sample count for temperature divisor
heinrichsweikamp
parents:
diff changeset
35 count_deco ; Current sample count for deco (ceiling) divisor
heinrichsweikamp
parents:
diff changeset
36 logbook_cur_depth:2 ; Current depth, for drawing profile.
heinrichsweikamp
parents:
diff changeset
37 logbook_cur_tp:2 ; Current temperature, for drawing profile.
heinrichsweikamp
parents:
diff changeset
38 logbook_last_tp ; Y of the last item in Tp° curve.
heinrichsweikamp
parents:
diff changeset
39 logbook_min_tp:2 ; Min temperature, for drawing profile.
heinrichsweikamp
parents:
diff changeset
40 logbook_max_tp:2 ; Maximum temperature, for drawing profile.
heinrichsweikamp
parents:
diff changeset
41 logbook_ceiling ; Current ceiling, for drawing profile.
418
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
42 logbook_flags ; Flags only used in logbook.asm
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
43 logbook_page_number ; Page# in logbook
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
44 logbook_divenumber ; # of dive in list during search
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
45 logbook_divenumber_temp ; # of dive in list during search
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
46 logbook_menupos_temp ; Last position of cursor
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
47 profile_temp:2 ; Temp for profile display
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
48 profile_temp2:2 ; Temp for profile display
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
49 logbook_max_dive_counter ; Counts dive# to zero
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
50 logbook_max_dive_counter_temp; Counts dive# to zero
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
51 logbook_sample_counter:2; Amount of read samples
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
52 divemins_backup ; Backup of divemins+0
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
53 y_scale:2 ; y-scale (The horizontal lines)
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
54 x_scale:2 ; x-scale (The vertical lines)
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
55 logbook_pixel_x_pos ; x2 position of current pixel in X-direction
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
56 logbook_min_temp_pos ; lowest row in the temp graph
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
57 logbook_max_temp_pos ; lowest row in the temp graph
418
a5fc007634c5 some cleanup
heinrichsweikamp
parents: 417
diff changeset
58 ;+.33, reserved to tmp+0x57
0
heinrichsweikamp
parents:
diff changeset
59 ENDC
heinrichsweikamp
parents:
diff changeset
60
heinrichsweikamp
parents:
diff changeset
61 #DEFINE return_from_profileview logbook_flags,0
heinrichsweikamp
parents:
diff changeset
62 #DEFINE all_dives_shown logbook_flags,1
heinrichsweikamp
parents:
diff changeset
63 #DEFINE logbook_page_not_empty logbook_flags,2
heinrichsweikamp
parents:
diff changeset
64 #DEFINE end_of_profile logbook_flags,3
169
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
65 #DEFINE keep_cursor_new_page logbook_flags,4
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
66 #DEFINE log_marker_found logbook_flags,5
0
heinrichsweikamp
parents:
diff changeset
67
heinrichsweikamp
parents:
diff changeset
68
heinrichsweikamp
parents:
diff changeset
69 ; Logbook Coordinates
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
70 #DEFINE logbook_list_left .10 ; Column of dive# in list
0
heinrichsweikamp
parents:
diff changeset
71 #DEFINE logbook_row_offset .28 ; Distance between rows of list
heinrichsweikamp
parents:
diff changeset
72 #DEFINE logbook_row_number .6 ; Amount of rows in the list
heinrichsweikamp
parents:
diff changeset
73
heinrichsweikamp
parents:
diff changeset
74 ; Profile display
heinrichsweikamp
parents:
diff changeset
75 #DEFINE profile_height_pixels .157 ; Amount of pixels height for profile display
heinrichsweikamp
parents:
diff changeset
76 #DEFINE profile_width_pixels .156 ; Amount of pixels width for profile display
heinrichsweikamp
parents:
diff changeset
77 #DEFINE profile_left .1 ; Left border
heinrichsweikamp
parents:
diff changeset
78 #DEFINE profile_top .65 ; Top border
heinrichsweikamp
parents:
diff changeset
79
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
80 ; "Bailout"
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
81 #DEFINE logbook_bailout_column .124
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
82 #DEFINE logbook_bailout_row .207
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
83
0
heinrichsweikamp
parents:
diff changeset
84 ; Dive number
heinrichsweikamp
parents:
diff changeset
85 #DEFINE logbook_divenumer_column .1
heinrichsweikamp
parents:
diff changeset
86 #DEFINE logbook_divenumer_row .1
heinrichsweikamp
parents:
diff changeset
87 ; Date and Time
heinrichsweikamp
parents:
diff changeset
88 #DEFINE logbook_date_column .100
heinrichsweikamp
parents:
diff changeset
89 #DEFINE logbook_date_row .7
heinrichsweikamp
parents:
diff changeset
90 #DEFINE logbook_time_column .120
389
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
91 #DEFINE logbook_time_row .38
0
heinrichsweikamp
parents:
diff changeset
92 ; Max. Depth
heinrichsweikamp
parents:
diff changeset
93 #DEFINE log_max_value_row .38
heinrichsweikamp
parents:
diff changeset
94 #DEFINE log_max_value_column .1
heinrichsweikamp
parents:
diff changeset
95 ; Divetime
heinrichsweikamp
parents:
diff changeset
96 #DEFINE log_divetime_value_row .38
heinrichsweikamp
parents:
diff changeset
97 #DEFINE log_divetime_value_column .65
heinrichsweikamp
parents:
diff changeset
98 ; Gaslist below profile
heinrichsweikamp
parents:
diff changeset
99 #DEFINE log_gas_row .225
heinrichsweikamp
parents:
diff changeset
100 #DEFINE log_gas_column1 .0
heinrichsweikamp
parents:
diff changeset
101 #DEFINE log_gas_column2 log_gas_column1+(.1*.32)
heinrichsweikamp
parents:
diff changeset
102 #DEFINE log_gas_column3 log_gas_column1+(.2*.32)
heinrichsweikamp
parents:
diff changeset
103 #DEFINE log_gas_column4 log_gas_column1+(.3*.32)
heinrichsweikamp
parents:
diff changeset
104 #DEFINE log_gas_column5 log_gas_column1+(.4*.32)
heinrichsweikamp
parents:
diff changeset
105
heinrichsweikamp
parents:
diff changeset
106 ; Logbook Page2
heinrichsweikamp
parents:
diff changeset
107 ; Gaslist
heinrichsweikamp
parents:
diff changeset
108 #DEFINE log2_title_row1 .20
heinrichsweikamp
parents:
diff changeset
109 #DEFINE log2_title_column .90
heinrichsweikamp
parents:
diff changeset
110 #DEFINE log2_gas_column log2_title_column
heinrichsweikamp
parents:
diff changeset
111 #DEFINE log2_gas_row1 .36
heinrichsweikamp
parents:
diff changeset
112 #DEFINE log2_gas_row2 1*.16+log2_gas_row1
heinrichsweikamp
parents:
diff changeset
113 #DEFINE log2_gas_row3 2*.16+log2_gas_row1
heinrichsweikamp
parents:
diff changeset
114 #DEFINE log2_gas_row4 3*.16+log2_gas_row1
heinrichsweikamp
parents:
diff changeset
115 #DEFINE log2_gas_row5 4*.16+log2_gas_row1
heinrichsweikamp
parents:
diff changeset
116
heinrichsweikamp
parents:
diff changeset
117 ; Setpoint List
heinrichsweikamp
parents:
diff changeset
118 #DEFINE log2_title_sp_row .130
heinrichsweikamp
parents:
diff changeset
119 #DEFINE log2_sp_row1 .146
heinrichsweikamp
parents:
diff changeset
120 #DEFINE log2_sp_row2 1*.16+log2_sp_row1
heinrichsweikamp
parents:
diff changeset
121 #DEFINE log2_sp_row3 2*.16+log2_sp_row1
heinrichsweikamp
parents:
diff changeset
122 #DEFINE log2_sp_row4 3*.16+log2_sp_row1
heinrichsweikamp
parents:
diff changeset
123 #DEFINE log2_sp_row5 4*.16+log2_sp_row1
heinrichsweikamp
parents:
diff changeset
124
heinrichsweikamp
parents:
diff changeset
125 ; Details list
heinrichsweikamp
parents:
diff changeset
126 #DEFINE log2_salinity_row .55
heinrichsweikamp
parents:
diff changeset
127 #DEFINE log2_salinity_column .2
heinrichsweikamp
parents:
diff changeset
128 #DEFINE log2_cns_row .1*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
129 #DEFINE log2_cns_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
130 #DEFINE log2_avr_row .2*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
131 #DEFINE log2_avr_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
132 #DEFINE log2_decomodel2_row .3*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
133 #DEFINE log2_decomodel2_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
134 #DEFINE log2_decomodel3_row .4*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
135 #DEFINE log2_decomodel3_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
136 #DEFINE log2_decomodel_row .5*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
137 #DEFINE log2_decomodel_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
138 #DEFINE log2_firmware_row .6*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
139 #DEFINE log2_firmware_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
140 #DEFINE log2_battery_row .7*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
141 #DEFINE log2_battery_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
142 #DEFINE log2_divemode_row .8*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
143 #DEFINE log2_divemode_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
144 #DEFINE log2_lastdeco_row .9*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
145 #DEFINE log2_lastdeco_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
146 ; Air pressure
heinrichsweikamp
parents:
diff changeset
147 #DEFINE MBAR_row .10*.16+log2_salinity_row
heinrichsweikamp
parents:
diff changeset
148 #DEFINE MBAR_column log2_salinity_column
heinrichsweikamp
parents:
diff changeset
149
heinrichsweikamp
parents:
diff changeset
150
heinrichsweikamp
parents:
diff changeset
151 ; Header coordinates
389
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
152 #DEFINE log_profile_version .8
0
heinrichsweikamp
parents:
diff changeset
153 #DEFINE log_date .12
heinrichsweikamp
parents:
diff changeset
154 #DEFINE log_time .15
heinrichsweikamp
parents:
diff changeset
155 #DEFINE log_max_depth .17
heinrichsweikamp
parents:
diff changeset
156 #DEFINE log_divetime .19
heinrichsweikamp
parents:
diff changeset
157 #DEFINE log_min_temp .22
heinrichsweikamp
parents:
diff changeset
158 #DEFINE log_surface_press .24
heinrichsweikamp
parents:
diff changeset
159 #DEFINE log_desattime .26
heinrichsweikamp
parents:
diff changeset
160 #DEFINE log_gas1 .28
heinrichsweikamp
parents:
diff changeset
161 #DEFINE log_gas2 .32
heinrichsweikamp
parents:
diff changeset
162 #DEFINE log_gas3 .36
heinrichsweikamp
parents:
diff changeset
163 #DEFINE log_gas4 .40
heinrichsweikamp
parents:
diff changeset
164 #DEFINE log_gas5 .44
heinrichsweikamp
parents:
diff changeset
165 #DEFINE log_firmware .48
heinrichsweikamp
parents:
diff changeset
166 #DEFINE log_battery .50
heinrichsweikamp
parents:
diff changeset
167 #DEFINE log_samplingrate .52
heinrichsweikamp
parents:
diff changeset
168 #DEFINE log_cns_start .53
heinrichsweikamp
parents:
diff changeset
169 #DEFINE log_gf_start .55
heinrichsweikamp
parents:
diff changeset
170 #DEFINE log_gf_end .56
heinrichsweikamp
parents:
diff changeset
171 #DEFINE log_sp1 .60
heinrichsweikamp
parents:
diff changeset
172 #DEFINE log_sp2 .62
heinrichsweikamp
parents:
diff changeset
173 #DEFINE log_sp3 .64
heinrichsweikamp
parents:
diff changeset
174 #DEFINE log_sp4 .66
heinrichsweikamp
parents:
diff changeset
175 #DEFINE log_sp5 .68
heinrichsweikamp
parents:
diff changeset
176 #DEFINE log_salinity .70
heinrichsweikamp
parents:
diff changeset
177 #DEFINE log_cns_end .71
heinrichsweikamp
parents:
diff changeset
178 #DEFINE log_avr_depth .73
heinrichsweikamp
parents:
diff changeset
179 #DEFINE log_total_seconds .75
heinrichsweikamp
parents:
diff changeset
180 #DEFINE log_gf_lo .77
heinrichsweikamp
parents:
diff changeset
181 #DEFINE log_sat_mult .77
heinrichsweikamp
parents:
diff changeset
182 #DEFINE log_gf_hi .78
heinrichsweikamp
parents:
diff changeset
183 #DEFINE log_desat_mult .78
heinrichsweikamp
parents:
diff changeset
184 #DEFINE log_decomodel .79
heinrichsweikamp
parents:
diff changeset
185 #DEFINE log_total_dives .80
heinrichsweikamp
parents:
diff changeset
186 #DEFINE log_divemode .82
heinrichsweikamp
parents:
diff changeset
187 #DEFINE log_last_stop .243
heinrichsweikamp
parents:
diff changeset
188
heinrichsweikamp
parents:
diff changeset
189 LOG_POINT_TO macro address
heinrichsweikamp
parents:
diff changeset
190 movlw address
heinrichsweikamp
parents:
diff changeset
191 movwf ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
192 endm
heinrichsweikamp
parents:
diff changeset
193
heinrichsweikamp
parents:
diff changeset
194 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
195
heinrichsweikamp
parents:
diff changeset
196 logbook code
heinrichsweikamp
parents:
diff changeset
197
heinrichsweikamp
parents:
diff changeset
198 TFT_logbook_cursor:
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
199 ; call speed_fastest
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
200 WIN_BOX_BLACK .0, .240-.16, logbook_list_left-.8, logbook_list_left-.1 ;top, bottom, left, right
0
heinrichsweikamp
parents:
diff changeset
201
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
202 WIN_LEFT logbook_list_left-.8
0
heinrichsweikamp
parents:
diff changeset
203 WIN_FONT FT_SMALL
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
204 ; bcf win_invert ; Reset invert flag
0
heinrichsweikamp
parents:
diff changeset
205 call TFT_standard_color
heinrichsweikamp
parents:
diff changeset
206
heinrichsweikamp
parents:
diff changeset
207 movff menupos,temp1
heinrichsweikamp
parents:
diff changeset
208 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
209 movlw d'0'
heinrichsweikamp
parents:
diff changeset
210 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
211 movlw logbook_row_offset
heinrichsweikamp
parents:
diff changeset
212 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
213 movlw .2*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
214 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
215 movlw .3*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
216 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
217 movlw .4*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
218 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
219 movlw .5*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
220 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
221 movlw .6*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
222 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
223 movlw .7*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
224 dcfsnz temp1,F
heinrichsweikamp
parents:
diff changeset
225 movlw .8*logbook_row_offset
heinrichsweikamp
parents:
diff changeset
226
433
heinrichsweikamp
parents: 432
diff changeset
227 movwf win_top
0
heinrichsweikamp
parents:
diff changeset
228 STRCPY_PRINT "\xB7"
heinrichsweikamp
parents:
diff changeset
229 return
heinrichsweikamp
parents:
diff changeset
230
heinrichsweikamp
parents:
diff changeset
231 global logbook
heinrichsweikamp
parents:
diff changeset
232 logbook:
heinrichsweikamp
parents:
diff changeset
233 clrf logbook_flags
heinrichsweikamp
parents:
diff changeset
234 clrf CCP1CON ; stop PWM
heinrichsweikamp
parents:
diff changeset
235 bcf PORTC,2 ; Pull PWM out to GND
heinrichsweikamp
parents:
diff changeset
236 call TFT_ClearScreen ; Clear screen
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
237 ; call TFT_standard_color
0
heinrichsweikamp
parents:
diff changeset
238 clrf menupos3 ; Here: used rows on current logbook-page
heinrichsweikamp
parents:
diff changeset
239 clrf logbook_page_number ; Here: # of current displayed page
heinrichsweikamp
parents:
diff changeset
240 clrf logbook_divenumber ; # of dive in list during search
heinrichsweikamp
parents:
diff changeset
241 clrf divemins+0 ; Here: used as temp variables
heinrichsweikamp
parents:
diff changeset
242 clrf divemins+1
heinrichsweikamp
parents:
diff changeset
243 clrf timeout_counter2 ; For timeout
heinrichsweikamp
parents:
diff changeset
244 movlw logbook_row_number
heinrichsweikamp
parents:
diff changeset
245 movwf menupos ; Here: stores current position on display (logbook_row_number-x)
heinrichsweikamp
parents:
diff changeset
246 read_int_eeprom .2 ; Get low-byte of total dives
heinrichsweikamp
parents:
diff changeset
247 movff EEDATA,logbook_max_dive_counter
heinrichsweikamp
parents:
diff changeset
248
heinrichsweikamp
parents:
diff changeset
249 ;-----------------------------------------------------------------------------
heinrichsweikamp
parents:
diff changeset
250 ; display dive headers backwards from read_int_eeprom .2 = lo-1
heinrichsweikamp
parents:
diff changeset
251 ; 1st: 200000h-200FFFh -> lo=0
heinrichsweikamp
parents:
diff changeset
252 ; 2nd: 201000h-201FFFh -> lo=1
heinrichsweikamp
parents:
diff changeset
253 ; 3rd: 202000h-202FFFh -> lo=2
heinrichsweikamp
parents:
diff changeset
254 ; 256: 2FF000h-2FFFFFh -> lo=255 (And hi>0...)
heinrichsweikamp
parents:
diff changeset
255 ; Stop when
heinrichsweikamp
parents:
diff changeset
256 ; a) no dive is stored (no valid header found)
heinrichsweikamp
parents:
diff changeset
257 ; b) current dive has no valid header (Number of stored dives < 256)
heinrichsweikamp
parents:
diff changeset
258 ; c) when 255 dives are reached divemins+0 = 255
heinrichsweikamp
parents:
diff changeset
259
heinrichsweikamp
parents:
diff changeset
260 logbook2:
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
261 ; call speed_fastest
0
heinrichsweikamp
parents:
diff changeset
262 incf divemins+0,F ; increase dive counter
heinrichsweikamp
parents:
diff changeset
263 incf divemins+0,W ; = 0x..FF ?
heinrichsweikamp
parents:
diff changeset
264 bz logbook_reset ; Yes: FF --> loop.
heinrichsweikamp
parents:
diff changeset
265
heinrichsweikamp
parents:
diff changeset
266 ; Set ext_flash_address:3 to TOC entry of this dive
heinrichsweikamp
parents:
diff changeset
267 ; 1st: 200000h-200FFFh -> logbook_max_dive_counter=0
heinrichsweikamp
parents:
diff changeset
268 ; 2nd: 201000h-201FFFh -> logbook_max_dive_counter=1
heinrichsweikamp
parents:
diff changeset
269 ; 3rd: 202000h-202FFFh -> logbook_max_dive_counter=2
heinrichsweikamp
parents:
diff changeset
270 ; 256: 2FF000h-2FFFFFh -> logbook_max_dive_counter=255 (And hi>0...)
heinrichsweikamp
parents:
diff changeset
271
heinrichsweikamp
parents:
diff changeset
272 decf logbook_max_dive_counter,F ; -1
heinrichsweikamp
parents:
diff changeset
273
heinrichsweikamp
parents:
diff changeset
274 clrf ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
275 clrf ext_flash_address+1
heinrichsweikamp
parents:
diff changeset
276 movlw 0x20
heinrichsweikamp
parents:
diff changeset
277 movwf ext_flash_address+2
heinrichsweikamp
parents:
diff changeset
278 movlw .16
heinrichsweikamp
parents:
diff changeset
279 mulwf logbook_max_dive_counter; logbook_max_dive_counter*16 = offset to 0x2000 (up:hi)
heinrichsweikamp
parents:
diff changeset
280 movf PRODL,W
heinrichsweikamp
parents:
diff changeset
281 addwf ext_flash_address+1,F
heinrichsweikamp
parents:
diff changeset
282 movf PRODH,W
heinrichsweikamp
parents:
diff changeset
283 addwfc ext_flash_address+2,F
heinrichsweikamp
parents:
diff changeset
284 ; pointer at the first 0xFA of header
heinrichsweikamp
parents:
diff changeset
285
heinrichsweikamp
parents:
diff changeset
286 call ext_flash_byte_read ; Reads one byte@ext_flash_address:3 into WREG and temp1
heinrichsweikamp
parents:
diff changeset
287 movwf temp1
heinrichsweikamp
parents:
diff changeset
288 movlw 0xFA
heinrichsweikamp
parents:
diff changeset
289 cpfseq temp1 ; 0xFA found?
heinrichsweikamp
parents:
diff changeset
290 bra logbook3b ; No, abort
heinrichsweikamp
parents:
diff changeset
291
heinrichsweikamp
parents:
diff changeset
292 incf logbook_divenumber,F ; new header found, increase logbook_divenumber
heinrichsweikamp
parents:
diff changeset
293 bra logbook4 ; Done with searching, display the header!
heinrichsweikamp
parents:
diff changeset
294
heinrichsweikamp
parents:
diff changeset
295 logbook3b:
heinrichsweikamp
parents:
diff changeset
296 btfss logbook_page_not_empty ; Was there at least one dive?
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
297 bra exit_logbook ; Not a single header was found, leave logbook.
0
heinrichsweikamp
parents:
diff changeset
298 bra logbook_display_loop2
heinrichsweikamp
parents:
diff changeset
299
heinrichsweikamp
parents:
diff changeset
300 logbook_reset:
heinrichsweikamp
parents:
diff changeset
301 tstfsz logbook_divenumber ; Was there at least one dive?
heinrichsweikamp
parents:
diff changeset
302 bra logbook_reset2
heinrichsweikamp
parents:
diff changeset
303 bra logbook3b ; No, Nothing to do
heinrichsweikamp
parents:
diff changeset
304
heinrichsweikamp
parents:
diff changeset
305 logbook_reset2:
heinrichsweikamp
parents:
diff changeset
306 bsf all_dives_shown ; Yes
heinrichsweikamp
parents:
diff changeset
307 bra logbook_display_loop2 ; Continue
heinrichsweikamp
parents:
diff changeset
308
heinrichsweikamp
parents:
diff changeset
309 logbook4:
heinrichsweikamp
parents:
diff changeset
310 btfsc all_dives_shown ; All dives displayed?
heinrichsweikamp
parents:
diff changeset
311 bra logbook_display_loop2 ; Yes, but display first page again.
heinrichsweikamp
parents:
diff changeset
312
heinrichsweikamp
parents:
diff changeset
313 call display_listdive ; display short header for list on current list position
heinrichsweikamp
parents:
diff changeset
314
heinrichsweikamp
parents:
diff changeset
315 movlw logbook_row_number
heinrichsweikamp
parents:
diff changeset
316 cpfseq menupos ; first dive on list (top place)?
heinrichsweikamp
parents:
diff changeset
317 bra logbook_display_loop1 ; no, so skip saving of address
heinrichsweikamp
parents:
diff changeset
318
heinrichsweikamp
parents:
diff changeset
319 ; store all registered required to rebuilt the current logbookpage after the detail/profile view
heinrichsweikamp
parents:
diff changeset
320 movff logbook_divenumber,logbook_divenumber_temp ; # of dive in list of the current page
heinrichsweikamp
parents:
diff changeset
321 movff divemins+0,divemins_backup ; amount of dives drawn until now
heinrichsweikamp
parents:
diff changeset
322 movff logbook_max_dive_counter,logbook_max_dive_counter_temp ; backup Counter
heinrichsweikamp
parents:
diff changeset
323
heinrichsweikamp
parents:
diff changeset
324 logbook_display_loop1:
heinrichsweikamp
parents:
diff changeset
325 decfsz menupos,F ; List full?
heinrichsweikamp
parents:
diff changeset
326 bra logbook2 ; no, search another dive for our current logbook page
heinrichsweikamp
parents:
diff changeset
327
heinrichsweikamp
parents:
diff changeset
328 logbook_display_loop2:
heinrichsweikamp
parents:
diff changeset
329 btfss logbook_page_not_empty ; Was there one dive at all?
heinrichsweikamp
parents:
diff changeset
330 bra logbook ; Yes, so reload the first page
heinrichsweikamp
parents:
diff changeset
331
heinrichsweikamp
parents:
diff changeset
332 ; TFT_mask...
heinrichsweikamp
parents:
diff changeset
333
heinrichsweikamp
parents:
diff changeset
334 WIN_LEFT logbook_list_left
heinrichsweikamp
parents:
diff changeset
335 WIN_TOP logbook_row_offset*logbook_row_number
heinrichsweikamp
parents:
diff changeset
336 STRCPY_TEXT_PRINT tNextLog ; "Next Page"
heinrichsweikamp
parents:
diff changeset
337 WIN_LEFT logbook_list_left
heinrichsweikamp
parents:
diff changeset
338 WIN_TOP logbook_row_offset*(logbook_row_number+.1)
276
e4cb495aed3d Increase byte timeout in PC download mode, faster response to "Exit" in main menu
heinrichsweikamp
parents: 275
diff changeset
339 STRCPY_TEXT_PRINT tExit ; "Exit"
0
heinrichsweikamp
parents:
diff changeset
340
heinrichsweikamp
parents:
diff changeset
341 movlw d'1' ; Set cursor to position 1...
heinrichsweikamp
parents:
diff changeset
342 btfsc return_from_profileview ; .. unless we are returning from a detail/profile view
heinrichsweikamp
parents:
diff changeset
343 movf logbook_menupos_temp,W ; load last cursor position again
heinrichsweikamp
parents:
diff changeset
344 movwf menupos ; and set menupos byte
heinrichsweikamp
parents:
diff changeset
345 bcf return_from_profileview ; Do this only once while the page is loaded again!
heinrichsweikamp
parents:
diff changeset
346
heinrichsweikamp
parents:
diff changeset
347 bcf logbook_page_not_empty ; Obviously the current page is NOT empty
169
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
348
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
349 movlw d'7' ; Set cursor to position 7...
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
350 btfsc keep_cursor_new_page ; ... if we came from the "new Page" line
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
351 movwf menupos ; and set menupos byte
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
352 bcf keep_cursor_new_page
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
353
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
354 call TFT_logbook_cursor ; Show the cursor
0
heinrichsweikamp
parents:
diff changeset
355
heinrichsweikamp
parents:
diff changeset
356 call logbook_preloop_tasks ; Clear some flags and set to Speed_eco
169
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
357 call menu_processor_bottom_line ; Show bottom line
0
heinrichsweikamp
parents:
diff changeset
358 logbook_loop:
heinrichsweikamp
parents:
diff changeset
359 btfsc switch_left ; SET/MENU?
heinrichsweikamp
parents:
diff changeset
360 goto next_logbook3 ; adjust cursor or create new page
heinrichsweikamp
parents:
diff changeset
361 btfsc switch_right ; ENTER?
heinrichsweikamp
parents:
diff changeset
362 bra display_profile_or_exit ; view details/profile or exit logbook
heinrichsweikamp
parents:
diff changeset
363
heinrichsweikamp
parents:
diff changeset
364 rcall log_screendump_and_onesecond ; Check if we need to make a screenshot and check for new second
heinrichsweikamp
parents:
diff changeset
365 btfsc sleepmode ; Timeout?
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
366 bra exit_logbook ; Yes
0
heinrichsweikamp
parents:
diff changeset
367
heinrichsweikamp
parents:
diff changeset
368 bra logbook_loop ; Wait for something to do
heinrichsweikamp
parents:
diff changeset
369
heinrichsweikamp
parents:
diff changeset
370 display_profile_or_exit:
heinrichsweikamp
parents:
diff changeset
371 movlw logbook_row_number+.2 ; exit?
heinrichsweikamp
parents:
diff changeset
372 cpfseq menupos
heinrichsweikamp
parents:
diff changeset
373 bra display_profile_or_exit2 ; No, check for "Next Page"
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
374
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
375 exit_logbook:
436
95ee78f4a974 no screen reboot after logbook exit
heinrichsweikamp
parents: 435
diff changeset
376 ; call TFT_DisplayOff
95ee78f4a974 no screen reboot after logbook exit
heinrichsweikamp
parents: 435
diff changeset
377 ; call TFT_boot
66
00636132cca6 BUGFIX: Maintain last selected customview in surface mode
heinrichsweikamp
parents: 50
diff changeset
378 goto do_main_menu2
0
heinrichsweikamp
parents:
diff changeset
379
heinrichsweikamp
parents:
diff changeset
380 display_profile_or_exit2:
heinrichsweikamp
parents:
diff changeset
381 movlw logbook_row_number+.1 ; Next page?
heinrichsweikamp
parents:
diff changeset
382 cpfseq menupos
heinrichsweikamp
parents:
diff changeset
383 bra display_profile ; No, show details/profile
heinrichsweikamp
parents:
diff changeset
384 goto next_logbook2 ; Next page!
heinrichsweikamp
parents:
diff changeset
385
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
386 display_profile:
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
387 bcf is_bailout
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
388 bcf gas6_changed ; Clear event flags
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
389 ; call speed_fastest
0
heinrichsweikamp
parents:
diff changeset
390 movff menupos,logbook_menupos_temp; store current cursor position
heinrichsweikamp
parents:
diff changeset
391 bsf return_from_profileview ; tweak search routine to exit after found
heinrichsweikamp
parents:
diff changeset
392
heinrichsweikamp
parents:
diff changeset
393 movf logbook_page_number,W ; Number of page
heinrichsweikamp
parents:
diff changeset
394 mullw logbook_row_number
heinrichsweikamp
parents:
diff changeset
395 movf PRODL,W
heinrichsweikamp
parents:
diff changeset
396 addwf menupos,W ; page*logbook_row_number+menupos=
heinrichsweikamp
parents:
diff changeset
397 movwf divesecs ; # of dive to show
heinrichsweikamp
parents:
diff changeset
398
heinrichsweikamp
parents:
diff changeset
399 display_profile2:
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
400 ; call speed_fastest
0
heinrichsweikamp
parents:
diff changeset
401 clrf CCP1CON ; stop PWM
heinrichsweikamp
parents:
diff changeset
402 bcf PORTC,2 ; Pull PWM out to GND
heinrichsweikamp
parents:
diff changeset
403 call TFT_ClearScreen ; Clear screen
heinrichsweikamp
parents:
diff changeset
404 ; Set ext_flash pointer to "#divesecs-oldest" dive
heinrichsweikamp
parents:
diff changeset
405 ; compute read_int_eeprom .2 - divesecs
heinrichsweikamp
parents:
diff changeset
406 ; Read required header data for profile display
heinrichsweikamp
parents:
diff changeset
407 ; look in header for pointer to begin of diveprofile (Byte 2-4)
heinrichsweikamp
parents:
diff changeset
408 ; Set pointer (ext_flash_log_pointer:3) to this address, start drawing
heinrichsweikamp
parents:
diff changeset
409
heinrichsweikamp
parents:
diff changeset
410 decf divesecs,F ;-1
heinrichsweikamp
parents:
diff changeset
411 read_int_eeprom .2
heinrichsweikamp
parents:
diff changeset
412 movf EEDATA,W
heinrichsweikamp
parents:
diff changeset
413 bcf STATUS,C
heinrichsweikamp
parents:
diff changeset
414 subfwb divesecs,W ; max. dives (low value) - divesecs
heinrichsweikamp
parents:
diff changeset
415 movwf lo ; result
heinrichsweikamp
parents:
diff changeset
416 incf divesecs,F ;+1
heinrichsweikamp
parents:
diff changeset
417 ; Set ext_flash_address:3 to TOC entry of this dive
heinrichsweikamp
parents:
diff changeset
418 ; 1st: 200000h-200FFFh -> lo=0
heinrichsweikamp
parents:
diff changeset
419 ; 2nd: 201000h-201FFFh -> lo=1
heinrichsweikamp
parents:
diff changeset
420 ; 3rd: 202000h-202FFFh -> lo=2
heinrichsweikamp
parents:
diff changeset
421 ; 256: 2FF000h-2FFFFFh -> lo=255 (And hi>0...)
heinrichsweikamp
parents:
diff changeset
422 clrf ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
423 clrf ext_flash_address+1
heinrichsweikamp
parents:
diff changeset
424 movlw 0x20
heinrichsweikamp
parents:
diff changeset
425 movwf ext_flash_address+2
heinrichsweikamp
parents:
diff changeset
426 movlw .16
heinrichsweikamp
parents:
diff changeset
427 mulwf lo ; lo*16 = offset to 0x2000 (up:hi)
heinrichsweikamp
parents:
diff changeset
428 movf PRODL,W
heinrichsweikamp
parents:
diff changeset
429 addwf ext_flash_address+1,F
heinrichsweikamp
parents:
diff changeset
430 movf PRODH,W
heinrichsweikamp
parents:
diff changeset
431 addwfc ext_flash_address+2,F
heinrichsweikamp
parents:
diff changeset
432 ; pointer at the first 0xFA of header
heinrichsweikamp
parents:
diff changeset
433
heinrichsweikamp
parents:
diff changeset
434 ; Now, show profile
heinrichsweikamp
parents:
diff changeset
435 LOG_POINT_TO log_samplingrate
heinrichsweikamp
parents:
diff changeset
436 call ext_flash_byte_read ; Read sampling rate
heinrichsweikamp
parents:
diff changeset
437 movff temp1,samplesecs_value ; needed later...
heinrichsweikamp
parents:
diff changeset
438
heinrichsweikamp
parents:
diff changeset
439 LOG_POINT_TO .2
heinrichsweikamp
parents:
diff changeset
440 call ext_flash_byte_read_plus ; Read start address of profile
heinrichsweikamp
parents:
diff changeset
441 movff temp1,ext_flash_log_pointer+0
heinrichsweikamp
parents:
diff changeset
442 call ext_flash_byte_read_plus ; Read start address of profile
heinrichsweikamp
parents:
diff changeset
443 movff temp1,ext_flash_log_pointer+1
heinrichsweikamp
parents:
diff changeset
444 call ext_flash_byte_read_plus ; Read start address of profile
heinrichsweikamp
parents:
diff changeset
445 movff temp1,ext_flash_log_pointer+2
heinrichsweikamp
parents:
diff changeset
446
heinrichsweikamp
parents:
diff changeset
447
heinrichsweikamp
parents:
diff changeset
448 clrf logbook_sample_counter+0
heinrichsweikamp
parents:
diff changeset
449 clrf logbook_sample_counter+1 ; holds amount of read samples
heinrichsweikamp
parents:
diff changeset
450
heinrichsweikamp
parents:
diff changeset
451 call TFT_standard_color
heinrichsweikamp
parents:
diff changeset
452 call logbook_show_divenumber ; Show the dive number in medium font
heinrichsweikamp
parents:
diff changeset
453
heinrichsweikamp
parents:
diff changeset
454 WIN_SMALL logbook_date_column, logbook_date_row
heinrichsweikamp
parents:
diff changeset
455 LOG_POINT_TO log_date
heinrichsweikamp
parents:
diff changeset
456 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
457 movff temp1,convert_value_temp+2 ; Year
heinrichsweikamp
parents:
diff changeset
458 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
459 movff temp1,convert_value_temp+0 ; Month
heinrichsweikamp
parents:
diff changeset
460 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
461 movff temp1,convert_value_temp+1 ; Day
heinrichsweikamp
parents:
diff changeset
462 call TFT_convert_date ; converts into "DD/MM/YY" or "MM/DD/YY" or "YY/MM/DD" in postinc2
heinrichsweikamp
parents:
diff changeset
463 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
464
heinrichsweikamp
parents:
diff changeset
465 WIN_SMALL logbook_time_column, logbook_time_row
heinrichsweikamp
parents:
diff changeset
466 call ext_flash_byte_read_plus ; hour
heinrichsweikamp
parents:
diff changeset
467 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
468 call ext_flash_byte_read_plus ; Minutes
heinrichsweikamp
parents:
diff changeset
469 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
470 output_99x ; hour
heinrichsweikamp
parents:
diff changeset
471 PUTC ':'
389
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
472 movff hi,lo
0
heinrichsweikamp
parents:
diff changeset
473 output_99x ; minute
heinrichsweikamp
parents:
diff changeset
474 STRCAT_PRINT "" ; Display 1st row of details
heinrichsweikamp
parents:
diff changeset
475
389
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
476 LOG_POINT_TO log_profile_version
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
477 call ext_flash_byte_read_plus ; Profile version
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
478 movlw 0x24
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
479 cpfslt temp1 ; <0x24?
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
480 bra log_skip_extra_icon ; Yes, skip
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
481
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
482 WIN_SMALL logbook_time_column-.8, logbook_time_row
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
483 STRCPY_PRINT 0x94 ; "End of dive" icon
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
484
9175429bdeba CHANGE: Logbook now shows end-of-dive date and time for dives made with firmware <1.92 indicated by an icon in the logbook
heinrichsweikamp
parents: 376
diff changeset
485 log_skip_extra_icon:
0
heinrichsweikamp
parents:
diff changeset
486 LOG_POINT_TO log_max_depth
heinrichsweikamp
parents:
diff changeset
487 call ext_flash_byte_read_plus ; read max depth
heinrichsweikamp
parents:
diff changeset
488 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
489 call ext_flash_byte_read_plus ; read max depth
heinrichsweikamp
parents:
diff changeset
490 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
491 movff lo,xA+0 ; calculate y-scale for profile display
heinrichsweikamp
parents:
diff changeset
492 movff hi,xA+1
heinrichsweikamp
parents:
diff changeset
493 movlw profile_height_pixels ; pixel height available for profile
heinrichsweikamp
parents:
diff changeset
494 movwf xB+0
heinrichsweikamp
parents:
diff changeset
495 clrf xB+1
heinrichsweikamp
parents:
diff changeset
496 call div16x16 ; does xA/xB=xC
heinrichsweikamp
parents:
diff changeset
497 movff xC+0,y_scale+0 ; holds LOW byte of y-scale (mbar/pixel!)
heinrichsweikamp
parents:
diff changeset
498 movff xC+1,y_scale+1 ; holds HIGH byte of y-scale (mbar/pixel!)
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
499 infsnz y_scale+0,F ; increase one, because there may be a remainder
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
500 incf y_scale+1,F
0
heinrichsweikamp
parents:
diff changeset
501
417
heinrichsweikamp
parents: 402
diff changeset
502 movlw LOW ((profile_height_pixels+1)*.1000)
0
heinrichsweikamp
parents:
diff changeset
503 movwf xC+0
heinrichsweikamp
parents:
diff changeset
504 movlw HIGH (((profile_height_pixels+1)*.1000) & h'FFFF')
heinrichsweikamp
parents:
diff changeset
505 movwf xC+1
heinrichsweikamp
parents:
diff changeset
506 movlw UPPER ((profile_height_pixels+1)*.1000)
heinrichsweikamp
parents:
diff changeset
507 movwf xC+2
heinrichsweikamp
parents:
diff changeset
508 clrf xC+3
heinrichsweikamp
parents:
diff changeset
509
heinrichsweikamp
parents:
diff changeset
510 movff lo,xB+0 ; Max. Depth in mbar
heinrichsweikamp
parents:
diff changeset
511 movff hi,xB+1 ; Max. Depth in mbar
heinrichsweikamp
parents:
diff changeset
512 call div32x16 ; xC:4 / xB:2 = xC+3:xC+2 with xC+1:xC+0 as remainder
heinrichsweikamp
parents:
diff changeset
513
heinrichsweikamp
parents:
diff changeset
514 movff xC+0,x_scale+0 ;
heinrichsweikamp
parents:
diff changeset
515 movff xC+1,x_scale+1 ; = Pixels/10m (For scale, draw any xx rows a scale-line)
heinrichsweikamp
parents:
diff changeset
516
heinrichsweikamp
parents:
diff changeset
517 movf x_scale+0,W
heinrichsweikamp
parents:
diff changeset
518 iorwf x_scale+1,W ; x_scale:2 = Null?
heinrichsweikamp
parents:
diff changeset
519 bnz display_profile_offset4 ; No, continue
heinrichsweikamp
parents:
diff changeset
520 incf x_scale+1,F ; Yes, make x_scale+1>1 to make "display_profile2e" working
heinrichsweikamp
parents:
diff changeset
521
heinrichsweikamp
parents:
diff changeset
522 display_profile_offset4:
heinrichsweikamp
parents:
diff changeset
523 WIN_SMALL log_max_value_column,log_max_value_row
heinrichsweikamp
parents:
diff changeset
524
heinrichsweikamp
parents:
diff changeset
525 TSTOSS opt_units ; 0=Meters, 1=Feets
heinrichsweikamp
parents:
diff changeset
526 bra display_profile_offset4_metric
heinrichsweikamp
parents:
diff changeset
527 ;display_profile_offset4_imperial:
heinrichsweikamp
parents:
diff changeset
528 call convert_mbar_to_feet ; convert value in lo:hi from mbar to feet
heinrichsweikamp
parents:
diff changeset
529 PUTC ' '
25
f65d070a5b76 fix imperial units in logbook
heinrichsweikamp
parents: 0
diff changeset
530 bcf leftbind
225
31088352ee32 BUGFIX: Show dives with >999mins divetime correctly
heinrichsweikamp
parents: 189
diff changeset
531 output_16_3 ; limit to 999 and display only (0-999)
0
heinrichsweikamp
parents:
diff changeset
532 STRCAT_TEXT_PRINT tFeets
heinrichsweikamp
parents:
diff changeset
533 bra display_profile_offset4_common
heinrichsweikamp
parents:
diff changeset
534
heinrichsweikamp
parents:
diff changeset
535 display_profile_offset4_metric:
heinrichsweikamp
parents:
diff changeset
536 bsf leftbind
heinrichsweikamp
parents:
diff changeset
537 output_16dp d'3' ; max. depth
heinrichsweikamp
parents:
diff changeset
538 STRCAT_TEXT_PRINT tMeters
heinrichsweikamp
parents:
diff changeset
539
heinrichsweikamp
parents:
diff changeset
540 display_profile_offset4_common:
heinrichsweikamp
parents:
diff changeset
541 call ext_flash_byte_read_plus ; divetime in minutes
heinrichsweikamp
parents:
diff changeset
542 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
543 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
544 movff temp1,hi ; divetime in minutes
heinrichsweikamp
parents:
diff changeset
545
heinrichsweikamp
parents:
diff changeset
546 movff lo,xA+0 ; calculate x-scale for profile display
heinrichsweikamp
parents:
diff changeset
547 movff hi,xA+1 ; calculate total diveseconds first
heinrichsweikamp
parents:
diff changeset
548 movlw d'60' ; 60seconds are one minute...
heinrichsweikamp
parents:
diff changeset
549 movwf xB+0
heinrichsweikamp
parents:
diff changeset
550 clrf xB+1
heinrichsweikamp
parents:
diff changeset
551 call mult16x16 ; result is in xC:2 !
heinrichsweikamp
parents:
diff changeset
552
heinrichsweikamp
parents:
diff changeset
553 WIN_SMALL log_divetime_value_column,log_divetime_value_row
heinrichsweikamp
parents:
diff changeset
554 bsf leftbind
heinrichsweikamp
parents:
diff changeset
555 output_16 ; divetime minutes
heinrichsweikamp
parents:
diff changeset
556 movlw LOW d'600'
heinrichsweikamp
parents:
diff changeset
557 movwf xA+0
heinrichsweikamp
parents:
diff changeset
558 movlw HIGH d'600'
heinrichsweikamp
parents:
diff changeset
559 movwf xA+1 ; A vertical line every 600 seconds
heinrichsweikamp
parents:
diff changeset
560 movff samplesecs_value,xB+0 ; Copy sampling rate
heinrichsweikamp
parents:
diff changeset
561 clrf xB+1
heinrichsweikamp
parents:
diff changeset
562 call div16x16 ; xA/xB=xC with xA as remainder
heinrichsweikamp
parents:
diff changeset
563 movff xC+0,average_depth_hold_total+0
heinrichsweikamp
parents:
diff changeset
564 movff xC+1,average_depth_hold_total+1
heinrichsweikamp
parents:
diff changeset
565 ;average_depth_hold_total:2 holds interval of samples for vertical 10min line
heinrichsweikamp
parents:
diff changeset
566
heinrichsweikamp
parents:
diff changeset
567 ; Restore divetime in minutes:
heinrichsweikamp
parents:
diff changeset
568 ; get real sample time
heinrichsweikamp
parents:
diff changeset
569 LOG_POINT_TO log_total_seconds
heinrichsweikamp
parents:
diff changeset
570 call ext_flash_byte_read_plus ; Total sample time in seconds
heinrichsweikamp
parents:
diff changeset
571 movff temp1,xC+0
heinrichsweikamp
parents:
diff changeset
572 call ext_flash_byte_read_plus ; Total sample time in seconds
heinrichsweikamp
parents:
diff changeset
573 movff temp1,xC+1
heinrichsweikamp
parents:
diff changeset
574
heinrichsweikamp
parents:
diff changeset
575 PUTC ':'
heinrichsweikamp
parents:
diff changeset
576 LOG_POINT_TO log_divetime+.2
heinrichsweikamp
parents:
diff changeset
577 call ext_flash_byte_read_plus ; read divetime seconds
heinrichsweikamp
parents:
diff changeset
578 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
579 movff xC+0,xA+0 ; now calculate x-scale value
heinrichsweikamp
parents:
diff changeset
580 movff xC+1,xA+1
heinrichsweikamp
parents:
diff changeset
581 movlw profile_width_pixels ; pix width available
heinrichsweikamp
parents:
diff changeset
582 movwf xB+0
heinrichsweikamp
parents:
diff changeset
583 clrf xB+1
heinrichsweikamp
parents:
diff changeset
584 call div16x16 ; xA/xB=xC
heinrichsweikamp
parents:
diff changeset
585 movff xC+0,xA+0
heinrichsweikamp
parents:
diff changeset
586 movff xC+1,xA+1
heinrichsweikamp
parents:
diff changeset
587 movf samplesecs_value,W ; devide through sample interval!
heinrichsweikamp
parents:
diff changeset
588 movwf xB+0
heinrichsweikamp
parents:
diff changeset
589 clrf xB+1
heinrichsweikamp
parents:
diff changeset
590 call div16x16 ; xA/xB=xC
heinrichsweikamp
parents:
diff changeset
591 movff xC+0,profile_temp+0 ; store value (use any #xC sample, skip xC-1) into temp registers
heinrichsweikamp
parents:
diff changeset
592 movff xC+1,profile_temp+1 ; store value (use any #xC sample, skip xC-1) into temp registers
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
593 infsnz profile_temp+0,F ; Increase by one, there might be a remainder
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
594 incf profile_temp+1,F
0
heinrichsweikamp
parents:
diff changeset
595
heinrichsweikamp
parents:
diff changeset
596 bsf leftbind
heinrichsweikamp
parents:
diff changeset
597 output_99x ; divetime seconds
heinrichsweikamp
parents:
diff changeset
598 call TFT_standard_color
heinrichsweikamp
parents:
diff changeset
599 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
600
heinrichsweikamp
parents:
diff changeset
601 call ext_flash_byte_read_plus ; Read min. Temperature
heinrichsweikamp
parents:
diff changeset
602 movff temp1,logbook_min_tp+0
heinrichsweikamp
parents:
diff changeset
603 call ext_flash_byte_read_plus ; Read min. Temperature
heinrichsweikamp
parents:
diff changeset
604 movff temp1,logbook_min_tp+1
heinrichsweikamp
parents:
diff changeset
605
heinrichsweikamp
parents:
diff changeset
606 ; Set pointer to Gas 1 Type.
heinrichsweikamp
parents:
diff changeset
607 LOG_POINT_TO log_gas1+.3
heinrichsweikamp
parents:
diff changeset
608 call ext_flash_byte_read_plus ; read Gas Type
heinrichsweikamp
parents:
diff changeset
609 decfsz temp1,W ; =1 (="First")?
heinrichsweikamp
parents:
diff changeset
610 bra logbook_find_first_gas2 ; No.
heinrichsweikamp
parents:
diff changeset
611 movlw .1
heinrichsweikamp
parents:
diff changeset
612 movwf temp1
heinrichsweikamp
parents:
diff changeset
613 bra logbook_find_first_gas_done
heinrichsweikamp
parents:
diff changeset
614 logbook_find_first_gas2:
heinrichsweikamp
parents:
diff changeset
615 ; Set pointer to Gas 2 Type.
heinrichsweikamp
parents:
diff changeset
616 LOG_POINT_TO log_gas2+.3
heinrichsweikamp
parents:
diff changeset
617 call ext_flash_byte_read_plus ; read Gas Type
heinrichsweikamp
parents:
diff changeset
618 decfsz temp1,W ; =1 (="First")?
heinrichsweikamp
parents:
diff changeset
619 bra logbook_find_first_gas3 ; No.
heinrichsweikamp
parents:
diff changeset
620 movlw .2
heinrichsweikamp
parents:
diff changeset
621 movwf temp1
heinrichsweikamp
parents:
diff changeset
622 bra logbook_find_first_gas_done
heinrichsweikamp
parents:
diff changeset
623 logbook_find_first_gas3:
heinrichsweikamp
parents:
diff changeset
624 ; Set pointer to Gas 3 Type.
heinrichsweikamp
parents:
diff changeset
625 LOG_POINT_TO log_gas3+.3
heinrichsweikamp
parents:
diff changeset
626 call ext_flash_byte_read_plus ; read Gas Type
heinrichsweikamp
parents:
diff changeset
627 decfsz temp1,W ; =1 (="First")?
heinrichsweikamp
parents:
diff changeset
628 bra logbook_find_first_gas4 ; No.
heinrichsweikamp
parents:
diff changeset
629 movlw .3
heinrichsweikamp
parents:
diff changeset
630 movwf temp1
heinrichsweikamp
parents:
diff changeset
631 bra logbook_find_first_gas_done
heinrichsweikamp
parents:
diff changeset
632 logbook_find_first_gas4:
heinrichsweikamp
parents:
diff changeset
633 ; Set pointer to Gas 4 Type.
heinrichsweikamp
parents:
diff changeset
634 LOG_POINT_TO log_gas4+.3
heinrichsweikamp
parents:
diff changeset
635 call ext_flash_byte_read_plus ; read Gas Type
heinrichsweikamp
parents:
diff changeset
636 decfsz temp1,W ; =1 (="First")?
heinrichsweikamp
parents:
diff changeset
637 bra logbook_find_first_gas5 ; No.
heinrichsweikamp
parents:
diff changeset
638 movlw .4
heinrichsweikamp
parents:
diff changeset
639 movwf temp1
heinrichsweikamp
parents:
diff changeset
640 bra logbook_find_first_gas_done
heinrichsweikamp
parents:
diff changeset
641 logbook_find_first_gas5:
heinrichsweikamp
parents:
diff changeset
642 movlw .5 ; Must be Gas5
heinrichsweikamp
parents:
diff changeset
643 movwf temp1
heinrichsweikamp
parents:
diff changeset
644 logbook_find_first_gas_done:
heinrichsweikamp
parents:
diff changeset
645 movff temp1,average_depth_hold_total+3; keep copy to restore color
heinrichsweikamp
parents:
diff changeset
646 rcall profile_display_color ; Back to normal profile color.
heinrichsweikamp
parents:
diff changeset
647 ; Pointer is now trashed!
heinrichsweikamp
parents:
diff changeset
648
heinrichsweikamp
parents:
diff changeset
649 ; Point to profile portion of this dive
heinrichsweikamp
parents:
diff changeset
650 movff ext_flash_log_pointer+0,ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
651 movff ext_flash_log_pointer+1,ext_flash_address+1
heinrichsweikamp
parents:
diff changeset
652 movff ext_flash_log_pointer+2,ext_flash_address+2
heinrichsweikamp
parents:
diff changeset
653
heinrichsweikamp
parents:
diff changeset
654 incf_ext_flash_address_0x20 d'2' ; Skip 0xFA 0xFA
heinrichsweikamp
parents:
diff changeset
655 call ext_flash_byte_read_plus_0x20 ; Read low byte of total dives into temp1 (at the time the dive was made)
heinrichsweikamp
parents:
diff changeset
656
heinrichsweikamp
parents:
diff changeset
657 ; Load total number of dives (low byte only)
heinrichsweikamp
parents:
diff changeset
658 read_int_eeprom .2
heinrichsweikamp
parents:
diff changeset
659 incf EEDATA,W ; +1
heinrichsweikamp
parents:
diff changeset
660 bsf STATUS,C ; Set borrow
heinrichsweikamp
parents:
diff changeset
661 subfwb divesecs,W ; total dives - dive# to show - 1 = low byte of total dives (at the time the dive was made)
heinrichsweikamp
parents:
diff changeset
662 cpfseq temp1 ; # of dive in logbook (Must be equal with low byte in short header)
heinrichsweikamp
parents:
diff changeset
663 bra display_profile_no_profile ; Not equal, no profile for this dive available!
heinrichsweikamp
parents:
diff changeset
664
heinrichsweikamp
parents:
diff changeset
665 ; Skip rest of short header: 3 Bytes
heinrichsweikamp
parents:
diff changeset
666 ; Skip length of profile data: 3 Bytes
heinrichsweikamp
parents:
diff changeset
667 ; Skip sampling rate in profile section: 1Byte
heinrichsweikamp
parents:
diff changeset
668 ; Skip number of divisors: 1Byte
heinrichsweikamp
parents:
diff changeset
669 incf_ext_flash_address_0x20 d'8'
heinrichsweikamp
parents:
diff changeset
670
heinrichsweikamp
parents:
diff changeset
671 ; Divisor temp
heinrichsweikamp
parents:
diff changeset
672 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
673 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
674 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
675 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
676 movf temp1,W
heinrichsweikamp
parents:
diff changeset
677 movwf divisor_temperature ; Store divisor
heinrichsweikamp
parents:
diff changeset
678 movwf count_temperature ; Store to tp° counter too.
heinrichsweikamp
parents:
diff changeset
679 ; Divisor Deco
heinrichsweikamp
parents:
diff changeset
680 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
681 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
682 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
683 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
684 movf temp1,W
heinrichsweikamp
parents:
diff changeset
685 movwf divisor_deco ; Store divisor
heinrichsweikamp
parents:
diff changeset
686 movwf count_deco ; Store as temp, too
heinrichsweikamp
parents:
diff changeset
687 ; Divisor GF
heinrichsweikamp
parents:
diff changeset
688 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
689 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
690 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
691 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
692 movff temp1,divisor_gf ; Store divisor
heinrichsweikamp
parents:
diff changeset
693 ; Divisor ppO2 Sensors
heinrichsweikamp
parents:
diff changeset
694 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
695 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
696 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
697 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
698 movff temp1,divisor_ppo2_sensors ; Store divisor
heinrichsweikamp
parents:
diff changeset
699 ; Divisor decoplan
heinrichsweikamp
parents:
diff changeset
700 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
701 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
702 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
703 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
704 movff temp1,divisor_decoplan ; Store divisor
heinrichsweikamp
parents:
diff changeset
705 ; Divisor CNS
heinrichsweikamp
parents:
diff changeset
706 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
707 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
708 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
709 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
710 movff temp1,divisor_cns ; Store divisor
heinrichsweikamp
parents:
diff changeset
711 ; Divisor Tank data
heinrichsweikamp
parents:
diff changeset
712 incf_ext_flash_address_0x20 d'2'
heinrichsweikamp
parents:
diff changeset
713 ; call ext_flash_byte_read_plus_0x20 ; Read information type
heinrichsweikamp
parents:
diff changeset
714 ; call ext_flash_byte_read_plus_0x20 ; Read information Length
heinrichsweikamp
parents:
diff changeset
715 call ext_flash_byte_read_plus_0x20 ; Read information Divisor
heinrichsweikamp
parents:
diff changeset
716 movff temp1,divisor_tank ; Store divisor
heinrichsweikamp
parents:
diff changeset
717
heinrichsweikamp
parents:
diff changeset
718 ; Start Profile display
heinrichsweikamp
parents:
diff changeset
719 movlw color_deepblue
heinrichsweikamp
parents:
diff changeset
720 call TFT_set_color ; Make this configurable?
heinrichsweikamp
parents:
diff changeset
721 ; Draw a frame around profile area
heinrichsweikamp
parents:
diff changeset
722 WIN_FRAME_COLOR16 profile_top-1,profile_top+profile_height_pixels+1,profile_left-1,profile_left+profile_width_pixels+1
heinrichsweikamp
parents:
diff changeset
723
heinrichsweikamp
parents:
diff changeset
724 movlw profile_top
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
725 movwf win_top
0
heinrichsweikamp
parents:
diff changeset
726 movlw profile_left
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
727 movwf win_leftx2 ; Left border (0-159)
0
heinrichsweikamp
parents:
diff changeset
728 movlw d'1'
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
729 movwf win_height
0
heinrichsweikamp
parents:
diff changeset
730 movlw profile_width_pixels+.1
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
731 movwf win_width+0 ; Right border (0-159)
433
heinrichsweikamp
parents: 432
diff changeset
732 clrf win_width+1
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
733 bra display_profile2f ; No 0m line
0
heinrichsweikamp
parents:
diff changeset
734 display_profile2e:
heinrichsweikamp
parents:
diff changeset
735 call TFT_box ; Inputs: win_top, win_leftx2, win_height, win_width, win_color1, win_color2
heinrichsweikamp
parents:
diff changeset
736 display_profile2f:
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
737 movf win_top,W ; Get row
0
heinrichsweikamp
parents:
diff changeset
738 addwf x_scale+0,W ; Add line interval distance to win_top
heinrichsweikamp
parents:
diff changeset
739 tstfsz x_scale+1 ; >255?
heinrichsweikamp
parents:
diff changeset
740 movlw d'255' ; Yes, make win_top>239 -> Abort here
heinrichsweikamp
parents:
diff changeset
741 btfsc STATUS,C ; A Cary from the addwf above?
heinrichsweikamp
parents:
diff changeset
742 movlw d'255' ; Yes, make win_top>239 -> Abort here
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
743 movwf win_top ; Result in win_top again
0
heinrichsweikamp
parents:
diff changeset
744 movlw profile_top+profile_height_pixels+.1 ; Limit
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
745 cpfsgt win_top ; >239?
0
heinrichsweikamp
parents:
diff changeset
746 bra display_profile2e ; No, draw another line
heinrichsweikamp
parents:
diff changeset
747
heinrichsweikamp
parents:
diff changeset
748 clrf timeout_counter2 ; here: used as counter for depth readings
heinrichsweikamp
parents:
diff changeset
749 movlw profile_width_pixels+profile_left-.1
heinrichsweikamp
parents:
diff changeset
750 movwf ignore_digits ; here: used as counter for x-pixels
heinrichsweikamp
parents:
diff changeset
751 bcf end_of_profile ; clear flag
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
752
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
753 movlw profile_left+.1
0
heinrichsweikamp
parents:
diff changeset
754 movwf logbook_pixel_x_pos ; here: used as colum x2 (Start at Colum 5)
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
755
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
756 movlw profile_top+.1 ; Zero-m row
0
heinrichsweikamp
parents:
diff changeset
757 movwf apnoe_mins ; here: used for fill between rows
heinrichsweikamp
parents:
diff changeset
758 movwf logbook_last_tp ; Initialise for Tp° curve too.
heinrichsweikamp
parents:
diff changeset
759
heinrichsweikamp
parents:
diff changeset
760 movlw LOW(-.100) ; Initialize max tp° to -10.0 °C.
heinrichsweikamp
parents:
diff changeset
761 movwf logbook_max_tp+0
heinrichsweikamp
parents:
diff changeset
762 movlw HIGH 0xFFFF & (-.100)
heinrichsweikamp
parents:
diff changeset
763 movwf logbook_max_tp+1
heinrichsweikamp
parents:
diff changeset
764
heinrichsweikamp
parents:
diff changeset
765 setf logbook_cur_tp+0 ; Initialize Tp°, before the first recorded point.
heinrichsweikamp
parents:
diff changeset
766 setf logbook_cur_tp+1
heinrichsweikamp
parents:
diff changeset
767 clrf logbook_last_tp ; Also reset previous Y for Tp°
heinrichsweikamp
parents:
diff changeset
768 clrf logbook_ceiling ; Ceiling = 0, correct value for no ceiling.
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
769 movlw profile_top+.1
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
770 movwf logbook_min_temp_pos ; Initialize for displaying the lowest temperature
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
771 movlw profile_top+profile_height_pixels
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
772 movwf logbook_max_temp_pos ; Initialize for displaying the highest temperature
0
heinrichsweikamp
parents:
diff changeset
773
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
774 movlw profile_left
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
775 movwf win_leftx2
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
776 movlw profile_top
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
777 movwf win_top
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
778 movlw profile_height_pixels
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
779 movwf win_height
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
780 movlw LOW (profile_width_pixels*.2)
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
781 movwf win_width+0
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
782 movlw HIGH (profile_width_pixels*.2)
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
783 movwf win_width+1
371
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
784 call TFT_box_write ; open box for d1
fec5eec4c8b7 fix some display issues with display1
heinrichsweikamp
parents: 343
diff changeset
785
434
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
786 ; INIT_PIXEL_WRITE logbook_pixel_x_pos ; pixel x2 (Also sets standard Color!)
0
heinrichsweikamp
parents:
diff changeset
787
heinrichsweikamp
parents:
diff changeset
788 profile_display_loop:
434
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
789 ; Init pixel write
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
790 movf logbook_pixel_x_pos,W
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
791 mullw 2
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
792 call pixel_write_col320
a001f170a1f7 hunting a bug in the logbook (Day 3)
heinrichsweikamp
parents: 433
diff changeset
793
0
heinrichsweikamp
parents:
diff changeset
794 movff profile_temp+0,profile_temp2+0
heinrichsweikamp
parents:
diff changeset
795 movff profile_temp+1,profile_temp2+1 ; 16Bit x-scaler
heinrichsweikamp
parents:
diff changeset
796 incf profile_temp2+1,F
heinrichsweikamp
parents:
diff changeset
797 tstfsz profile_temp2+0 ; Must not be Zero
heinrichsweikamp
parents:
diff changeset
798 bra profile_display_loop2 ; Not Zero!
heinrichsweikamp
parents:
diff changeset
799 incf profile_temp2+0,F ; Zero, Increase!
heinrichsweikamp
parents:
diff changeset
800
heinrichsweikamp
parents:
diff changeset
801 profile_display_loop2:
heinrichsweikamp
parents:
diff changeset
802 rcall profile_view_get_depth ; reads depth, temp and profile data
heinrichsweikamp
parents:
diff changeset
803
heinrichsweikamp
parents:
diff changeset
804 btfsc end_of_profile ; end-of profile reached?
heinrichsweikamp
parents:
diff changeset
805 bra profile_display_loop_done ; Yes, skip all remaining pixels
heinrichsweikamp
parents:
diff changeset
806
heinrichsweikamp
parents:
diff changeset
807
heinrichsweikamp
parents:
diff changeset
808 ;---- Draw Ceiling curve, if any ---------------------------------------------
heinrichsweikamp
parents:
diff changeset
809 movf divisor_deco,W
heinrichsweikamp
parents:
diff changeset
810 bz profile_display_skip_deco
heinrichsweikamp
parents:
diff changeset
811
heinrichsweikamp
parents:
diff changeset
812 movf logbook_ceiling,W ; Any deco ceiling ?
heinrichsweikamp
parents:
diff changeset
813 bz profile_display_skip_deco
heinrichsweikamp
parents:
diff changeset
814
heinrichsweikamp
parents:
diff changeset
815 mullw .100 ; Yes: convert to mbar
heinrichsweikamp
parents:
diff changeset
816 movff PRODL,sub_a+0
heinrichsweikamp
parents:
diff changeset
817 movff PRODH,sub_a+1
heinrichsweikamp
parents:
diff changeset
818 movff logbook_cur_depth+0,sub_b+0 ; Compare with UNSIGNED current depth (16bits)
heinrichsweikamp
parents:
diff changeset
819 movff logbook_cur_depth+1,sub_b+1
heinrichsweikamp
parents:
diff changeset
820 call subU16 ; set (or not) neg_flag
heinrichsweikamp
parents:
diff changeset
821
heinrichsweikamp
parents:
diff changeset
822 movlw color_dark_green ; Dark green if Ok,
heinrichsweikamp
parents:
diff changeset
823 btfss neg_flag
heinrichsweikamp
parents:
diff changeset
824 movlw color_dark_red ; Or dark red if ceiling overflown.
heinrichsweikamp
parents:
diff changeset
825 call TFT_set_color
heinrichsweikamp
parents:
diff changeset
826
heinrichsweikamp
parents:
diff changeset
827 movff PRODL,xA+0
heinrichsweikamp
parents:
diff changeset
828 movff PRODH,xA+1
heinrichsweikamp
parents:
diff changeset
829 movff y_scale+0,xB+0 ; devide pressure in mbar/quant for row offsett
heinrichsweikamp
parents:
diff changeset
830 movff y_scale+1,xB+1
heinrichsweikamp
parents:
diff changeset
831 call div16x16 ; xA/xB=xC
heinrichsweikamp
parents:
diff changeset
832
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
833 movlw profile_top+.1 ; Starts right after the top line.
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
834 movwf win_top
0
heinrichsweikamp
parents:
diff changeset
835 movff logbook_pixel_x_pos,win_leftx2 ; Left border (0-159)
heinrichsweikamp
parents:
diff changeset
836 movff xC+0,win_height
heinrichsweikamp
parents:
diff changeset
837 call half_vertical_line ; Inputs: win_top, win_leftx2, win_height, win_color1, win_color2
heinrichsweikamp
parents:
diff changeset
838
heinrichsweikamp
parents:
diff changeset
839 profile_display_skip_deco:
heinrichsweikamp
parents:
diff changeset
840 ;---- Draw Tp° curve, if any ---------------------------------------------
heinrichsweikamp
parents:
diff changeset
841 movf divisor_temperature,W
heinrichsweikamp
parents:
diff changeset
842 bz profile_display_skip_temp
heinrichsweikamp
parents:
diff changeset
843
heinrichsweikamp
parents:
diff changeset
844 movf logbook_cur_tp+0,W ; Did we had already a valid Tp°C record ?
heinrichsweikamp
parents:
diff changeset
845 andwf logbook_cur_tp+1,W
heinrichsweikamp
parents:
diff changeset
846 incf WREG
heinrichsweikamp
parents:
diff changeset
847 bz profile_display_skip_temp ; No: just skip drawing.
heinrichsweikamp
parents:
diff changeset
848
heinrichsweikamp
parents:
diff changeset
849 movlw LOW(((profile_height_pixels-.10)*.256)/.370) ; fixed tp° scale: (-2 .. +35°C * scale256 )/153pix
heinrichsweikamp
parents:
diff changeset
850 movwf xB+0
heinrichsweikamp
parents:
diff changeset
851 movlw HIGH(((profile_height_pixels-.10)*.256)/.370)
heinrichsweikamp
parents:
diff changeset
852 movwf xB+1
heinrichsweikamp
parents:
diff changeset
853
heinrichsweikamp
parents:
diff changeset
854 movf logbook_cur_tp+0,W ; Current Tp° - (-2.0°C) == Tp° + 20.
heinrichsweikamp
parents:
diff changeset
855 addlw LOW(.20) ; Low byte.
heinrichsweikamp
parents:
diff changeset
856 movwf xA+0
heinrichsweikamp
parents:
diff changeset
857 movf logbook_cur_tp+1,W
heinrichsweikamp
parents:
diff changeset
858 btfsc STATUS,C ; Propagate carry, if any
heinrichsweikamp
parents:
diff changeset
859 incf WREG
heinrichsweikamp
parents:
diff changeset
860 movwf xA+1
heinrichsweikamp
parents:
diff changeset
861 call mult16x16 ; xA*xB=xC
heinrichsweikamp
parents:
diff changeset
862
heinrichsweikamp
parents:
diff changeset
863 ; scale: divide by 256, ie. take just high byte.
heinrichsweikamp
parents:
diff changeset
864 movf xC+1,W
heinrichsweikamp
parents:
diff changeset
865 sublw profile_top+profile_height_pixels-.10 ; Upside-down: Y = .75 + (.153 - result)
heinrichsweikamp
parents:
diff changeset
866 movwf xC+0
heinrichsweikamp
parents:
diff changeset
867
heinrichsweikamp
parents:
diff changeset
868 ; Check limits
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
869 movlw profile_top+.1
0
heinrichsweikamp
parents:
diff changeset
870 movwf xC+1
heinrichsweikamp
parents:
diff changeset
871 cpfsgt xC+0
heinrichsweikamp
parents:
diff changeset
872 movff xC+1,xC+0
heinrichsweikamp
parents:
diff changeset
873
heinrichsweikamp
parents:
diff changeset
874 movlw color_orange
heinrichsweikamp
parents:
diff changeset
875 call TFT_set_color
heinrichsweikamp
parents:
diff changeset
876
heinrichsweikamp
parents:
diff changeset
877 movf logbook_last_tp,W ; do we have a valid previous value ?
heinrichsweikamp
parents:
diff changeset
878 bz profile_display_temp_1 ; No: skip the vertical line.
heinrichsweikamp
parents:
diff changeset
879 movwf xC+1
heinrichsweikamp
parents:
diff changeset
880 call profile_display_fill ; In this column between this row (xC+0) and the last row (xC+1)
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
881 profile_display_temp_1:
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
882 movf xC+0,W ; current row
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
883 cpfsgt logbook_min_temp_pos ; check limit
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
884 movwf logbook_min_temp_pos ; lowest row in the temp graph
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
885 cpfslt logbook_max_temp_pos ; check limit
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
886 movwf logbook_max_temp_pos ; lowest row in the temp graph
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
887
0
heinrichsweikamp
parents:
diff changeset
888 movff xC+0,logbook_last_tp
heinrichsweikamp
parents:
diff changeset
889 PIXEL_WRITE logbook_pixel_x_pos,xC+0 ; Set col(0..159) x row (0..239), put a current color pixel.
heinrichsweikamp
parents:
diff changeset
890
heinrichsweikamp
parents:
diff changeset
891 profile_display_skip_temp:
heinrichsweikamp
parents:
diff changeset
892 ;---- Draw depth curve ---------------------------------------------------
heinrichsweikamp
parents:
diff changeset
893 movff y_scale+0,xB+0 ; devide pressure in mbar/quant for row offsett
heinrichsweikamp
parents:
diff changeset
894 movff y_scale+1,xB+1
heinrichsweikamp
parents:
diff changeset
895 movff logbook_cur_depth+0,xA+0
heinrichsweikamp
parents:
diff changeset
896 movff logbook_cur_depth+1,xA+1
heinrichsweikamp
parents:
diff changeset
897 call div16x16 ; xA/xB=xC
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
898 movlw profile_top+.1
0
heinrichsweikamp
parents:
diff changeset
899 addwf xC+0,F ; add 75 pixel offset to result
heinrichsweikamp
parents:
diff changeset
900
heinrichsweikamp
parents:
diff changeset
901 btfsc STATUS,C ; Ignore potential profile errors
heinrichsweikamp
parents:
diff changeset
902 movff apnoe_mins,xC+0
heinrichsweikamp
parents:
diff changeset
903
heinrichsweikamp
parents:
diff changeset
904 rcall profile_display_color ; Back to normal profile color.
heinrichsweikamp
parents:
diff changeset
905
heinrichsweikamp
parents:
diff changeset
906 movff apnoe_mins,xC+1
heinrichsweikamp
parents:
diff changeset
907 call profile_display_fill ; In this column between this row (xC+0) and the last row (xC+1)
heinrichsweikamp
parents:
diff changeset
908 movff xC+0,apnoe_mins ; Store last row for fill routine
heinrichsweikamp
parents:
diff changeset
909
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
910 PIXEL_WRITE logbook_pixel_x_pos,xC+0 ; Set col(0..159) x row (0..239), put a std color pixel.
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
911 incf logbook_pixel_x_pos,F ; Next column
0
heinrichsweikamp
parents:
diff changeset
912
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
913 ;---- Draw Marker square , if any ----------------------------------------
435
0590b8fafc8d Logbook marker temporally disabled in internal logbook
heinrichsweikamp
parents: 434
diff changeset
914 ; btfss log_marker_found ; Any marker to draw? ; mH
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
915 bra profile_display_skip_marker ; No
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
916
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
917 ; 2x2 square
430
heinrichsweikamp
parents: 418
diff changeset
918 incf apnoe_mins,W ; increase row (Y)
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
919 movwf win_top
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
920 movlw .4
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
921 movwf win_height
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
922 movlw .2
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
923 movwf win_width+0
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
924 clrf win_width+1
430
heinrichsweikamp
parents: 418
diff changeset
925 decf logbook_pixel_x_pos,W ; decrease column (X)
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
926 movwf win_leftx2
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
927
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
928 movlw color_orange
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
929 call TFT_set_color
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
930 call TFT_box ; Draw 2x2 Box
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
931 bcf log_marker_found ; Clear flag
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
932
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
933 profile_display_skip_marker:
435
0590b8fafc8d Logbook marker temporally disabled in internal logbook
heinrichsweikamp
parents: 434
diff changeset
934 bcf log_marker_found ; Clear flag ; mH
0
heinrichsweikamp
parents:
diff changeset
935 ;---- Draw CNS curve, if any ---------------------------------------------
heinrichsweikamp
parents:
diff changeset
936 movf divisor_cns,W
heinrichsweikamp
parents:
diff changeset
937 bz profile_display_skip_cns
heinrichsweikamp
parents:
diff changeset
938 ;
heinrichsweikamp
parents:
diff changeset
939 ; TODO HERE
heinrichsweikamp
parents:
diff changeset
940 ;
heinrichsweikamp
parents:
diff changeset
941 profile_display_skip_cns:
heinrichsweikamp
parents:
diff changeset
942
heinrichsweikamp
parents:
diff changeset
943 ;---- Draw GF curve, if any ----------------------------------------------
heinrichsweikamp
parents:
diff changeset
944 movf divisor_gf,W
heinrichsweikamp
parents:
diff changeset
945 bz profile_display_skip_gf
heinrichsweikamp
parents:
diff changeset
946 ;
heinrichsweikamp
parents:
diff changeset
947 ; TODO HERE
heinrichsweikamp
parents:
diff changeset
948 ;
heinrichsweikamp
parents:
diff changeset
949 profile_display_skip_gf:
heinrichsweikamp
parents:
diff changeset
950
heinrichsweikamp
parents:
diff changeset
951 ;---- All curves done.
heinrichsweikamp
parents:
diff changeset
952
heinrichsweikamp
parents:
diff changeset
953 profile_display_skip_loop1: ; skips readings!
heinrichsweikamp
parents:
diff changeset
954 dcfsnz profile_temp2+0,F
heinrichsweikamp
parents:
diff changeset
955 bra profile_display_loop3 ; check 16bit....
heinrichsweikamp
parents:
diff changeset
956
heinrichsweikamp
parents:
diff changeset
957 rcall profile_view_get_depth ; reads depth, temp and profile data
168
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
958
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
959 btfsc end_of_profile ; end-of profile reached?
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
960 bra profile_display_loop_done ; Yes, skip all remaining pixels
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
961
0
heinrichsweikamp
parents:
diff changeset
962 bra profile_display_skip_loop1
heinrichsweikamp
parents:
diff changeset
963
heinrichsweikamp
parents:
diff changeset
964 profile_display_loop3:
heinrichsweikamp
parents:
diff changeset
965 decfsz profile_temp2+1,F ; 16 bit x-scaler test
heinrichsweikamp
parents:
diff changeset
966 bra profile_display_skip_loop1 ; skips readings!
heinrichsweikamp
parents:
diff changeset
967
heinrichsweikamp
parents:
diff changeset
968 decfsz ignore_digits,F ; counts drawn x-pixels to zero
heinrichsweikamp
parents:
diff changeset
969 bra profile_display_loop ; Not ready yet
heinrichsweikamp
parents:
diff changeset
970 ; Done.
heinrichsweikamp
parents:
diff changeset
971
heinrichsweikamp
parents:
diff changeset
972 display_profile_no_profile: ; No profile available for this dive!
heinrichsweikamp
parents:
diff changeset
973
heinrichsweikamp
parents:
diff changeset
974 profile_display_loop_done:
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
975 btfss is_bailout ; Bailout during the dive?
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
976 bra profile_display_loop_done_nobail ; No
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
977 ; Yes, show "Bailout"
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
978 movlw color_pink
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
979 call TFT_set_color
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
980 WIN_TINY logbook_bailout_column,logbook_bailout_row
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
981 STRCPY_TEXT_PRINT tDiveBailout ; Bailout
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
982 profile_display_loop_done_nobail:
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
983 btfss gas6_changed ; Gas6
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
984 bra profile_display_loop_done_nogas6 ; No
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
985 ; Yes, show "Gas 6!"
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
986 movlw color_pink
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
987 call TFT_set_color
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
988 WIN_TINY logbook_bailout_column,logbook_bailout_row-.15
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
989 STRCPY_TEXT tGas ; Gas
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
990 STRCAT_PRINT " 6!"
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
991
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
992 profile_display_loop_done_nogas6:
0
heinrichsweikamp
parents:
diff changeset
993 decf divesecs,F ;-1
heinrichsweikamp
parents:
diff changeset
994 read_int_eeprom .2
heinrichsweikamp
parents:
diff changeset
995 movf EEDATA,W
heinrichsweikamp
parents:
diff changeset
996 bcf STATUS,C
heinrichsweikamp
parents:
diff changeset
997 subfwb divesecs,W ; max. dives (low value) - divesecs
heinrichsweikamp
parents:
diff changeset
998 movwf lo ; result
heinrichsweikamp
parents:
diff changeset
999 incf divesecs,F ;+1
heinrichsweikamp
parents:
diff changeset
1000 ; Set ext_flash_address:3 to TOC entry of this dive
heinrichsweikamp
parents:
diff changeset
1001 ; 1st: 200000h-200FFFh -> lo=0
heinrichsweikamp
parents:
diff changeset
1002 ; 2nd: 201000h-201FFFh -> lo=1
heinrichsweikamp
parents:
diff changeset
1003 ; 3rd: 202000h-202FFFh -> lo=2
heinrichsweikamp
parents:
diff changeset
1004 ; 256: 2FF000h-2FFFFFh -> lo=255 (And hi>0...)
heinrichsweikamp
parents:
diff changeset
1005 clrf ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
1006 clrf ext_flash_address+1
heinrichsweikamp
parents:
diff changeset
1007 movlw 0x20
heinrichsweikamp
parents:
diff changeset
1008 movwf ext_flash_address+2
heinrichsweikamp
parents:
diff changeset
1009 movlw .16
heinrichsweikamp
parents:
diff changeset
1010 mulwf lo ; lo*16 = offset to 0x2000 (up:hi)
heinrichsweikamp
parents:
diff changeset
1011 movf PRODL,W
heinrichsweikamp
parents:
diff changeset
1012 addwf ext_flash_address+1,F
heinrichsweikamp
parents:
diff changeset
1013 movf PRODH,W
heinrichsweikamp
parents:
diff changeset
1014 addwfc ext_flash_address+2,F
heinrichsweikamp
parents:
diff changeset
1015 ; pointer at the first 0xFA of header
heinrichsweikamp
parents:
diff changeset
1016
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1017 movff logbook_min_temp_pos,win_top ; Y position at lowest temperature
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1018 movff logbook_pixel_x_pos,win_leftx2
0
heinrichsweikamp
parents:
diff changeset
1019 movlw .130
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1020 cpfslt win_leftx2 ; limit left border to 130
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1021 movwf win_leftx2
0
heinrichsweikamp
parents:
diff changeset
1022 WIN_FONT FT_TINY
heinrichsweikamp
parents:
diff changeset
1023 movlw color_orange ; Use same color as tp° curve
heinrichsweikamp
parents:
diff changeset
1024 call TFT_set_color
heinrichsweikamp
parents:
diff changeset
1025
heinrichsweikamp
parents:
diff changeset
1026 movff logbook_min_tp+0,lo
heinrichsweikamp
parents:
diff changeset
1027 movff logbook_min_tp+1,hi
heinrichsweikamp
parents:
diff changeset
1028 lfsr FSR2,buffer
heinrichsweikamp
parents:
diff changeset
1029
heinrichsweikamp
parents:
diff changeset
1030 TSTOSS opt_units ; 0=°C, 1=°F
heinrichsweikamp
parents:
diff changeset
1031 bra logbook_show_temp_metric
heinrichsweikamp
parents:
diff changeset
1032 ;logbook_show_temp_imperial:
heinrichsweikamp
parents:
diff changeset
1033 call TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required
heinrichsweikamp
parents:
diff changeset
1034 call convert_celsius_to_fahrenheit ; convert value in lo:hi from celsius to fahrenheit
heinrichsweikamp
parents:
diff changeset
1035 lfsr FSR2,buffer ; Overwrite "-"
heinrichsweikamp
parents:
diff changeset
1036 bsf ignore_digit5 ; Full degrees only
heinrichsweikamp
parents:
diff changeset
1037 output_16
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1038 STRCAT_TEXT_PRINT tLogTunitF
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1039 ; Now, the max. temperature
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1040 movlw .15
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1041 subwf logbook_max_temp_pos,W
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1042 movff WREG,win_top ; Y position at max temperature
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1043 movff logbook_max_tp+0,lo
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1044 movff logbook_max_tp+1,hi
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1045 lfsr FSR2,buffer
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1046 call TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1047 call convert_celsius_to_fahrenheit ; convert value in lo:hi from celsius to fahrenheit
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1048 output_16
0
heinrichsweikamp
parents:
diff changeset
1049 bcf ignore_digit5
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1050 STRCAT_TEXT_PRINT tLogTunitF
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1051
0
heinrichsweikamp
parents:
diff changeset
1052 bra logbook_show_temp_common
heinrichsweikamp
parents:
diff changeset
1053
heinrichsweikamp
parents:
diff changeset
1054 logbook_show_temp_metric:
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1055 call TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1056 movlw d'3'
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1057 movwf ignore_digits
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1058 bsf leftbind
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1059 output_16dp d'2' ; temperature
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1060 STRCAT_TEXT_PRINT tLogTunitC
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1061 ; Now, the max. temperature
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1062 movlw .15
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1063 subwf logbook_max_temp_pos,W
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1064 movwf win_top ; Y position at max temperature
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1065 movff logbook_max_tp+0,lo
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1066 movff logbook_max_tp+1,hi
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1067 lfsr FSR2,buffer
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1068 call TFT_convert_signed_16bit ; converts lo:hi into signed-short and adds '-' to POSTINC2 if required
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1069 movlw d'3'
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1070 movwf ignore_digits
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1071 bsf leftbind
0
heinrichsweikamp
parents:
diff changeset
1072 output_16dp d'2' ; temperature
heinrichsweikamp
parents:
diff changeset
1073 STRCAT_TEXT_PRINT tLogTunitC
heinrichsweikamp
parents:
diff changeset
1074
heinrichsweikamp
parents:
diff changeset
1075 logbook_show_temp_common:
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1076
50
ec4d8503ec45 NEW: user-selectable color schemes
heinrichsweikamp
parents: 25
diff changeset
1077 bcf leftbind
ec4d8503ec45 NEW: user-selectable color schemes
heinrichsweikamp
parents: 25
diff changeset
1078 call TFT_standard_color
0
heinrichsweikamp
parents:
diff changeset
1079
heinrichsweikamp
parents:
diff changeset
1080 ; Get pointer to Gaslist
heinrichsweikamp
parents:
diff changeset
1081 LOG_POINT_TO log_gas1
heinrichsweikamp
parents:
diff changeset
1082
heinrichsweikamp
parents:
diff changeset
1083 movlw color_white ; Color for Gas 1
heinrichsweikamp
parents:
diff changeset
1084 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1085 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1086 WIN_TINY log_gas_column1, log_gas_row
heinrichsweikamp
parents:
diff changeset
1087 rcall log_show_gas_common
heinrichsweikamp
parents:
diff changeset
1088
heinrichsweikamp
parents:
diff changeset
1089 movlw color_green ; Color for Gas 2
heinrichsweikamp
parents:
diff changeset
1090 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1091 WIN_TINY log_gas_column2, log_gas_row
heinrichsweikamp
parents:
diff changeset
1092 rcall log_show_gas_common
heinrichsweikamp
parents:
diff changeset
1093
heinrichsweikamp
parents:
diff changeset
1094 movlw color_red ; Color for Gas 3
heinrichsweikamp
parents:
diff changeset
1095 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1096 WIN_TINY log_gas_column3, log_gas_row
heinrichsweikamp
parents:
diff changeset
1097 rcall log_show_gas_common
heinrichsweikamp
parents:
diff changeset
1098
heinrichsweikamp
parents:
diff changeset
1099 movlw color_yellow ; Color for Gas 4
heinrichsweikamp
parents:
diff changeset
1100 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1101 WIN_TINY log_gas_column4, log_gas_row
heinrichsweikamp
parents:
diff changeset
1102 rcall log_show_gas_common
heinrichsweikamp
parents:
diff changeset
1103
heinrichsweikamp
parents:
diff changeset
1104 movlw color_cyan ; Color for Gas 5
heinrichsweikamp
parents:
diff changeset
1105 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1106 WIN_TINY log_gas_column5, log_gas_row
heinrichsweikamp
parents:
diff changeset
1107 rcall log_show_gas_common
heinrichsweikamp
parents:
diff changeset
1108
heinrichsweikamp
parents:
diff changeset
1109 rcall logbook_preloop_tasks ; Clear some flags and set to Speed_eco
heinrichsweikamp
parents:
diff changeset
1110 display_profile_loop:
heinrichsweikamp
parents:
diff changeset
1111 btfsc switch_left ; SET/MENU?
heinrichsweikamp
parents:
diff changeset
1112 bra logbook_page2 ; Show more information
heinrichsweikamp
parents:
diff changeset
1113 btfsc switch_right ; ENTER?
heinrichsweikamp
parents:
diff changeset
1114 bra exit_profileview ; back to list
heinrichsweikamp
parents:
diff changeset
1115
heinrichsweikamp
parents:
diff changeset
1116 rcall log_screendump_and_onesecond ; Check if we need to make a screenshot and check for new second
heinrichsweikamp
parents:
diff changeset
1117 btfsc sleepmode ; Timeout?
heinrichsweikamp
parents:
diff changeset
1118 bra exit_profileview ; back to list
heinrichsweikamp
parents:
diff changeset
1119 bra display_profile_loop ; wait for something to do
heinrichsweikamp
parents:
diff changeset
1120
heinrichsweikamp
parents:
diff changeset
1121 global log_screendump_and_onesecond
heinrichsweikamp
parents:
diff changeset
1122 log_screendump_and_onesecond: ; Check if we need to make a screenshot and check for new second
heinrichsweikamp
parents:
diff changeset
1123 btfsc onesecupdate
heinrichsweikamp
parents:
diff changeset
1124 call timeout_surfmode ; Timeout
heinrichsweikamp
parents:
diff changeset
1125 btfsc onesecupdate
heinrichsweikamp
parents:
diff changeset
1126 call set_dive_modes ; Check, if divemode must be entered
heinrichsweikamp
parents:
diff changeset
1127 bcf onesecupdate ; one second update
heinrichsweikamp
parents:
diff changeset
1128 btfsc divemode
heinrichsweikamp
parents:
diff changeset
1129 goto restart ; Enter Divemode if required
heinrichsweikamp
parents:
diff changeset
1130
heinrichsweikamp
parents:
diff changeset
1131 btfsc enable_screen_dumps ; =1: Ignore vin_usb, wait for "l" command (Screen dump)
heinrichsweikamp
parents:
diff changeset
1132 bra log_screendump_and_onesecond2
heinrichsweikamp
parents:
diff changeset
1133 btfsc vusb_in ; USB plugged in?
113
heinrichsweikamp
parents: 99
diff changeset
1134 call comm_mode ; Start COMM mode
0
heinrichsweikamp
parents:
diff changeset
1135 return
heinrichsweikamp
parents:
diff changeset
1136 log_screendump_and_onesecond2:
heinrichsweikamp
parents:
diff changeset
1137 btfss vusb_in ; USB (still) plugged in?
heinrichsweikamp
parents:
diff changeset
1138 bcf enable_screen_dumps ; No, clear flag
heinrichsweikamp
parents:
diff changeset
1139 call rs232_get_byte
heinrichsweikamp
parents:
diff changeset
1140 btfsc rs232_recieve_overflow
heinrichsweikamp
parents:
diff changeset
1141 return
heinrichsweikamp
parents:
diff changeset
1142 movlw "l"
heinrichsweikamp
parents:
diff changeset
1143 cpfseq RCREG1
heinrichsweikamp
parents:
diff changeset
1144 return
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1145 goto TFT_dump_screen ; Dump the screen contents and return
0
heinrichsweikamp
parents:
diff changeset
1146
heinrichsweikamp
parents:
diff changeset
1147 log_show_gas_common:
heinrichsweikamp
parents:
diff changeset
1148 extern customview_show_mix
heinrichsweikamp
parents:
diff changeset
1149 lfsr FSR2,buffer
heinrichsweikamp
parents:
diff changeset
1150 call ext_flash_byte_read_plus ; Gas2 current O2
heinrichsweikamp
parents:
diff changeset
1151 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1152 call ext_flash_byte_read_plus ; Gas2 current He
heinrichsweikamp
parents:
diff changeset
1153 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1154 call customview_show_mix ; Put "Nxlo", "Txlo/hi", "Air" or "O2" into Postinc2
heinrichsweikamp
parents:
diff changeset
1155 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
1156 call ext_flash_byte_read_plus ; Gas2 change depth
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1157 goto ext_flash_byte_read_plus ; Gas2 Type and return
0
heinrichsweikamp
parents:
diff changeset
1158
heinrichsweikamp
parents:
diff changeset
1159 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
1160 profile_display_color:
heinrichsweikamp
parents:
diff changeset
1161 movff average_depth_hold_total+3,active_gas ; Restore gas color.
heinrichsweikamp
parents:
diff changeset
1162 movlw color_white ; Default color
heinrichsweikamp
parents:
diff changeset
1163 dcfsnz active_gas,F
heinrichsweikamp
parents:
diff changeset
1164 movlw color_white ; Color for Gas 1
heinrichsweikamp
parents:
diff changeset
1165 dcfsnz active_gas,F
heinrichsweikamp
parents:
diff changeset
1166 movlw color_green ; Color for Gas 2
heinrichsweikamp
parents:
diff changeset
1167 dcfsnz active_gas,F
heinrichsweikamp
parents:
diff changeset
1168 movlw color_red ; Color for Gas 3
heinrichsweikamp
parents:
diff changeset
1169 dcfsnz active_gas,F
heinrichsweikamp
parents:
diff changeset
1170 movlw color_yellow ; Color for Gas 4
heinrichsweikamp
parents:
diff changeset
1171 dcfsnz active_gas,F
heinrichsweikamp
parents:
diff changeset
1172 movlw color_cyan ; Color for Gas 5
heinrichsweikamp
parents:
diff changeset
1173 dcfsnz active_gas,F
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1174 movlw color_pink ; Color for Gas 6
0
heinrichsweikamp
parents:
diff changeset
1175 goto TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1176
heinrichsweikamp
parents:
diff changeset
1177 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
1178 ; Draw a vertical line between xC+1 and xC+0, at current X position.
heinrichsweikamp
parents:
diff changeset
1179 ;
heinrichsweikamp
parents:
diff changeset
1180 ; Note: should keep xC+0
heinrichsweikamp
parents:
diff changeset
1181 ; Note: ascending or descending !
heinrichsweikamp
parents:
diff changeset
1182 ;
heinrichsweikamp
parents:
diff changeset
1183 profile_display_fill:
heinrichsweikamp
parents:
diff changeset
1184 ; First, check if xC+0>apnoe_mins or xC+0<aponoe_mins
heinrichsweikamp
parents:
diff changeset
1185 movf xC+0,W
heinrichsweikamp
parents:
diff changeset
1186 cpfseq xC+1 ; xC+0 = apone_mins?
heinrichsweikamp
parents:
diff changeset
1187 bra profile_display_fill2 ; No!
heinrichsweikamp
parents:
diff changeset
1188 return
heinrichsweikamp
parents:
diff changeset
1189
heinrichsweikamp
parents:
diff changeset
1190 profile_display_fill2:
heinrichsweikamp
parents:
diff changeset
1191 ; Make sure to init X position.
heinrichsweikamp
parents:
diff changeset
1192 movf logbook_pixel_x_pos,W
heinrichsweikamp
parents:
diff changeset
1193 mullw 2
heinrichsweikamp
parents:
diff changeset
1194 decf PRODL,F
heinrichsweikamp
parents:
diff changeset
1195 movlw 0
heinrichsweikamp
parents:
diff changeset
1196 subwfb PRODH,F
heinrichsweikamp
parents:
diff changeset
1197 call pixel_write_col320
heinrichsweikamp
parents:
diff changeset
1198
heinrichsweikamp
parents:
diff changeset
1199 movf xC+0,W
heinrichsweikamp
parents:
diff changeset
1200 cpfsgt xC+1 ; apnoe_mins>xC+0?
heinrichsweikamp
parents:
diff changeset
1201 bra profile_display_fill_up ; Yes!
heinrichsweikamp
parents:
diff changeset
1202
heinrichsweikamp
parents:
diff changeset
1203 profile_display_fill_down2: ; Loop
heinrichsweikamp
parents:
diff changeset
1204 decf xC+1,F
heinrichsweikamp
parents:
diff changeset
1205
heinrichsweikamp
parents:
diff changeset
1206 HALF_PIXEL_WRITE xC+1 ; Updates just row (0..239)
heinrichsweikamp
parents:
diff changeset
1207
heinrichsweikamp
parents:
diff changeset
1208 movf xC+0,W
heinrichsweikamp
parents:
diff changeset
1209 cpfseq xC+1 ; Loop until xC+1=xC+0
heinrichsweikamp
parents:
diff changeset
1210 bra profile_display_fill_down2
heinrichsweikamp
parents:
diff changeset
1211 return ; apnoe_mins and xC+0 are untouched
heinrichsweikamp
parents:
diff changeset
1212
heinrichsweikamp
parents:
diff changeset
1213 profile_display_fill_up: ; Fill upwards from xC+0 to apone_mins!
heinrichsweikamp
parents:
diff changeset
1214 incf xC+1,F
heinrichsweikamp
parents:
diff changeset
1215
heinrichsweikamp
parents:
diff changeset
1216 HALF_PIXEL_WRITE xC+1 ; Updates just row (0..239)
heinrichsweikamp
parents:
diff changeset
1217
heinrichsweikamp
parents:
diff changeset
1218 movf xC+0,W
heinrichsweikamp
parents:
diff changeset
1219 cpfseq xC+1 ; Loop until xC+1=apnoe_mins
heinrichsweikamp
parents:
diff changeset
1220 bra profile_display_fill_up
heinrichsweikamp
parents:
diff changeset
1221 return ; apnoe_mins and xC+0 are untouched
heinrichsweikamp
parents:
diff changeset
1222
heinrichsweikamp
parents:
diff changeset
1223 ;=============================================================================
heinrichsweikamp
parents:
diff changeset
1224
heinrichsweikamp
parents:
diff changeset
1225
heinrichsweikamp
parents:
diff changeset
1226 profile_view_get_depth:
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1227 infsnz logbook_sample_counter+0,F
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1228 incf logbook_sample_counter+1,F ; Count read pixels
0
heinrichsweikamp
parents:
diff changeset
1229
heinrichsweikamp
parents:
diff changeset
1230 movf logbook_sample_counter+0,W
heinrichsweikamp
parents:
diff changeset
1231 cpfseq average_depth_hold_total+0
heinrichsweikamp
parents:
diff changeset
1232 bra profile_view_get_depth_no_line ; no need to draw a 10min line, continue
heinrichsweikamp
parents:
diff changeset
1233 movf logbook_sample_counter+1,W
heinrichsweikamp
parents:
diff changeset
1234 cpfseq average_depth_hold_total+1
heinrichsweikamp
parents:
diff changeset
1235 bra profile_view_get_depth_no_line ; no need to draw a 10min line, continue
heinrichsweikamp
parents:
diff changeset
1236 ; draw a new 10min line here...
heinrichsweikamp
parents:
diff changeset
1237 clrf logbook_sample_counter+0
heinrichsweikamp
parents:
diff changeset
1238 clrf logbook_sample_counter+1 ; clear counting registers for next line
heinrichsweikamp
parents:
diff changeset
1239
heinrichsweikamp
parents:
diff changeset
1240 ; Vertical lines...
heinrichsweikamp
parents:
diff changeset
1241 movlw color_deepblue
heinrichsweikamp
parents:
diff changeset
1242 call TFT_set_color ; Make this configurable?
heinrichsweikamp
parents:
diff changeset
1243 movlw profile_top+.1
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1244 movwf win_top
0
heinrichsweikamp
parents:
diff changeset
1245 incf logbook_pixel_x_pos,W ; draw one line to right to make sure it's the background of the profile
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1246 movwf win_leftx2 ; Left border (0-159)
0
heinrichsweikamp
parents:
diff changeset
1247 movlw profile_height_pixels
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1248 movwf win_height
0
heinrichsweikamp
parents:
diff changeset
1249 movlw profile_height_pixels
432
929feb0da4f5 hunting a bug in the logbook (Day 2)
heinrichsweikamp
parents: 430
diff changeset
1250 movwf win_width ; "Window" height
0
heinrichsweikamp
parents:
diff changeset
1251 call half_horizontal_line ; Inputs: win_top, win_leftx2, win_width, win_color1, win_color2
heinrichsweikamp
parents:
diff changeset
1252
heinrichsweikamp
parents:
diff changeset
1253 profile_view_get_depth_no_line:
heinrichsweikamp
parents:
diff changeset
1254 call ext_flash_byte_read_plus_0x20 ; read depth first
heinrichsweikamp
parents:
diff changeset
1255 movff temp1,logbook_cur_depth+0 ; low value
heinrichsweikamp
parents:
diff changeset
1256 call ext_flash_byte_read_plus_0x20 ; read depth first
heinrichsweikamp
parents:
diff changeset
1257 movff temp1,logbook_cur_depth+1 ; high value
heinrichsweikamp
parents:
diff changeset
1258 call ext_flash_byte_read_plus_0x20 ; read Profile Flag Byte
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1259 movff temp1,timeout_counter2 ; store Profile Flag Byte
0
heinrichsweikamp
parents:
diff changeset
1260
heinrichsweikamp
parents:
diff changeset
1261 bcf event_occured ; clear flag
heinrichsweikamp
parents:
diff changeset
1262 btfsc timeout_counter2,7
heinrichsweikamp
parents:
diff changeset
1263 bsf event_occured ; We also have an Event byte!
heinrichsweikamp
parents:
diff changeset
1264 bcf timeout_counter2,7 ; Clear Event Byte Flag (If any)
heinrichsweikamp
parents:
diff changeset
1265 ; timeout_counter2 now holds the number of additional bytes to ignore (0-127)
heinrichsweikamp
parents:
diff changeset
1266 movlw 0xFD ; end of profile bytes?
heinrichsweikamp
parents:
diff changeset
1267 cpfseq logbook_cur_depth+0
heinrichsweikamp
parents:
diff changeset
1268 bra profile_view_get_depth_new1 ; no 1st. 0xFD
heinrichsweikamp
parents:
diff changeset
1269 cpfseq logbook_cur_depth+1
heinrichsweikamp
parents:
diff changeset
1270 bra profile_view_get_depth_new1 ; no 2nd. 0xFD
heinrichsweikamp
parents:
diff changeset
1271 bsf end_of_profile ; End found! Set Flag! Skip remaining pixels!
heinrichsweikamp
parents:
diff changeset
1272 return
heinrichsweikamp
parents:
diff changeset
1273
heinrichsweikamp
parents:
diff changeset
1274 profile_view_get_depth_new1:
heinrichsweikamp
parents:
diff changeset
1275 btfsc event_occured ; Was there an event attached to this sample?
168
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1276 rcall profile_view_get_depth_events ; Yes, get information about this event(s)
0
heinrichsweikamp
parents:
diff changeset
1277
heinrichsweikamp
parents:
diff changeset
1278 ;---- Read Tp°, if any AND divisor reached AND bytes available -----------
heinrichsweikamp
parents:
diff changeset
1279 movf divisor_temperature,W ; Is Tp° divisor null ?
heinrichsweikamp
parents:
diff changeset
1280 bz profile_view_get_depth_no_tp; Yes: no Tp° curve.
heinrichsweikamp
parents:
diff changeset
1281 decf count_temperature,F ; Decrement tp° counter
heinrichsweikamp
parents:
diff changeset
1282 bnz profile_view_get_depth_no_tp; No temperature this time
heinrichsweikamp
parents:
diff changeset
1283
heinrichsweikamp
parents:
diff changeset
1284 call ext_flash_byte_read_plus_0x20 ; Tp° low
heinrichsweikamp
parents:
diff changeset
1285 decf timeout_counter2,F
heinrichsweikamp
parents:
diff changeset
1286 movff temp1,logbook_cur_tp+0
heinrichsweikamp
parents:
diff changeset
1287 call ext_flash_byte_read_plus_0x20 ; Tp° high
heinrichsweikamp
parents:
diff changeset
1288 decf timeout_counter2,F
heinrichsweikamp
parents:
diff changeset
1289 movff temp1,logbook_cur_tp+1
heinrichsweikamp
parents:
diff changeset
1290 movff divisor_temperature,count_temperature ; Restart counter.
heinrichsweikamp
parents:
diff changeset
1291
heinrichsweikamp
parents:
diff changeset
1292 ; Compute Tp° max on the fly...
heinrichsweikamp
parents:
diff changeset
1293 movff logbook_cur_tp+0,sub_a+0 ; Compare cur_tp > max_tp ?
heinrichsweikamp
parents:
diff changeset
1294 movff logbook_cur_tp+1,sub_a+1
heinrichsweikamp
parents:
diff changeset
1295 movff logbook_max_tp+0,sub_b+0
heinrichsweikamp
parents:
diff changeset
1296 movff logbook_max_tp+1,sub_b+1
heinrichsweikamp
parents:
diff changeset
1297 call sub16 ; SIGNED sub_a - sub_b
heinrichsweikamp
parents:
diff changeset
1298 btfsc neg_flag
heinrichsweikamp
parents:
diff changeset
1299 bra profile_view_get_depth_no_tp
162
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1300
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1301 ; store max. temp only below start_dive_threshold (1,0m)
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1302 tstfsz logbook_cur_depth+1 ; > 2,56m?
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1303 bra profile_view_compute_max_temp ; Yes, include in max. temp measurement
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1304 movlw start_dive_threshold ; 1,0m
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1305 cpfsgt logbook_cur_depth+0 ; low value
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1306 bra profile_view_get_depth_no_tp ; above 1,0m, ignore temp
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1307
95d05cc14736 NEW: Safe tissue data, date and time during firmware update
heinrichsweikamp
parents: 124
diff changeset
1308 profile_view_compute_max_temp:
0
heinrichsweikamp
parents:
diff changeset
1309 movff logbook_cur_tp+0,logbook_max_tp+0
heinrichsweikamp
parents:
diff changeset
1310 movff logbook_cur_tp+1,logbook_max_tp+1
heinrichsweikamp
parents:
diff changeset
1311
heinrichsweikamp
parents:
diff changeset
1312 ;---- Read deco, if any AND divisor=0 AND bytes available ----------------
heinrichsweikamp
parents:
diff changeset
1313 profile_view_get_depth_no_tp:
heinrichsweikamp
parents:
diff changeset
1314 movf divisor_deco,W
heinrichsweikamp
parents:
diff changeset
1315 bz profile_view_get_depth_no_deco
heinrichsweikamp
parents:
diff changeset
1316 decf count_deco,F
heinrichsweikamp
parents:
diff changeset
1317 bnz profile_view_get_depth_no_deco
heinrichsweikamp
parents:
diff changeset
1318
heinrichsweikamp
parents:
diff changeset
1319 call ext_flash_byte_read_plus_0x20
heinrichsweikamp
parents:
diff changeset
1320 decf timeout_counter2,F
heinrichsweikamp
parents:
diff changeset
1321 movff temp1,logbook_ceiling
heinrichsweikamp
parents:
diff changeset
1322 movff divisor_deco,count_deco ; Restart counter.
168
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1323 call ext_flash_byte_read_plus_0x20 ; Skip stop length
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1324 decf timeout_counter2,F
0
heinrichsweikamp
parents:
diff changeset
1325
heinrichsweikamp
parents:
diff changeset
1326 ;---- Read GF, if any AND divisor=0 AND bytes available ------------------
heinrichsweikamp
parents:
diff changeset
1327 profile_view_get_depth_no_deco:
heinrichsweikamp
parents:
diff changeset
1328 ; Then skip remaining bytes...
heinrichsweikamp
parents:
diff changeset
1329 movf timeout_counter2,W ; number of additional bytes to ignore (0-127)
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1330 tstfsz timeout_counter2 ; Anything to skip?
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1331 call incf_ext_flash_address0_0x20; Yes, increases bytes in ext_flash_address:3 with 0x200000 bank switching
0
heinrichsweikamp
parents:
diff changeset
1332 return
heinrichsweikamp
parents:
diff changeset
1333
168
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1334 profile_view_get_depth_events:
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1335 clrf EventByte2 ; Clear EventByte2
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1336 call ext_flash_byte_read_plus_0x20 ; Read Event byte
0
heinrichsweikamp
parents:
diff changeset
1337 movff temp1,EventByte ; store EventByte
heinrichsweikamp
parents:
diff changeset
1338 decf timeout_counter2,F ; reduce counter
98
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1339
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1340 btfss EventByte,7 ; Another Event byte?
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1341 bra profile_no_second_eventbyte ; No
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1342 call ext_flash_byte_read_plus_0x20; Read Event byte2
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1343 movff temp1,EventByte2 ; store EventByte2
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1344 decf timeout_counter2,F ; reduce counter
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1345 bcf EventByte,7 ; Clear flag
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1346
24b3fd59e61f add event "bailout" in profile
heinrichsweikamp
parents: 89
diff changeset
1347 profile_no_second_eventbyte:
168
1784ab9362ca BUGFIX: False max. temp in Logbook, false Bailout and Gas 6 flags in logbook
heinrichsweikamp
parents: 167
diff changeset
1348 ; Check event flags in the EventBytes
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1349 btfsc EventByte,4 ; Manual Gas Changed?
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1350 rcall logbook_event1 ; Yes!
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1351 btfsc EventByte,5 ; Stored Gas Changed?
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1352 rcall logbook_event4 ; Yes!
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1353 btfsc EventByte,6 ; Setpoint Change?
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1354 rcall logbook_event3 ; Yes!
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1355 btfsc EventByte2,0 ; Bailout?
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1356 rcall logbook_event2 ; Yes!
402
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1357 ; Any Alarm?
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1358 bcf EventByte,4 ; Clear bits already tested
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1359 bcf EventByte,5
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1360 bcf EventByte,6
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1361 movlw .6 ; manual marker?
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1362 cpfseq EventByte
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1363 return ; No, return
a3a0f1fd7fc4 NEW: Logbook shows markers with small orange boxes in the profile
heinrichsweikamp
parents: 392
diff changeset
1364 bsf log_marker_found ; Manual marker! Draw small yellow rectancle here
163
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1365 return
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1366
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1367 logbook_event4: ; Stored Gas changed!
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1368 call ext_flash_byte_read_plus_0x20 ; Read Gas#
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1369 decf timeout_counter2,F ; reduce counter
0
heinrichsweikamp
parents:
diff changeset
1370 movff temp1,average_depth_hold_total+3
163
4d71549dcf6c clarify diluent change in the documentation
heinrichsweikamp
parents: 162
diff changeset
1371 rcall profile_display_color ; Change profile color according to gas number
0
heinrichsweikamp
parents:
diff changeset
1372 return
heinrichsweikamp
parents:
diff changeset
1373
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1374 logbook_event1: ; Gas6 changed
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1375 bsf gas6_changed
0
heinrichsweikamp
parents:
diff changeset
1376 movlw 6 ; Just color backup to 6
heinrichsweikamp
parents:
diff changeset
1377 movwf average_depth_hold_total+3
heinrichsweikamp
parents:
diff changeset
1378 rcall profile_display_color ; Back to normal profile color.
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1379 incf_ext_flash_address_0x20 .2 ; Skip two bytes
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1380 decf timeout_counter2,F ; reduce counter
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1381 decf timeout_counter2,F ; reduce counter
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1382 return
0
heinrichsweikamp
parents:
diff changeset
1383
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1384 logbook_event2: ; Bailout
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1385 bsf is_bailout ; Set flag
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1386 movff average_depth_hold_total+3,total_divetime_seconds+0 ; Backup last gas color in case we return to CCR
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1387 movlw 6 ; Use Gas6 color
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1388 movwf average_depth_hold_total+3
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1389 rcall profile_display_color ; Back to normal profile color.
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1390 incf_ext_flash_address_0x20 .2 ; Skip two bytes
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1391 decf timeout_counter2,F ; reduce counter
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1392 decf timeout_counter2,F ; reduce counter
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1393 return
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1394
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1395 logbook_event3: ; Setpoint change
167
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1396 incf_ext_flash_address_0x20 .1 ; Skip one byte
05f2100d2eb8 logbook
heinrichsweikamp
parents: 163
diff changeset
1397 decf timeout_counter2,F ; reduce counter
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1398 btfss is_bailout ; Are we in bailout?
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1399 return ; No, return
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1400 ; We were in bailout before, restore profile color
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1401 movff total_divetime_seconds+0,average_depth_hold_total+3 ; Restore color
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1402 rcall profile_display_color ; Back to normal profile color.
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1403 return
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1404
0
heinrichsweikamp
parents:
diff changeset
1405 exit_profileview:
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
1406 ; call speed_fastest
0
heinrichsweikamp
parents:
diff changeset
1407 bcf sleepmode
heinrichsweikamp
parents:
diff changeset
1408 clrf timeout_counter2 ; restore all registers to build same page again
heinrichsweikamp
parents:
diff changeset
1409 movff divemins_backup,divemins+0
heinrichsweikamp
parents:
diff changeset
1410 movff logbook_divenumber_temp, logbook_divenumber
heinrichsweikamp
parents:
diff changeset
1411 movff logbook_max_dive_counter_temp,logbook_max_dive_counter
heinrichsweikamp
parents:
diff changeset
1412 incf logbook_max_dive_counter,F
heinrichsweikamp
parents:
diff changeset
1413 decf logbook_divenumber,F
heinrichsweikamp
parents:
diff changeset
1414 bcf all_dives_shown
heinrichsweikamp
parents:
diff changeset
1415 clrf menupos3 ; here: used row on current page
heinrichsweikamp
parents:
diff changeset
1416 movlw logbook_row_number
heinrichsweikamp
parents:
diff changeset
1417 movwf menupos ; here: active row on current page
372
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
1418 ; call TFT_DisplayOff
f8adb2d5d328 logbook work
heinrichsweikamp
parents: 371
diff changeset
1419 ; call TFT_boot
0
heinrichsweikamp
parents:
diff changeset
1420 clrf CCP1CON ; stop PWM
heinrichsweikamp
parents:
diff changeset
1421 bcf PORTC,2 ; Pull PWM out to GND
heinrichsweikamp
parents:
diff changeset
1422 call TFT_ClearScreen ; clear details/profile
heinrichsweikamp
parents:
diff changeset
1423 goto logbook2 ; start search
heinrichsweikamp
parents:
diff changeset
1424
heinrichsweikamp
parents:
diff changeset
1425 next_logbook2:
heinrichsweikamp
parents:
diff changeset
1426 btfsc all_dives_shown ; all shown
heinrichsweikamp
parents:
diff changeset
1427 goto logbook ; all reset
heinrichsweikamp
parents:
diff changeset
1428 clrf menupos3
heinrichsweikamp
parents:
diff changeset
1429 movlw logbook_row_number
heinrichsweikamp
parents:
diff changeset
1430 movwf menupos
heinrichsweikamp
parents:
diff changeset
1431 incf logbook_page_number,F ; start new screen
169
dcf3e08f31ac CHANGE: Improve internal logbook usability
heinrichsweikamp
parents: 168
diff changeset
1432 bsf keep_cursor_new_page ; Keep cursor on "next page"
0
heinrichsweikamp
parents:
diff changeset
1433 clrf CCP1CON ; stop PWM
heinrichsweikamp
parents:
diff changeset
1434 bcf PORTC,2 ; Pull PWM out to GND
heinrichsweikamp
parents:
diff changeset
1435 call TFT_ClearScreen
heinrichsweikamp
parents:
diff changeset
1436 goto logbook2 ; start search
heinrichsweikamp
parents:
diff changeset
1437
heinrichsweikamp
parents:
diff changeset
1438 next_logbook3:
heinrichsweikamp
parents:
diff changeset
1439 incf menupos,F ; +1
heinrichsweikamp
parents:
diff changeset
1440 movlw logbook_row_number+.2
heinrichsweikamp
parents:
diff changeset
1441 cpfsgt menupos ; =logbook_row_number+.3?
heinrichsweikamp
parents:
diff changeset
1442 bra next_logbook3a ; No
heinrichsweikamp
parents:
diff changeset
1443 movlw .1
heinrichsweikamp
parents:
diff changeset
1444 movwf menupos
heinrichsweikamp
parents:
diff changeset
1445 bra next_logbook3b
heinrichsweikamp
parents:
diff changeset
1446
heinrichsweikamp
parents:
diff changeset
1447 next_logbook3a:
heinrichsweikamp
parents:
diff changeset
1448 incf menupos3,W ; last entry in current page +1
heinrichsweikamp
parents:
diff changeset
1449 cpfseq menupos ; same as cursor pos.?
heinrichsweikamp
parents:
diff changeset
1450 bra next_logbook3b ; No
heinrichsweikamp
parents:
diff changeset
1451 movlw logbook_row_number+.1 ; Yes, ...
heinrichsweikamp
parents:
diff changeset
1452 movwf menupos ; ... jump directly to "next page" if page is not full
heinrichsweikamp
parents:
diff changeset
1453
heinrichsweikamp
parents:
diff changeset
1454 movlw logbook_row_number
heinrichsweikamp
parents:
diff changeset
1455 cpfseq menupos3 ; Last dive was row logbook_row_number?
heinrichsweikamp
parents:
diff changeset
1456 bsf all_dives_shown ; No, set flag to load first page again (full reset)
heinrichsweikamp
parents:
diff changeset
1457
heinrichsweikamp
parents:
diff changeset
1458 next_logbook3b:
heinrichsweikamp
parents:
diff changeset
1459 clrf timeout_counter2
heinrichsweikamp
parents:
diff changeset
1460 call TFT_logbook_cursor
heinrichsweikamp
parents:
diff changeset
1461
heinrichsweikamp
parents:
diff changeset
1462 bcf switch_left
heinrichsweikamp
parents:
diff changeset
1463 goto logbook_loop
heinrichsweikamp
parents:
diff changeset
1464
heinrichsweikamp
parents:
diff changeset
1465 display_listdive:
heinrichsweikamp
parents:
diff changeset
1466 bsf logbook_page_not_empty ; Page not empty
heinrichsweikamp
parents:
diff changeset
1467 incf menupos3,F
heinrichsweikamp
parents:
diff changeset
1468
heinrichsweikamp
parents:
diff changeset
1469 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1470 WIN_FONT FT_SMALL
heinrichsweikamp
parents:
diff changeset
1471 WIN_LEFT logbook_list_left
heinrichsweikamp
parents:
diff changeset
1472
heinrichsweikamp
parents:
diff changeset
1473 decf menupos3,W ; -1 into wreg
heinrichsweikamp
parents:
diff changeset
1474 mullw logbook_row_offset
heinrichsweikamp
parents:
diff changeset
1475 movff PRODL,win_top
heinrichsweikamp
parents:
diff changeset
1476
heinrichsweikamp
parents:
diff changeset
1477 lfsr FSR2,buffer
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1478 call do_logoffset_common_read ; Read into lo:hi
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1479 tstfsz lo ; lo=0?
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1480 bra display_listdive1 ; No, adjust offset
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1481 tstfsz hi ; hi=0?
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1482 bra display_listdive1 ; No, adjust offset
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1483 bra display_listdive1b ; Display now
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1484
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1485 display_listdive1:
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1486 ; Check limit (lo:hi must be <1000)
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1487 movlw LOW d'1000' ; Compare to 1000
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1488 subwf lo,W
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1489 movlw HIGH d'1000'
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1490 subwfb hi,W
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1491 bc display_listdive1b ; carry = no-borrow = > 1000, skip!
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1492
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1493 infsnz lo,F
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1494 incf hi,F ; hi:lo = hi:lo + 1
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1495 movff lo,sub_a+0
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1496 movff hi,sub_a+1
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1497 movff logbook_divenumber,sub_b+0
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1498 clrf sub_b+1
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1499 call subU16 ; sub_c = sub_a - sub_b
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1500 movff sub_c+0,lo
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1501 movff sub_c+1,hi
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1502 bra display_listdive1a
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1503
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1504 display_listdive1b:
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1505 clrf hi
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1506 movff logbook_divenumber,lo ; lo=0 and hi=0 -> show without applied offset
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1507 display_listdive1a:
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1508 output_16_3 ; displays only last three figures from a 16Bit value (0-999), # of dive
0
heinrichsweikamp
parents:
diff changeset
1509 PUTC ' '
heinrichsweikamp
parents:
diff changeset
1510 LOG_POINT_TO log_date+1 ; Point to month
heinrichsweikamp
parents:
diff changeset
1511 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
1512 movff temp1,lo ; read month
heinrichsweikamp
parents:
diff changeset
1513
heinrichsweikamp
parents:
diff changeset
1514 display_listdive2:
heinrichsweikamp
parents:
diff changeset
1515 movff lo,convert_value_temp+0 ; Month (in lo, see above)
heinrichsweikamp
parents:
diff changeset
1516 call ext_flash_byte_read_plus ; Day
heinrichsweikamp
parents:
diff changeset
1517 movff temp1,convert_value_temp+1
heinrichsweikamp
parents:
diff changeset
1518 call TFT_convert_date_short ; converts into "DD/MM" or "MM/DD" or "MM/DD" into buffer
heinrichsweikamp
parents:
diff changeset
1519 PUTC ' '
heinrichsweikamp
parents:
diff changeset
1520
heinrichsweikamp
parents:
diff changeset
1521 LOG_POINT_TO log_max_depth ; Point to max. depth
heinrichsweikamp
parents:
diff changeset
1522 call ext_flash_byte_read_plus ; max. Depth
heinrichsweikamp
parents:
diff changeset
1523 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1524 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
1525 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1526
heinrichsweikamp
parents:
diff changeset
1527 TSTOSS opt_units ; 0=Meters, 1=Feets
heinrichsweikamp
parents:
diff changeset
1528 bra display_listdive2_metric
heinrichsweikamp
parents:
diff changeset
1529 ;display_listdive2_imperial:
heinrichsweikamp
parents:
diff changeset
1530 call convert_mbar_to_feet ; convert value in lo:hi from mbar to feet
heinrichsweikamp
parents:
diff changeset
1531 PUTC ' '
25
f65d070a5b76 fix imperial units in logbook
heinrichsweikamp
parents: 0
diff changeset
1532 bcf leftbind
225
31088352ee32 BUGFIX: Show dives with >999mins divetime correctly
heinrichsweikamp
parents: 189
diff changeset
1533 output_16_3 ; limit to 999 and display only (0-999)
0
heinrichsweikamp
parents:
diff changeset
1534 STRCAT_TEXT tFeets1
heinrichsweikamp
parents:
diff changeset
1535 bra display_listdive3
heinrichsweikamp
parents:
diff changeset
1536
heinrichsweikamp
parents:
diff changeset
1537 display_listdive2_metric:
heinrichsweikamp
parents:
diff changeset
1538 bsf ignore_digit5 ; no cm...
heinrichsweikamp
parents:
diff changeset
1539 movlw d'1' ; +1
heinrichsweikamp
parents:
diff changeset
1540 movff WREG,ignore_digits ; no 1000m
heinrichsweikamp
parents:
diff changeset
1541 bcf leftbind
heinrichsweikamp
parents:
diff changeset
1542 output_16dp .3 ; xxx.y
heinrichsweikamp
parents:
diff changeset
1543 STRCAT_TEXT tMeters
heinrichsweikamp
parents:
diff changeset
1544 PUTC ' '
heinrichsweikamp
parents:
diff changeset
1545
heinrichsweikamp
parents:
diff changeset
1546 display_listdive3:
heinrichsweikamp
parents:
diff changeset
1547 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
1548 movff temp1,lo ; read divetime minutes
heinrichsweikamp
parents:
diff changeset
1549 call ext_flash_byte_read_plus
heinrichsweikamp
parents:
diff changeset
1550 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1551 output_16_3 ; Divetime minutes (0-999min)
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1552 STRCAT_TEXT tMinutes
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1553 clrf WREG
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1554 movff WREG,buffer+.21 ; limit to 21 chars
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1555 STRCAT_PRINT "" ; Display header-row in list
0
heinrichsweikamp
parents:
diff changeset
1556 return
heinrichsweikamp
parents:
diff changeset
1557
heinrichsweikamp
parents:
diff changeset
1558 logbook_show_divenumber:
heinrichsweikamp
parents:
diff changeset
1559 call do_logoffset_common_read ; Read into lo:hi
heinrichsweikamp
parents:
diff changeset
1560 tstfsz lo ; lo=0?
heinrichsweikamp
parents:
diff changeset
1561 bra logbook_show_divenumber2 ; No, adjust offset
heinrichsweikamp
parents:
diff changeset
1562 tstfsz hi ; hi=0?
heinrichsweikamp
parents:
diff changeset
1563 bra logbook_show_divenumber2 ; No, adjust offset
heinrichsweikamp
parents:
diff changeset
1564 movff divesecs,lo ; lo=0 and hi=0 -> skip Offset routine
heinrichsweikamp
parents:
diff changeset
1565 bra logbook_show_divenumber3 ; Display now
heinrichsweikamp
parents:
diff changeset
1566
heinrichsweikamp
parents:
diff changeset
1567 logbook_show_divenumber2:
376
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1568 infsnz lo,F
e99bb91f6f92 CHANGE: Do not show ppO2 in warning area if already shown in custom view
heinrichsweikamp
parents: 372
diff changeset
1569 incf hi,F ; hi:lo = hi:lo + 1
0
heinrichsweikamp
parents:
diff changeset
1570 movff lo,sub_a+0
heinrichsweikamp
parents:
diff changeset
1571 movff hi,sub_a+1
heinrichsweikamp
parents:
diff changeset
1572 movff divesecs,sub_b+0
heinrichsweikamp
parents:
diff changeset
1573 clrf sub_b+1
heinrichsweikamp
parents:
diff changeset
1574 call subU16 ; sub_c = sub_a - sub_b
heinrichsweikamp
parents:
diff changeset
1575 movff sub_c+0,lo
heinrichsweikamp
parents:
diff changeset
1576 movff sub_c+1,hi
heinrichsweikamp
parents:
diff changeset
1577
heinrichsweikamp
parents:
diff changeset
1578 logbook_show_divenumber3:
heinrichsweikamp
parents:
diff changeset
1579 WIN_MEDIUM logbook_divenumer_column, logbook_divenumer_row
heinrichsweikamp
parents:
diff changeset
1580 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1581 output_16 ; # of dive in logbook
heinrichsweikamp
parents:
diff changeset
1582 bcf leftbind
heinrichsweikamp
parents:
diff changeset
1583 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
1584 return
heinrichsweikamp
parents:
diff changeset
1585
heinrichsweikamp
parents:
diff changeset
1586
heinrichsweikamp
parents:
diff changeset
1587 logbook_page2: ; Show more info
255
ad62dff7739a add bearing option to compass
heinrichsweikamp
parents: 225
diff changeset
1588 ; call speed_fastest
0
heinrichsweikamp
parents:
diff changeset
1589 clrf CCP1CON ; stop PWM
heinrichsweikamp
parents:
diff changeset
1590 bcf PORTC,2 ; Pull PWM out to GND
heinrichsweikamp
parents:
diff changeset
1591 call TFT_ClearScreen ; Clear screen
heinrichsweikamp
parents:
diff changeset
1592
heinrichsweikamp
parents:
diff changeset
1593 ; Set ext_flash pointer to "#divesecs-oldest" dive
heinrichsweikamp
parents:
diff changeset
1594 ; compute read_int_eeprom .2 - divesecs
heinrichsweikamp
parents:
diff changeset
1595 ; Read required header data for profile display
heinrichsweikamp
parents:
diff changeset
1596 ; look in header for pointer to begin of diveprofile (Byte 2-4)
heinrichsweikamp
parents:
diff changeset
1597 ; Set pointer (ext_flash_log_pointer:3) to this address, start drawing
heinrichsweikamp
parents:
diff changeset
1598
heinrichsweikamp
parents:
diff changeset
1599 decf divesecs,F ;-1
heinrichsweikamp
parents:
diff changeset
1600 read_int_eeprom .2
heinrichsweikamp
parents:
diff changeset
1601 movf EEDATA,W
heinrichsweikamp
parents:
diff changeset
1602 bcf STATUS,C
heinrichsweikamp
parents:
diff changeset
1603 subfwb divesecs,W ; max. dives (low value) - divesecs
heinrichsweikamp
parents:
diff changeset
1604 movwf lo ; result
heinrichsweikamp
parents:
diff changeset
1605 incf divesecs,F ;+1
heinrichsweikamp
parents:
diff changeset
1606 ; Set ext_flash_address:3 to TOC entry of this dive
heinrichsweikamp
parents:
diff changeset
1607 ; 1st: 200000h-200FFFh -> lo=0
heinrichsweikamp
parents:
diff changeset
1608 ; 2nd: 201000h-201FFFh -> lo=1
heinrichsweikamp
parents:
diff changeset
1609 ; 3rd: 202000h-202FFFh -> lo=2
heinrichsweikamp
parents:
diff changeset
1610 ; 256: 2FF000h-2FFFFFh -> lo=255 (And hi>0...)
heinrichsweikamp
parents:
diff changeset
1611 clrf ext_flash_address+0
heinrichsweikamp
parents:
diff changeset
1612 clrf ext_flash_address+1
heinrichsweikamp
parents:
diff changeset
1613 movlw 0x20
heinrichsweikamp
parents:
diff changeset
1614 movwf ext_flash_address+2
heinrichsweikamp
parents:
diff changeset
1615 movlw .16
heinrichsweikamp
parents:
diff changeset
1616 mulwf lo ; lo*16 = offset to 0x2000 (up:hi)
heinrichsweikamp
parents:
diff changeset
1617 movf PRODL,W
heinrichsweikamp
parents:
diff changeset
1618 addwf ext_flash_address+1,F
heinrichsweikamp
parents:
diff changeset
1619 movf PRODH,W
heinrichsweikamp
parents:
diff changeset
1620 addwfc ext_flash_address+2,F
heinrichsweikamp
parents:
diff changeset
1621 ; pointer at the first 0xFA of header
heinrichsweikamp
parents:
diff changeset
1622 call logbook_show_divenumber ; Show the dive number in medium font
heinrichsweikamp
parents:
diff changeset
1623
heinrichsweikamp
parents:
diff changeset
1624
heinrichsweikamp
parents:
diff changeset
1625 LOG_POINT_TO log_surface_press
heinrichsweikamp
parents:
diff changeset
1626 ; surface pressure in mbar
heinrichsweikamp
parents:
diff changeset
1627 call ext_flash_byte_read_plus ; read surface pressure
heinrichsweikamp
parents:
diff changeset
1628 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1629 call ext_flash_byte_read_plus ; read surface pressure
heinrichsweikamp
parents:
diff changeset
1630 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1631 WIN_TINY MBAR_column,MBAR_row
heinrichsweikamp
parents:
diff changeset
1632 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1633 output_16 ; Air pressure before dive
heinrichsweikamp
parents:
diff changeset
1634 STRCAT_TEXT_PRINT tMBAR
heinrichsweikamp
parents:
diff changeset
1635
89
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1636 ; OC/CC Gas List
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1637 LOG_POINT_TO log_divemode
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1638 call ext_flash_byte_read_plus ; 0=OC, 1=CC, 2=Gauge, 3=Apnea into temp1
0
heinrichsweikamp
parents:
diff changeset
1639 WIN_TINY log2_title_column,log2_title_row1
heinrichsweikamp
parents:
diff changeset
1640 WIN_COLOR color_greenish
89
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1641 movlw .1
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1642 cpfseq temp1 ;=CC?
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1643 bra logbook_gaslist_oc
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1644 STRCPY_TEXT_PRINT tGaslistCC
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1645 bra logbook_gaslist_common
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1646 logbook_gaslist_oc:
0
heinrichsweikamp
parents:
diff changeset
1647 STRCPY_TEXT_PRINT tGaslist
89
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1648 logbook_gaslist_common:
c34516c99ca8 BUGFIX: No average depth for end-of-dive portion (<1m)
heinrichsweikamp
parents: 66
diff changeset
1649 LOG_POINT_TO log_gas1
0
heinrichsweikamp
parents:
diff changeset
1650 WIN_FRAME_STD log2_title_row1-2, log2_gas_row5+.15, log2_title_column-2, .159 ; Top, Bottom, Left, Right
heinrichsweikamp
parents:
diff changeset
1651 bcf leftbind
heinrichsweikamp
parents:
diff changeset
1652 movlw color_white ; Color for Gas 1
heinrichsweikamp
parents:
diff changeset
1653 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1654 WIN_TINY log2_gas_column, log2_gas_row1
heinrichsweikamp
parents:
diff changeset
1655 rcall log_show_gas_common2
heinrichsweikamp
parents:
diff changeset
1656 movlw color_green ; Color for Gas 2
heinrichsweikamp
parents:
diff changeset
1657 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1658 WIN_TINY log2_gas_column, log2_gas_row2
heinrichsweikamp
parents:
diff changeset
1659 rcall log_show_gas_common2
heinrichsweikamp
parents:
diff changeset
1660 movlw color_red ; Color for Gas 3
heinrichsweikamp
parents:
diff changeset
1661 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1662 WIN_TINY log2_gas_column, log2_gas_row3
heinrichsweikamp
parents:
diff changeset
1663 rcall log_show_gas_common2
heinrichsweikamp
parents:
diff changeset
1664 movlw color_yellow ; Color for Gas 4
heinrichsweikamp
parents:
diff changeset
1665 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1666 WIN_TINY log2_gas_column, log2_gas_row4
heinrichsweikamp
parents:
diff changeset
1667 rcall log_show_gas_common2
heinrichsweikamp
parents:
diff changeset
1668 movlw color_cyan ; Color for Gas 5
heinrichsweikamp
parents:
diff changeset
1669 call TFT_set_color ; Set Color...
heinrichsweikamp
parents:
diff changeset
1670 WIN_TINY log2_gas_column, log2_gas_row5
heinrichsweikamp
parents:
diff changeset
1671 rcall log_show_gas_common2
heinrichsweikamp
parents:
diff changeset
1672
heinrichsweikamp
parents:
diff changeset
1673 ; Firmware
heinrichsweikamp
parents:
diff changeset
1674 call TFT_standard_color
heinrichsweikamp
parents:
diff changeset
1675 WIN_TINY log2_firmware_column,log2_firmware_row
heinrichsweikamp
parents:
diff changeset
1676 STRCPY_TEXT tFirmware
heinrichsweikamp
parents:
diff changeset
1677 call ext_flash_byte_read_plus ; read firmware xx
heinrichsweikamp
parents:
diff changeset
1678 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1679 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1680 output_8
heinrichsweikamp
parents:
diff changeset
1681 PUTC "."
heinrichsweikamp
parents:
diff changeset
1682 call ext_flash_byte_read_plus ; read firmware yy
heinrichsweikamp
parents:
diff changeset
1683 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1684 output_99x
heinrichsweikamp
parents:
diff changeset
1685 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
1686
heinrichsweikamp
parents:
diff changeset
1687 ; Battery
heinrichsweikamp
parents:
diff changeset
1688 WIN_TINY log2_battery_column,log2_battery_row
heinrichsweikamp
parents:
diff changeset
1689 STRCPY "Batt:"
heinrichsweikamp
parents:
diff changeset
1690 call ext_flash_byte_read_plus ; read battery low
heinrichsweikamp
parents:
diff changeset
1691 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1692 call ext_flash_byte_read_plus ; read battery high
heinrichsweikamp
parents:
diff changeset
1693 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1694 output_16dp .2
heinrichsweikamp
parents:
diff changeset
1695 STRCAT_PRINT "V"
heinrichsweikamp
parents:
diff changeset
1696
heinrichsweikamp
parents:
diff changeset
1697 ; Setpoint list
heinrichsweikamp
parents:
diff changeset
1698 LOG_POINT_TO log_sp1
heinrichsweikamp
parents:
diff changeset
1699 WIN_TINY log2_title_column,log2_title_sp_row
heinrichsweikamp
parents:
diff changeset
1700 WIN_COLOR color_greenish
heinrichsweikamp
parents:
diff changeset
1701 STRCPY_TEXT_PRINT tFixedSetpoints
heinrichsweikamp
parents:
diff changeset
1702 WIN_FRAME_STD log2_title_sp_row-2, log2_sp_row5+.15, log2_title_column-2, .159 ; Top, Bottom, Left, Right
heinrichsweikamp
parents:
diff changeset
1703 WIN_TINY log2_gas_column, log2_sp_row1
heinrichsweikamp
parents:
diff changeset
1704 rcall log_show_sp_common
heinrichsweikamp
parents:
diff changeset
1705 WIN_TINY log2_gas_column, log2_sp_row2
heinrichsweikamp
parents:
diff changeset
1706 rcall log_show_sp_common
heinrichsweikamp
parents:
diff changeset
1707 WIN_TINY log2_gas_column, log2_sp_row3
heinrichsweikamp
parents:
diff changeset
1708 rcall log_show_sp_common
heinrichsweikamp
parents:
diff changeset
1709 WIN_TINY log2_gas_column, log2_sp_row4
heinrichsweikamp
parents:
diff changeset
1710 rcall log_show_sp_common
heinrichsweikamp
parents:
diff changeset
1711 WIN_TINY log2_gas_column, log2_sp_row5
heinrichsweikamp
parents:
diff changeset
1712 rcall log_show_sp_common
heinrichsweikamp
parents:
diff changeset
1713
heinrichsweikamp
parents:
diff changeset
1714 ; Salinity
heinrichsweikamp
parents:
diff changeset
1715 WIN_TINY log2_salinity_column,log2_salinity_row
heinrichsweikamp
parents:
diff changeset
1716 STRCPY_TEXT tDvSalinity
heinrichsweikamp
parents:
diff changeset
1717 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1718 call ext_flash_byte_read_plus ; read salinity
heinrichsweikamp
parents:
diff changeset
1719 movff temp1,lo
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1720 movff temp1,total_divetime_seconds+1 ; backup for average depth display
0
heinrichsweikamp
parents:
diff changeset
1721 output_8
heinrichsweikamp
parents:
diff changeset
1722 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1723
heinrichsweikamp
parents:
diff changeset
1724 ; CNS
heinrichsweikamp
parents:
diff changeset
1725 LOG_POINT_TO log_cns_start
heinrichsweikamp
parents:
diff changeset
1726 WIN_TINY log2_cns_column,log2_cns_row
heinrichsweikamp
parents:
diff changeset
1727 STRCPY_TEXT tCNS2
heinrichsweikamp
parents:
diff changeset
1728 call ext_flash_byte_read_plus ; read cns low
heinrichsweikamp
parents:
diff changeset
1729 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1730 call ext_flash_byte_read_plus ; read cns high
heinrichsweikamp
parents:
diff changeset
1731 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1732 output_16
heinrichsweikamp
parents:
diff changeset
1733 LOG_POINT_TO log_cns_end
heinrichsweikamp
parents:
diff changeset
1734 STRCAT "->"
heinrichsweikamp
parents:
diff changeset
1735 call ext_flash_byte_read_plus ; read CNS low
heinrichsweikamp
parents:
diff changeset
1736 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1737 call ext_flash_byte_read_plus ; read CNS high
heinrichsweikamp
parents:
diff changeset
1738 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1739 output_16
heinrichsweikamp
parents:
diff changeset
1740 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1741
heinrichsweikamp
parents:
diff changeset
1742 ; Average depth
heinrichsweikamp
parents:
diff changeset
1743 WIN_TINY log2_avr_column,log2_avr_row
437
23b58c4bc6aa CHANGE: Language fixes, 2.08 release
heinrichsweikamp
parents: 436
diff changeset
1744 STRCPY_TEXT tAVG
0
heinrichsweikamp
parents:
diff changeset
1745 call ext_flash_byte_read_plus ; read avr low
heinrichsweikamp
parents:
diff changeset
1746 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1747 call ext_flash_byte_read_plus ; read avr high
heinrichsweikamp
parents:
diff changeset
1748 movff temp1,hi
99
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1749
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1750 movf total_divetime_seconds+1,W ; salinity for this dive
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1751 call adjust_depth_with_salinity_log ; computes salinity setting (FROM WREG!) into lo:hi [mbar]
87cc1adfe4da show event "bailout" in the internal logbook
heinrichsweikamp
parents: 98
diff changeset
1752
0
heinrichsweikamp
parents:
diff changeset
1753 output_16dp .3
heinrichsweikamp
parents:
diff changeset
1754 STRCAT_PRINT "m"
heinrichsweikamp
parents:
diff changeset
1755
heinrichsweikamp
parents:
diff changeset
1756 ; Deco model
heinrichsweikamp
parents:
diff changeset
1757 LOG_POINT_TO log_decomodel
heinrichsweikamp
parents:
diff changeset
1758 WIN_TINY log2_decomodel_column,log2_decomodel_row
heinrichsweikamp
parents:
diff changeset
1759 STRCPY_TEXT tDkMode
heinrichsweikamp
parents:
diff changeset
1760 call ext_flash_byte_read_plus ; read deco model
heinrichsweikamp
parents:
diff changeset
1761 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1762 decfsz temp1,F
heinrichsweikamp
parents:
diff changeset
1763 bra logbook_decomodel1
heinrichsweikamp
parents:
diff changeset
1764 ; Deco model GF Version
heinrichsweikamp
parents:
diff changeset
1765 STRCAT_TEXT_PRINT tZHL16GF
heinrichsweikamp
parents:
diff changeset
1766 LOG_POINT_TO log_gf_lo
heinrichsweikamp
parents:
diff changeset
1767 WIN_TINY log2_decomodel2_column,log2_decomodel2_row
heinrichsweikamp
parents:
diff changeset
1768 STRCPY_TEXT tGF_low
heinrichsweikamp
parents:
diff changeset
1769 call ext_flash_byte_read_plus ; Read GF lo
heinrichsweikamp
parents:
diff changeset
1770 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1771 output_8
heinrichsweikamp
parents:
diff changeset
1772 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1773 WIN_TINY log2_decomodel3_column,log2_decomodel3_row
heinrichsweikamp
parents:
diff changeset
1774 STRCPY_TEXT tGF_high
heinrichsweikamp
parents:
diff changeset
1775 call ext_flash_byte_read_plus ; Read GF hi
heinrichsweikamp
parents:
diff changeset
1776 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1777 output_8
heinrichsweikamp
parents:
diff changeset
1778 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1779 bra logbook_decomodel2
heinrichsweikamp
parents:
diff changeset
1780 logbook_decomodel1:
heinrichsweikamp
parents:
diff changeset
1781 ; Deco model NON-GF Version
heinrichsweikamp
parents:
diff changeset
1782 STRCAT_TEXT_PRINT tZHL16
heinrichsweikamp
parents:
diff changeset
1783 LOG_POINT_TO log_sat_mult
heinrichsweikamp
parents:
diff changeset
1784 WIN_TINY log2_decomodel2_column,log2_decomodel2_row
heinrichsweikamp
parents:
diff changeset
1785 STRCPY_TEXT tSaturationMult
heinrichsweikamp
parents:
diff changeset
1786 call ext_flash_byte_read_plus ; Read sat_mult
heinrichsweikamp
parents:
diff changeset
1787 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1788 output_8
heinrichsweikamp
parents:
diff changeset
1789 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1790 WIN_TINY log2_decomodel3_column,log2_decomodel3_row
heinrichsweikamp
parents:
diff changeset
1791 STRCPY_TEXT tDesaturationMult
heinrichsweikamp
parents:
diff changeset
1792 call ext_flash_byte_read_plus ; Read desat_mult
heinrichsweikamp
parents:
diff changeset
1793 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1794 output_8
heinrichsweikamp
parents:
diff changeset
1795 STRCAT_PRINT "%"
heinrichsweikamp
parents:
diff changeset
1796 logbook_decomodel2:
heinrichsweikamp
parents:
diff changeset
1797 ; Dive mode
heinrichsweikamp
parents:
diff changeset
1798 LOG_POINT_TO log_divemode
heinrichsweikamp
parents:
diff changeset
1799 WIN_TINY log2_divemode_column,log2_divemode_row
heinrichsweikamp
parents:
diff changeset
1800 STRCPY_TEXT tDvMode
heinrichsweikamp
parents:
diff changeset
1801 call ext_flash_byte_read_plus ; Read divemode
heinrichsweikamp
parents:
diff changeset
1802 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1803 call TFT_display_decotype_surface1 ; "strcat_print"s divemode (OC, CC, APNEA or GAUGE)
heinrichsweikamp
parents:
diff changeset
1804
heinrichsweikamp
parents:
diff changeset
1805 ; Last deco
heinrichsweikamp
parents:
diff changeset
1806 LOG_POINT_TO log_last_stop
heinrichsweikamp
parents:
diff changeset
1807 WIN_TINY log2_lastdeco_column,log2_lastdeco_row
heinrichsweikamp
parents:
diff changeset
1808 STRCPY_TEXT tLastDecostop
heinrichsweikamp
parents:
diff changeset
1809 call ext_flash_byte_read_plus ; Read last stop
heinrichsweikamp
parents:
diff changeset
1810 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1811 output_8
heinrichsweikamp
parents:
diff changeset
1812 STRCAT_PRINT "m"
heinrichsweikamp
parents:
diff changeset
1813
heinrichsweikamp
parents:
diff changeset
1814 ; A frame around the details
heinrichsweikamp
parents:
diff changeset
1815 WIN_TINY log2_lastdeco_column,log2_salinity_row-.16
heinrichsweikamp
parents:
diff changeset
1816 WIN_COLOR color_greenish
heinrichsweikamp
parents:
diff changeset
1817 STRCPY_TEXT_PRINT tLogbook
heinrichsweikamp
parents:
diff changeset
1818 WIN_FRAME_STD log2_salinity_row-.18, MBAR_row+.15, 0, .85 ; Top, Bottom, Left, Right
heinrichsweikamp
parents:
diff changeset
1819
heinrichsweikamp
parents:
diff changeset
1820 rcall logbook_preloop_tasks ; Clear some flags and set to Speed_eco
heinrichsweikamp
parents:
diff changeset
1821 display_details_loop:
heinrichsweikamp
parents:
diff changeset
1822 btfsc switch_left ; SET/MENU?
heinrichsweikamp
parents:
diff changeset
1823 goto display_profile2 ; Show the profile view again
heinrichsweikamp
parents:
diff changeset
1824 btfsc switch_right ; ENTER?
heinrichsweikamp
parents:
diff changeset
1825 bra exit_profileview ; back to list
heinrichsweikamp
parents:
diff changeset
1826 rcall log_screendump_and_onesecond ; Check if we need to make a screenshot and check for new second
heinrichsweikamp
parents:
diff changeset
1827 btfsc sleepmode ; Timeout?
heinrichsweikamp
parents:
diff changeset
1828 bra exit_profileview ; back to list
heinrichsweikamp
parents:
diff changeset
1829
heinrichsweikamp
parents:
diff changeset
1830 bra display_details_loop ; wait for something to do
heinrichsweikamp
parents:
diff changeset
1831
heinrichsweikamp
parents:
diff changeset
1832 global logbook_preloop_tasks
heinrichsweikamp
parents:
diff changeset
1833 logbook_preloop_tasks:
275
653a3ab08062 rename into hwOS
heinrichsweikamp
parents: 255
diff changeset
1834 movlw CCP1CON_VALUE ; See hwos.inc
0
heinrichsweikamp
parents:
diff changeset
1835 movwf CCP1CON ; Power-on backlight
heinrichsweikamp
parents:
diff changeset
1836 call TFT_standard_color
heinrichsweikamp
parents:
diff changeset
1837 bcf sleepmode ; clear some flags
heinrichsweikamp
parents:
diff changeset
1838 bcf switch_right
heinrichsweikamp
parents:
diff changeset
1839 bcf switch_left
heinrichsweikamp
parents:
diff changeset
1840 clrf timeout_counter2
392
32780516c8c6 NEW: Show actual dive count in logbook list view (If <1000)
heinrichsweikamp
parents: 389
diff changeset
1841 goto speed_normal ; and return
0
heinrichsweikamp
parents:
diff changeset
1842
heinrichsweikamp
parents:
diff changeset
1843 log_show_sp_common:
heinrichsweikamp
parents:
diff changeset
1844 lfsr FSR2,buffer
heinrichsweikamp
parents:
diff changeset
1845 call ext_flash_byte_read_plus ; Read setpoint
heinrichsweikamp
parents:
diff changeset
1846 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1847 clrf hi
heinrichsweikamp
parents:
diff changeset
1848 bsf leftbind
heinrichsweikamp
parents:
diff changeset
1849 output_16dp d'3'
heinrichsweikamp
parents:
diff changeset
1850 bcf leftbind
heinrichsweikamp
parents:
diff changeset
1851 STRCAT_TEXT tbar
heinrichsweikamp
parents:
diff changeset
1852 PUTC " "
heinrichsweikamp
parents:
diff changeset
1853 call ext_flash_byte_read_plus ; change depth
heinrichsweikamp
parents:
diff changeset
1854 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1855
heinrichsweikamp
parents:
diff changeset
1856 TSTOSS opt_units ; 0=Meters, 1=Feets
heinrichsweikamp
parents:
diff changeset
1857 bra log_show_sp_common_metric
heinrichsweikamp
parents:
diff changeset
1858 movf lo,W
heinrichsweikamp
parents:
diff changeset
1859 mullw .100 ; convert meters to mbar
heinrichsweikamp
parents:
diff changeset
1860 movff PRODL,lo
heinrichsweikamp
parents:
diff changeset
1861 movff PRODH,hi
heinrichsweikamp
parents:
diff changeset
1862 call convert_mbar_to_feet ; convert value in lo:hi from mbar to feet
heinrichsweikamp
parents:
diff changeset
1863 output_16
heinrichsweikamp
parents:
diff changeset
1864 STRCAT_TEXT tFeets ; "ft"
heinrichsweikamp
parents:
diff changeset
1865 bra log_show_sp_common_common
heinrichsweikamp
parents:
diff changeset
1866 log_show_sp_common_metric:
heinrichsweikamp
parents:
diff changeset
1867 output_8
heinrichsweikamp
parents:
diff changeset
1868 STRCAT_TEXT tMeters ; "m"
heinrichsweikamp
parents:
diff changeset
1869 log_show_sp_common_common:
heinrichsweikamp
parents:
diff changeset
1870 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
1871 return
heinrichsweikamp
parents:
diff changeset
1872
heinrichsweikamp
parents:
diff changeset
1873 log_show_gas_common2: ; as log_show_gas_common but with change depth
heinrichsweikamp
parents:
diff changeset
1874 lfsr FSR2,buffer
heinrichsweikamp
parents:
diff changeset
1875 call ext_flash_byte_read_plus ; current O2
heinrichsweikamp
parents:
diff changeset
1876 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1877 call ext_flash_byte_read_plus ; current He
heinrichsweikamp
parents:
diff changeset
1878 movff temp1,hi
heinrichsweikamp
parents:
diff changeset
1879 call customview_show_mix ; Put "Nxlo", "Txlo/hi", "Air" or "O2" into Postinc2
heinrichsweikamp
parents:
diff changeset
1880 call ext_flash_byte_read_plus ; change depth
heinrichsweikamp
parents:
diff changeset
1881 movff temp1,lo
heinrichsweikamp
parents:
diff changeset
1882
heinrichsweikamp
parents:
diff changeset
1883 TSTOSS opt_units ; 0=Meters, 1=Feets
heinrichsweikamp
parents:
diff changeset
1884 bra log_show_gas_common2_metric
heinrichsweikamp
parents:
diff changeset
1885 movf lo,W
heinrichsweikamp
parents:
diff changeset
1886 mullw .100 ; convert meters to mbar
heinrichsweikamp
parents:
diff changeset
1887 movff PRODL,lo
heinrichsweikamp
parents:
diff changeset
1888 movff PRODH,hi
heinrichsweikamp
parents:
diff changeset
1889 call convert_mbar_to_feet ; convert value in lo:hi from mbar to feet
heinrichsweikamp
parents:
diff changeset
1890 output_16
heinrichsweikamp
parents:
diff changeset
1891 STRCAT_TEXT tFeets ; "ft"
heinrichsweikamp
parents:
diff changeset
1892 bra log_show_gas_common2_common
heinrichsweikamp
parents:
diff changeset
1893 log_show_gas_common2_metric:
heinrichsweikamp
parents:
diff changeset
1894 output_8
heinrichsweikamp
parents:
diff changeset
1895 STRCAT_TEXT tMeters ; "m"
heinrichsweikamp
parents:
diff changeset
1896 log_show_gas_common2_common:
heinrichsweikamp
parents:
diff changeset
1897 bcf leftbind
heinrichsweikamp
parents:
diff changeset
1898 call ext_flash_byte_read_plus ; Gas Type
heinrichsweikamp
parents:
diff changeset
1899 STRCAT_PRINT ""
heinrichsweikamp
parents:
diff changeset
1900 return
heinrichsweikamp
parents:
diff changeset
1901
heinrichsweikamp
parents:
diff changeset
1902 END