annotate code_part1/OSTC_code_asm_part1/menu_logbook.asm @ 192:c8816e4bc724

GF Model + Apply the Eric's Baker gradient formula. + Apply GF varying corrections for each compartiment. + B?hlmann 100/100 == Gradient factor 100/100. + Compute stop with gradient at current depth (not GF_low) + Add assert() on visual platform. + Overflow stop into the next bin at same depth. + debug last deco depth in range 3m..6m.
author JeanDo
date Fri, 11 Feb 2011 23:39:35 +0100
parents c3ac603ba248
children f5e9db793dd3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
2 ; OSTC - diving computer code
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
3 ; Copyright (C) 2008 HeinrichsWeikamp GbR
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
4
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
5 ; This program is free software: you can redistribute it and/or modify
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
6 ; it under the terms of the GNU General Public License as published by
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
7 ; the Free Software Foundation, either version 3 of the License, or
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
8 ; (at your option) any later version.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
9
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
10 ; This program is distributed in the hope that it will be useful,
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
11 ; but WITHOUT ANY WARRANTY; without even the implied warranty of
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
12 ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
13 ; GNU General Public License for more details.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
14
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
15 ; You should have received a copy of the GNU General Public License
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
16 ; along with this program. If not, see <http://www.gnu.org/licenses/>.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
17
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
18
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
19 ; Menu "Logbook"
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
20 ; written by: Matthias Heinrichs, info@heinrichsweikamp.com
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
21 ; written: 060107
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
22 ; last updated: 081026
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
23 ; known bugs:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
24 ; ToDo:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
25
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
26 ; searches external EEPROM for dive headers and displays them in a list
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
27 ; a detailed view with all informations and profile can be selected
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
28 ; does not require a FAT, will work with other profile intervals as ten seconds, too
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
29
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
30 menu_logbook:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
31 bcf return_from_profileview ; clear some flags
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
32 ;call enable_rs232
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
33 menu_logbook1:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
34 bcf logbook_header_drawn
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
35 call PLED_ClearScreen ; Clear screen
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
36 bcf all_dives_shown ; clear some flags
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
37 bcf logbook_profile_view
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
38 bcf logbook_page_not_empty
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
39 clrf menupos3 ; Here: used rows on current logbook-page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
40 clrf menupos2 ; Here: # of current displayed page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
41 clrf divenumber ; # of dive in list during search
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
42
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
43
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
44 menu_logbook1a:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
45 WIN_INVERT .1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
46 DISPLAYTEXT .12 ;" Wait.."
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
47 WIN_INVERT .0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
48 clrf divemins+0 ; Here: used as temp variables
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
49 clrf divemins+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
50 call I2CReset ; Reset I2C Bus
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
51 call get_free_EEPROM_location ; search from "here" backwards through the external memory
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
52
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
53 movlw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
54 movwf menupos ; Here: stores current position on display (5-x)
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
55
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
56 ;-----------------------------------------------------------------------------
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
57 ; search external EEPROM backwards from eeprom_address
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
58 ; for 0xFA, 0xFA (store 1st. 0xFA position for next search)
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
59 ; read header data and display it
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
60 ; wait for user to confirm/exit
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
61 ; recopy data to search from here
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
62
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
63 menu_logbook1b:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
64 WIN_INVERT .1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
65 DISPLAYTEXT .12 ;" Wait.."
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
66 WIN_INVERT .0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
67
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
68 ;---- fast loop: check every other byte ----------------------------------
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
69 menu_logbook2:
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
70 infsnz divemins+0,F ; increase 16Bit value
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
71 incf divemins+1,F
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
72 infsnz divemins+0,F ; increase 16Bit value, twice
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
73 incf divemins+1,F
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
74
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
75 btfsc divemins+1,7 ; At 0x8000?
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
76 bra menu_logbook_reset ; yes, restart (if not empty)
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
77
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
78 decf_eeprom_address d'2' ; +2 to eeprom address.
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
79
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
80 call I2CREAD ; reads one byte (Slow! Better use Blockread!)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
81
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
82 movlw 0xFA ; That was a FA ?
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
83 cpfseq SSPBUF
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
84 bra menu_logbook2 ; No: continue the fast loop...
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
85
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
86 ;---- Slow check : was it before or after that one ? ---------------------
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
87
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
88 incf_eeprom_address d'1' ; Been one step too far ?
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
89 call I2CREAD ; reads one byte (Slow! Better use Blockread!)
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
90 movlw 0xFA ; That was a FA ?
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
91 xorwf SSPBUF,W
151
c3ac603ba248 Fix logbook display when there odd-size dives.
JeanDo
parents: 148
diff changeset
92 bz menu_loop_tooFar ; Got both of them...
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
93
151
c3ac603ba248 Fix logbook display when there odd-size dives.
JeanDo
parents: 148
diff changeset
94 infsnz divemins+0,F ; Advance to the next byte.
c3ac603ba248 Fix logbook display when there odd-size dives.
JeanDo
parents: 148
diff changeset
95 incf divemins+1,F
c3ac603ba248 Fix logbook display when there odd-size dives.
JeanDo
parents: 148
diff changeset
96 decf_eeprom_address d'2' ; One step back, two steps forward.
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
97 call I2CREAD ; reads one byte (Slow! Better use Blockread!)
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
98 movlw 0xFA ; It was the second FA ?
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
99 xorwf SSPBUF,W
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
100 bz test_FA_DONE
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
101 bra menu_logbook2 ; No: continue the fast loop...
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
102
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
103 menu_loop_tooFar;
151
c3ac603ba248 Fix logbook display when there odd-size dives.
JeanDo
parents: 148
diff changeset
104 decf_eeprom_address d'1' ; So stays pointing at the second one.
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
105
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
106 test_FA_DONE: ; Found 0xFA 0xFA!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
107 movff eeprom_address+0,eeprom_header_address+0 ; store current address into temp register
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
108 movff eeprom_address+1,eeprom_header_address+1 ; we must continue search here later
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
109 incf divenumber,F ; new header found, increase divenumber
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
110 bra menu_logbook4 ; Done with searching, display the header!
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
111
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
112 menu_logbook3b:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
113 btfss logbook_page_not_empty ; Was there at least one dive?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
114 goto menu ; Not a single header was found, leave logbook.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
115 bra menu_logbook_display_loop2 ; rcall of get_free_eeprom_location not required here (faster)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
116
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
117 menu_logbook_reset:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
118 movf divenumber,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
119 btfsc STATUS,Z ; Was there at least one dive?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
120 bra menu_logbook3b ; No, Nothing to do
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
121
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
122 bsf all_dives_shown ; Yes
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
123 bra menu_logbook_display_loop2 ; rcall of get_free_eeprom_location not required here (faster)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
124
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
125
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
126 menu_logbook4:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
127 ; Adjust eeprom_address to set pointer on first headerbyte
148
055977afc2f9 Make loogbook search twice faster.
JeanDo
parents: 146
diff changeset
128 incf_eeprom_address d'2' ; Macro, that adds 8Bit to eeprom_address:2 with banking at 0x8000
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
129
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
130 btfss logbook_profile_view ; Display profile (search routine is used in profileview, too)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
131 bra menu_logbook_display_loop ; No, display overwiev list
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
132
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
133 movf divesecs,W ; divenumber that is searched
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
134 cpfseq divenumber ; current divenumber
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
135 bra next_logbook ; No match, continue search
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
136 bra display_profile2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
137
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
138
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
139 menu_logbook_display_loop:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
140 btfsc all_dives_shown ; All dives displayed?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
141 bra menu_logbook_display_loop2 ; Yes, but display first page again.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
142
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
143 rcall display_listdive ; display short header for list on current list position
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
144
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
145 movlw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
146 cpfseq menupos ; first dive on list (top place)?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
147 bra menu_logbook_display_loop1 ; no, so skip saving of address
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
148
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
149
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
150 movff divenumber,mintemp+0 ; store all registered required to rebuilt the current logbookpage after the detail/profile view
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
151 movff eeprom_header_address+0,decodata+0 ; several registers are used as temp registers here
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
152 movff eeprom_header_address+1,decodata+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
153 movff divemins+0,max_pressure+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
154 movff divemins+1,max_pressure+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
155
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
156 movlw d'3'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
157 addwf decodata+0,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
158 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
159 addwfc decodata+1,F ; Re-Adjust pointer again
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
160 movlw d'3' ; So first row will be the same again after detail/profile view
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
161 subwf max_pressure+0,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
162 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
163 subwfb max_pressure+1,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
164
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
165 menu_logbook_display_loop1:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
166 decfsz menupos,F ; List full?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
167 bra next_logbook ; no, search another dive for our current logbook page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
168
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
169 menu_logbook_display_loop2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
170 btfss logbook_page_not_empty ; Was there one dive at all?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
171 bra menu_logbook ; Yes, so reload the first page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
172
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
173 call PLED_topline_box ; Draw box
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
174 WIN_INVERT .1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
175 DISPLAYTEXT .26 ; "Logbook"
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
176 WIN_INVERT .0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
177
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
178 DISPLAYTEXT .11 ; Displays "Exit" in the last row on the current page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
179
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
180 bcf sleepmode ; clear some flags for user input
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
181 bcf menubit2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
182 bcf menubit3
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
183 bcf cursor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
184 bcf switch_right
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
185 bcf switch_left
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
186 clrf timeout_counter2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
187
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
188 movlw d'1' ; Set cursor to position 1...
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
189 btfsc return_from_profileview ; .. unless we are returning from a detail/profile view
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
190 movf mintemp+1,W ; load last cursor position again
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
191 movwf menupos ; and set menupos byte
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
192 bcf return_from_profileview ; Do this only once while the page is loaded again!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
193
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
194 bcf logbook_page_not_empty ; Obviously the current page is NOT empty
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
195 call PLED_logbook_cursor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
196
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
197 menu_logbook_loop:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
198 call check_switches_logbook
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
199
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
200 btfsc menubit3 ; SET/MENU?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
201 bra next_logbook3 ; adjust cursor or create new page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
202
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
203 btfsc menubit2 ; ENTER?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
204 bra display_profile_or_exit ; view details/profile or exit logbook
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
205
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
206 btfsc onesecupdate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
207 call timeout_surfmode ; Timeout
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
208
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
209 btfsc onesecupdate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
210 call set_dive_modes ; Check, if divemode must be entered
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
211
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
212 bcf onesecupdate ; one second update
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
213
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
214 btfsc sleepmode ; Timeout?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
215 goto menu ; Yes
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
216
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
217 btfsc divemode
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
218 goto restart ; Enter Divemode if required
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
219
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
220 bra menu_logbook_loop ; Wait for something to do
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
221
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
222 display_profile_or_exit:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
223 bcf menubit2 ; debounce
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
224 movlw d'6' ; exit?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
225 cpfseq menupos
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
226 bra display_profile ; No, show details/profile
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
227 goto menu
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
228
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
229 display_profile:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
230 movff menupos,mintemp+1 ; store current cursor position
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
231 bsf return_from_profileview ; tweak search routine to exit after found
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
232
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
233 movf menupos2,W ; Number of page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
234 mullw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
235 movf PRODL,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
236 addwf menupos,W ; page*5+menupos=
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
237 movwf divesecs ; # of dive to search
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
238
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
239 call PLED_ClearScreen ; search for dive
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
240 bsf logbook_profile_view ; set flag for search routine
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
241
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
242 clrf divenumber ; search from scratch
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
243 bra menu_logbook1a ; start search
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
244 display_profile2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
245 bcf logbook_profile_view ; clear flag for search routine
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
246
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
247 call PLED_display_wait_clear
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
248 WIN_TOP .0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
249 WIN_LEFT .0
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
250 STRCPY "#"
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
251
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
252 GETCUSTOM15 .28 ; Logbook Offset -> lo, hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
253 tstfsz lo ; lo=0?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
254 bra display_profile_offset1 ; No, adjust offset
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
255 tstfsz hi ; hi=0?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
256 bra display_profile_offset1 ; No, adjust offset
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
257 bra display_profile_offset2 ; lo=0 and hi=0 -> skip Offset routine
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
258
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
259 display_profile_offset1:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
260 movlw d'1'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
261 addwf lo,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
262 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
263 addwfc hi,F ; hi:lo = hi:lo + 1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
264 movff lo,sub_a+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
265 movff hi,sub_a+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
266 movff divesecs,sub_b+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
267 clrf sub_b+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
268 call sub16 ; sub_c = sub_a - sub_b
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
269 movff sub_c+0,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
270 movff sub_c+1,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
271 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
272 output_16dp d'10' ; # of dive with offset
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
273 bra display_profile_offset3 ; Skip normal routine
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
274
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
275 display_profile_offset2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
276 movff divesecs,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
277 output_99x ; # of dive
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
278
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
279 display_profile_offset3:
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
280 PUTC ' '
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
281 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
282 movff SSPBUF,lo ;
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
283
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
284 call I2CREAD2 ; Skip Profile version
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
285 movff SSPBUF,lo ; read month
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
286
41
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
287 ; movff eeprom_address+0, EventByte ; Store current EEPROM position
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
288 ; movff eeprom_address+1, ProfileFlagByte
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
289 ; Offset to SamplingRate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
290 incf_eeprom_address d'32' ; Macro, that adds 8Bit to eeprom_address:2 with banking at 0x8000
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
291 call I2CREAD ; Read Sampling rate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
292 movff SSPBUF,samplesecs_value ; Copy sampling rate
41
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
293 decf_eeprom_address d'32' ; Macro, that subtracts 8Bit from eeprom_address:2 with banking at 0x8000
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
294 ; movff EventByte, eeprom_address+0 ; Re-Store current EEPROM position
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
295 ; movff ProfileFlagByte, eeprom_address+1 ; Re-Store current EEPROM position
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
296
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
297 ;display_profile2a:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
298
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
299 movff lo,convert_value_temp+0 ; Month (in lo, see above)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
300 call I2CREAD2 ; Day
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
301 movff SSPBUF,convert_value_temp+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
302 call I2CREAD2 ; Year
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
303 movff SSPBUF,convert_value_temp+2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
304 call PLED_convert_date ; converts into "DD/MM/YY" or "MM/DD/YY" or "YY/MM/DD" in postinc2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
305
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
306 PUTC ' '
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
307 call I2CREAD2 ; hour
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
308 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
309 output_99x
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
310 PUTC ':'
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
311 call I2CREAD2 ; Minute
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
312 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
313 output_99x
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
314 call word_processor ; Display 1st row of details
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
315
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
316 WIN_TOP .25
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
317 WIN_LEFT .05
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
318 lfsr FSR2,letter
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
319 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
320 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
321 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
322 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
323 movff lo,xA+0 ; calculate y-scale for profile display
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
324 movff hi,xA+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
325 movlw d'164' ; 164pixel height available
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
326 movwf xB+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
327 clrf xB+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
328 call div16x16 ; does xA/xB=xC
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
329 movff xC+0,sim_pressure+0 ; holds LOW byte of y-scale (mbar/pixel!)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
330 movff xC+1,sim_pressure+1 ; holds HIGH byte of y-scale (mbar/pixel!)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
331 incf sim_pressure+0,F ; increase one, because there may be a remainder
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
332 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
333 addwfc sim_pressure+1,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
334
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
335 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
336 output_16dp d'3' ; max. depth
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
337 STRCAT "m "
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
338 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
339 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
340 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
341 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
342
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
343 movff lo,xA+0 ; calculate x-scale for profile display
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
344 movff hi,xA+1 ; calculate total diveseconds first
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
345 movlw d'60' ; 60seconds are one minute
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
346 movwf xB+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
347 clrf xB+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
348 call mult16x16 ; result is in xC:2 !
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
349
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
350 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
351 output_16 ; divetime minutes
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
352 PUTC d'39'
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
353 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
354 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
355 movf lo,W ; add seconds to total seconds
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
356 addwf xC+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
357 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
358 addwfc xC+1 ; xC:2 now holds total dive seconds!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
359 movff xC+0,xA+0 ; now calculate x-scale value
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
360 movff xC+1,xA+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
361 movlw d'159' ; 159pix width available
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
362 movwf xB+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
363 clrf xB+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
364 call div16x16 ; xA/xB=xC
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
365 movff xC+0,xA+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
366 movff xC+1,xA+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
367 movf samplesecs_value,W ; devide through sample interval!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
368 movwf xB+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
369 clrf xB+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
370 call div16x16 ; xA/xB=xC
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
371 movff xC+0,profile_temp+0 ; store value (use any #xC sample, skip xC-1) into temp registers
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
372 movff xC+1,profile_temp+1 ; store value (use any #xC sample, skip xC-1) into temp registers
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
373 incf profile_temp+0,F ; increase one, because there may be a remainder
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
374 movlw d'0'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
375 addwfc profile_temp+1,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
376
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
377 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
378 output_99x ; divetime seconds
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
379 STRCAT "\" "
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
380 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
381 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
382 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
383 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
384 movlw d'3'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
385 movwf ignore_digits
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
386 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
387 output_16dp d'2' ; temperature
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
388 STRCAT_PRINT "°C" ; Display 2nd row of details
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
389
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
390 WIN_TOP .50
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
391 WIN_LEFT .05
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
392 lfsr FSR2,letter
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
393
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
394 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
395 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
396 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
397 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
398 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
399 output_16 ; Air pressure before dive
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
400 STRCAT "mbar Desat "
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
401
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
402 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
403 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
404 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
405 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
406 call convert_time ; converts hi:lo in minutes to hours (hi) and minutes (lo)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
407 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
408 movf lo,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
409 movff hi,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
410 movwf hi ; exchange lo and hi...
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
411 output_8 ; Hours
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
412 PUTC ':'
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
413 movff hi,lo ; Minutes
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
414 output_99x
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
415 bcf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
416 call word_processor ; display 3rd page of details
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
417
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
418 call I2CREAD2 ; Skip Gas1 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
419 call I2CREAD2 ; Skip Gas1 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
420 call I2CREAD2 ; Skip Gas2 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
421 call I2CREAD2 ; Skip Gas2 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
422 call I2CREAD2 ; Skip Gas3 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
423 call I2CREAD2 ; Skip Gas3 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
424 call I2CREAD2 ; Skip Gas4 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
425 call I2CREAD2 ; Skip Gas4 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
426 call I2CREAD2 ; Skip Gas5 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
427 call I2CREAD2 ; Skip Gas5 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
428 call I2CREAD2 ; Skip Gas6 current O2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
429 call I2CREAD2 ; Skip Gas6 current HE
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
430 call I2CREAD2 ; Skip Start Gas
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
431 call I2CREAD2 ; Skip Firmware x
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
432 call I2CREAD2 ; Skip Firmware y
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
433 call I2CREAD2 ; Skip battery
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
434 call I2CREAD2 ; Skip battery
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
435 call I2CREAD2 ; Skip Sampling rate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
436 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
437 movff SSPBUF,divisor_temperature ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
438 bcf divisor_temperature,4 ; Clear information length
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
439 bcf divisor_temperature,5
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
440 bcf divisor_temperature,6
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
441 bcf divisor_temperature,7
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
442 incf divisor_temperature,F ; increase divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
443 movff divisor_temperature,logbook_temp1 ; Store as temp, too
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
444 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
445 movff SSPBUF,divisor_deco ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
446 bcf divisor_deco,4 ; Clear information length
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
447 bcf divisor_deco,5
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
448 bcf divisor_deco,6
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
449 bcf divisor_deco,7
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
450 movff divisor_deco,logbook_temp2 ; Store as temp, too
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
451 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
452 movff SSPBUF,divisor_tank ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
453 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
454 movff SSPBUF,divisor_ppo2 ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
455 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
456 movff SSPBUF,divisor_deco_debug ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
457 call I2CREAD2 ; Read divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
458 movff SSPBUF,divisor_nuy2 ; Store divisor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
459 call I2CREAD2 ; Read Salinity
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
460 call I2CREAD2 ; Skip Dummy byte
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
461
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
462 display_profile2d:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
463 ; Start Profile display
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
464
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
465 movlw color_deepblue
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
466 WIN_BOX_COLOR .75, .239, .0, .159
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
467
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
468 call I2CREAD2 ; skip 0xFB (Header-end)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
469 clrf timeout_counter2 ; here: used as counter for depth readings
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
470 call I2CREAD2 ; skip 0xFB (Header-end)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
471 movlw d'158'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
472 movwf ignore_digits ; here: used as counter for x-pixels
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
473 bcf second_FD ; clear flag
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
474 movlw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
475 movwf timeout_counter3 ; here: used as colum x2 (Start at Colum 5)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
476 movlw d'75' ; Zero-m row
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
477 movwf apnoe_mins ; here: used for fill between rows
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
478 incf timeout_counter3,W ; Init Column
146
c09b0be2e1e6 PIXEL_WRITE macros.
JeanDo
parents: 142
diff changeset
479
c09b0be2e1e6 PIXEL_WRITE macros.
JeanDo
parents: 142
diff changeset
480 INIT_PIXEL_WROTE timeout_counter3 ; pixel x2
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
481
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
482 profile_display_loop:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
483 movff profile_temp+0,profile_temp2+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
484 movff profile_temp+1,profile_temp2+1 ; 16Bit x-scaler
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
485 incf profile_temp2+1,F
42
da553e5c7a90 1.63 in work
heinrichsweikamp
parents: 41
diff changeset
486 tstfsz profile_temp2+0 ; Must not be Zero
da553e5c7a90 1.63 in work
heinrichsweikamp
parents: 41
diff changeset
487 bra profile_display_loop2 ; Not Zero!
da553e5c7a90 1.63 in work
heinrichsweikamp
parents: 41
diff changeset
488 incf profile_temp2+0,F ; Zero, Increase!
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
489
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
490 profile_display_loop2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
491 rcall profile_view_get_depth ; reads depth, ignores temp and profile data -> hi, lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
492
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
493 btfsc second_FD ; end-of profile reached?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
494 bra profile_display_loop_done ; Yes, skip all remaining pixels
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
495
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
496 movff sim_pressure+0,xB+0 ; devide pressure in mbar/quant for row offsett
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
497 movff sim_pressure+1,xB+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
498 movff lo,xA+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
499 movff hi,xA+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
500 call div16x16 ; xA/xB=xC
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
501 movlw d'75'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
502 addwf xC+0,F ; add 75 pixel offset to result
41
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
503
44
475a9e536d77 1.63beta release
heinrichsweikamp
parents: 42
diff changeset
504 btfsc STATUS,C ; Ignore potential profile errors
475a9e536d77 1.63beta release
heinrichsweikamp
parents: 42
diff changeset
505 movff apnoe_mins,xC+0
41
3ab1188651af 1.63 in work...
heinrichsweikamp
parents: 33
diff changeset
506
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
507 call profile_display_fill ; In this column between this row (xC+0) and the last row (apnoe_mins)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
508 movff xC+0,apnoe_mins ; Store last row for fill routine
142
8b75ba28d641 Screen-flipping custom function.
JeanDo
parents: 130
diff changeset
509 incf timeout_counter3,F
8b75ba28d641 Screen-flipping custom function.
JeanDo
parents: 130
diff changeset
510
146
c09b0be2e1e6 PIXEL_WRITE macros.
JeanDo
parents: 142
diff changeset
511 PIXEL_WRITE timeout_counter3,xC+0 ; Set col(0..159) x row (0..239), put a std color pixel.
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
512
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
513 profile_display_skip_loop1: ; skips readings!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
514 dcfsnz profile_temp2+0,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
515 bra profile_display_loop3 ; check 16bit....
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
516
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
517 rcall profile_view_get_depth ; reads depth, ignores temp and profile data
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
518 bra profile_display_skip_loop1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
519
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
520 profile_display_loop3:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
521 decfsz profile_temp2+1,F ; 16 bit x-scaler test
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
522 bra profile_display_skip_loop1 ; skips readings!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
523
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
524 decfsz ignore_digits,F ; counts x-pixels to zero
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
525 bra profile_display_loop ; Not ready yet
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
526 ; Done.
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
527 profile_display_loop_done:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
528 bcf sleepmode ; clear some flags
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
529 bcf menubit2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
530 bcf menubit3
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
531 bcf switch_right
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
532 bcf switch_left
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
533 clrf timeout_counter2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
534
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
535 display_profile_loop:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
536 call check_switches_logbook
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
537
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
538 btfsc menubit2 ; SET/MENU?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
539 bra exit_profileview ; back to list
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
540
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
541 btfsc menubit3 ; ENTER?
33
6e5db85382a2 Speedy simulator! New Deco code test 1
heinrichsweikamp
parents: 17
diff changeset
542 bra exit_profileview ; back to list
6e5db85382a2 Speedy simulator! New Deco code test 1
heinrichsweikamp
parents: 17
diff changeset
543 ; bra profileview_menu ; Switch to the Profileview menu
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
544
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
545 btfsc onesecupdate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
546 call timeout_surfmode ; timeout
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
547
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
548 btfsc onesecupdate
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
549 call set_dive_modes ; check, if divemode must be entered
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
550
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
551 bcf onesecupdate ; one second update
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
552
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
553 btfsc sleepmode ; Timeout?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
554 bra exit_profileview ; back to list
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
555
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
556 btfsc divemode
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
557 goto restart ; Enter Divemode if required
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
558
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
559 bra display_profile_loop ; wait for something to do
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
560
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
561 profile_display_fill: ; In this column between this row (xC+0) and the last row (apnoe_mins), keep xC+0!!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
562 ; First, check if xC+0>apnoe_mins or xC+0<aponoe_mins
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
563 movf xC+0,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
564 cpfseq apnoe_mins ; xC+0 = apone_mins?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
565 bra profile_display_fill2 ; No!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
566 return
130
d721b49b8934 Fixed profile view (Logbook)
Heinrichsweikamp
parents: 123
diff changeset
567
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
568 profile_display_fill2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
569 movf xC+0,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
570 cpfsgt apnoe_mins ; apnoe_mins>xC+0?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
571 bra profile_display_fill_up ; Yes!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
572
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
573 profile_display_fill_down: ; Fill downwards from apone_mins to xC+0!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
574 movff apnoe_mins,xC+1 ; Copy
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
575 profile_display_fill_down2: ; Loop
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
576 decf xC+1,F
142
8b75ba28d641 Screen-flipping custom function.
JeanDo
parents: 130
diff changeset
577
146
c09b0be2e1e6 PIXEL_WRITE macros.
JeanDo
parents: 142
diff changeset
578 HALF_PIXEL_WRITE xC+1 ; Updates just row (0..239)
3
3cf8af30b36e v1.51 beta
heinrichsweikamp
parents: 0
diff changeset
579
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
580 movf xC+0,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
581 cpfseq xC+1 ; Loop until xC+1=xC+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
582 bra profile_display_fill_down2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
583 return ; apnoe_mins and xC+0 are untouched
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
584
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
585 profile_display_fill_up: ; Fill upwards from xC+0 to apone_mins!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
586 movff xC+0,xC+1 ; Copy
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
587 profile_display_fill_up2: ; Loop
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
588 decf xC+1,F
142
8b75ba28d641 Screen-flipping custom function.
JeanDo
parents: 130
diff changeset
589
146
c09b0be2e1e6 PIXEL_WRITE macros.
JeanDo
parents: 142
diff changeset
590 HALF_PIXEL_WRITE xC+1 ; Updates just row (0..239)
3
3cf8af30b36e v1.51 beta
heinrichsweikamp
parents: 0
diff changeset
591
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
592 movf apnoe_mins,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
593 cpfseq xC+1 ; Loop until xC+1=apnoe_mins
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
594 bra profile_display_fill_up2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
595 return ; apnoe_mins and xC+0 are untouched
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
596
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
597 profile_view_get_depth:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
598 call I2CREAD2 ; read first depth
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
599 movff SSPBUF,lo ; low value
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
600 call I2CREAD2 ; read first depth
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
601 movff SSPBUF,hi ; high value
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
602 call I2CREAD2 ; read Profile Flag Byte
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
603 movff SSPBUF,timeout_counter2 ; Read Profile Flag Byte
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
604 bcf event_occured ; clear flag
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
605 btfsc timeout_counter2,7
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
606 bsf event_occured ; We also have an Event byte!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
607 bcf timeout_counter2,7 ; Clear Event Byte Flag (If any)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
608 ; timeout_counter2 now holds the number of additional bytes to ignore (0-127)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
609 movlw 0xFD ; end of profile bytes?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
610 cpfseq lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
611 bra profile_view_get_depth_new1 ; no 0xFD
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
612 movlw 0xFD ; end of profile bytes?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
613 cpfseq hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
614 bra profile_view_get_depth_new1 ; no 0xFD
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
615 bsf second_FD ; End found! Set Flag! Skip remaining pixels!
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
616 return
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
617
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
618 profile_view_get_depth_new1:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
619 tstfsz timeout_counter2 ; Any bytes to ignore
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
620 bra profile_view_get_depth_new3 ; Yes (1-127)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
621 return ; No (0)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
622
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
623 ; timeout_counter2 now holds the number of additional bytes to ignore (0-127)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
624 profile_view_get_depth_new3:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
625 call I2CREAD2 ; ignore byte
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
626 decfsz timeout_counter2,F ; reduce counter
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
627 bra profile_view_get_depth_new3 ; Loop
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
628 return
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
629
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
630 exit_profileview:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
631 bcf sleepmode
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
632 clrf timeout_counter2 ; restore all registers to build same page again
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
633 movff decodata+0,eeprom_address+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
634 movff decodata+1,eeprom_address+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
635 movff max_pressure+0,divemins+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
636 movff max_pressure+1,divemins+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
637 movff mintemp+0, divenumber
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
638 decf divenumber,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
639 bcf all_dives_shown
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
640
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
641 decf menupos2,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
642
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
643 clrf menupos3 ; here: used row on current page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
644 movlw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
645 movwf menupos ; here: active row on current page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
646 incf menupos2,F ; start new page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
647 call PLED_ClearScreen ; clear details/profile
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
648 bra menu_logbook1b ; start search
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
649
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
650 next_logbook2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
651 btfsc all_dives_shown ; all shown
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
652 goto menu_logbook1 ; all reset
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
653
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
654 clrf menupos3
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
655 movlw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
656 movwf menupos ;
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
657 incf menupos2,F ; start new screen
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
658 call PLED_ClearScreen
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
659
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
660 next_logbook:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
661 movff eeprom_header_address+0,eeprom_address+0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
662 movff eeprom_header_address+1,eeprom_address+1 ; continue search here
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
663 goto menu_logbook1b
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
664
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
665 check_switches_logbook:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
666 btfsc switch_right
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
667 bsf menubit3
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
668 btfsc switch_left
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
669 bsf menubit2 ; Enter
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
670 return
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
671
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
672 next_logbook3:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
673 incf menupos,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
674 movlw d'7'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
675 cpfseq menupos ; =7?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
676 bra next_logbook3a ; No
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
677 bra next_logbook2 ; yes, new page please
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
678
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
679 next_logbook3a:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
680 incf menupos3,W ;
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
681 cpfseq menupos
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
682 bra next_logbook3b
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
683 movlw d'6'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
684 movwf menupos ; Jump directly to exit if page is not full
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
685
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
686 next_logbook3b:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
687 clrf timeout_counter2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
688 call PLED_logbook_cursor
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
689
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
690 bcf switch_right
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
691 bcf menubit3 ; clear flag
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
692 bra menu_logbook_loop
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
693
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
694 display_listdive:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
695 bsf logbook_page_not_empty ; Page not empty
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
696 incf menupos3,F
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
697
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
698 btfsc logbook_header_drawn ; "Logbook already displayed?
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
699 bra display_listdive1a
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
700 call PLED_topline_box ; Draw box
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
701 WIN_INVERT .1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
702 DISPLAYTEXT .26 ; "Logbook"
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
703 WIN_INVERT .0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
704 bsf logbook_header_drawn
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
705
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
706 display_listdive1a:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
707 WIN_LEFT .20
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
708
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
709 movf menupos2,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
710 mullw d'5'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
711 movf PRODL,W
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
712 subwf divenumber,W ; current row on page
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
713
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
714 mullw d'30' ; x30
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
715 movf PRODL,W ; is pixel-row for entry
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
716 addlw d'5' ; +5 Pixel, so list entries are at rows 35,65,95,125,155,185
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
717 movff WREG,win_top
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
718
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
719 lfsr FSR2,letter
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
720 movff divenumber,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
721 output_99x ; # of dive
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
722 PUTC ' '
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
723 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
724 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
725 movlw d'13'
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
726 cpfsgt lo ; Skip if lo>13
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
727 bra display_listdive2 ; use old format
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
728
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
729 call I2CREAD2 ; Skip Profile version
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
730 movff SSPBUF,lo ; in new format, read month
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
731
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
732 display_listdive2:
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
733 movff lo,convert_value_temp+0 ; Month (in lo, see above)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
734 call I2CREAD2 ; Day
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
735 movff SSPBUF,convert_value_temp+1
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
736 call I2CREAD2 ; Year
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
737 movff SSPBUF,convert_value_temp+2
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
738 call PLED_convert_date_short ; converts into "DD/MM" or "MM/DD" or "MM/DD" in s
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
739
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
740
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
741 call I2CREAD2 ; hours (Skip)
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
742 call I2CREAD2 ; minutes (skip)
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
743 PUTC ' '
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
744 call I2CREAD2 ; Depth
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
745 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
746 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
747 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
748 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
749 bsf ignore_digit5 ; Do not display 1cm figure
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
750 output_16dp d'3' ; max. depth
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
751 STRCAT "m "
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
752 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
753 movff SSPBUF,lo
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
754 call I2CREAD2
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
755 movff SSPBUF,hi
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
756 bsf leftbind
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
757 output_16 ; Divetime minutes
123
6a94f96e9cea The big cleanup, again.
JeanDo
parents: 44
diff changeset
758 STRCAT_PRINT "'" ; Display header-row in list
0
96a35aeda5f2 Initial setup
heinrichsweikamp
parents:
diff changeset
759 return