Mercurial > public > ostc4
comparison Discovery/Src/tMenuEditGasOC.c @ 295:718e5feded62
Merged in janlmulder/ostc4/div-fixes-6 (pull request #23)
Cleanup VPM, NDL to 240 min, and more cleanup
author | heinrichsweikamp <bitbucket@heinrichsweikamp.com> |
---|---|
date | Mon, 13 May 2019 13:37:34 +0000 |
parents | ba229a012ac7 |
children | 3f09b283d993 |
comparison
equal
deleted
inserted
replaced
287:ba9d99a2e310 | 295:718e5feded62 |
---|---|
146 } | 146 } |
147 | 147 |
148 | 148 |
149 void openEdit_DiveGasSelect_Subroutine(uint8_t line, uint8_t ccr) | 149 void openEdit_DiveGasSelect_Subroutine(uint8_t line, uint8_t ccr) |
150 { | 150 { |
151 SDiveState * pState; | |
152 uint8_t setpoint; | 151 uint8_t setpoint; |
153 | 152 |
154 if(actual_menu_content == MENU_DIVE_REAL) | 153 editGasPage.pGasLine = stateUsed->diveSettings.gas; |
155 { | |
156 pState = stateRealGetPointerWrite(); | |
157 editGasPage.pGasLine = pState->diveSettings.gas; | |
158 } | |
159 else | |
160 { | |
161 pState = stateSimGetPointerWrite(); | |
162 editGasPage.pGasLine = pState->diveSettings.gas; | |
163 } | |
164 | 154 |
165 if(ccr) | 155 if(ccr) |
166 { | 156 { |
167 editGasPage.gasID = line + NUM_OFFSET_DILUENT; | 157 editGasPage.gasID = line + NUM_OFFSET_DILUENT; |
168 setpoint = pState->lifeData.actualGas.setPoint_cbar; | 158 setpoint = stateUsed->lifeData.actualGas.setPoint_cbar; |
169 } | 159 } |
170 else | 160 else |
171 { | 161 { |
172 editGasPage.gasID = line; | 162 editGasPage.gasID = line; |
173 setpoint = 0; | 163 setpoint = 0; |
176 for(int i=0;i<(1+ (2*NUM_GASES));i++) | 166 for(int i=0;i<(1+ (2*NUM_GASES));i++) |
177 editGasPage.pGasLine[i].note.ub.first = 0; | 167 editGasPage.pGasLine[i].note.ub.first = 0; |
178 | 168 |
179 editGasPage.pGasLine[editGasPage.gasID].note.ub.active = 1; | 169 editGasPage.pGasLine[editGasPage.gasID].note.ub.active = 1; |
180 editGasPage.pGasLine[editGasPage.gasID].note.ub.first = 1; | 170 editGasPage.pGasLine[editGasPage.gasID].note.ub.first = 1; |
181 setActualGas_DM(&pState->lifeData,editGasPage.gasID,setpoint); | 171 setActualGas_DM(&stateUsedWrite->lifeData,editGasPage.gasID,setpoint); |
182 } | 172 } |
183 | 173 |
184 /* extra gas and gas on/off option */ | 174 /* extra gas and gas on/off option */ |
185 void openEdit_SpecialDiveGasMenu(uint8_t ccr) | 175 void openEdit_SpecialDiveGasMenu(uint8_t ccr) |
186 { | 176 { |
187 char text[32]; | 177 char text[32]; |
188 uint8_t oxygen, helium, gasOffset, textpointer, lineCount, ptrGas; | 178 uint8_t oxygen, helium, gasOffset, textpointer, lineCount, ptrGas; |
189 SDiveState * pState; | 179 //SDiveState * pState; |
190 | 180 |
191 if(actual_menu_content == MENU_DIVE_REAL) | 181 editGasPage.pGasLine = stateUsed->diveSettings.gas; |
192 { | |
193 pState = stateRealGetPointerWrite(); | |
194 editGasPage.pGasLine = pState->diveSettings.gas; | |
195 } | |
196 else | |
197 { | |
198 pState = stateSimGetPointerWrite(); | |
199 editGasPage.pGasLine = pState->diveSettings.gas; | |
200 } | |
201 if(ccr) | 182 if(ccr) |
202 { | 183 { |
203 editGasPage.setpoint = pState->lifeData.actualGas.setPoint_cbar; | 184 editGasPage.setpoint = stateUsed->lifeData.actualGas.setPoint_cbar; |
204 } | 185 } |
205 editGasPage.ccr = ccr; | 186 editGasPage.ccr = ccr; |
206 | 187 |
207 set_globalState_Menu_Line(6); | 188 set_globalState_Menu_Line(6); |
208 | 189 |
320 if(newHelium > 95) | 301 if(newHelium > 95) |
321 newHelium = 95; | 302 newHelium = 95; |
322 if((newOxygen + newHelium) > 100) | 303 if((newOxygen + newHelium) > 100) |
323 newOxygen = 100 - newHelium; | 304 newOxygen = 100 - newHelium; |
324 | 305 |
325 SDiveState * pDiveState = 0; | 306 //SDiveState * pDiveState = 0; |
326 | 307 |
327 for(int i=1;i<=(2*NUM_GASES);i++) | 308 for(int i=1;i<=(2*NUM_GASES);i++) |
328 editGasPage.pGasLine[i].note.ub.first = 0; | 309 editGasPage.pGasLine[i].note.ub.first = 0; |
329 | 310 |
330 if(actual_menu_content == MENU_DIVE_REAL) | 311 setActualGas_ExtraGas(&stateUsedWrite->lifeData, newOxygen, newHelium, 0); |
331 pDiveState = stateRealGetPointerWrite(); | |
332 else | |
333 pDiveState = stateSimGetPointerWrite(); | |
334 | |
335 setActualGas_ExtraGas(&pDiveState->lifeData, newOxygen, newHelium, 0); | |
336 tMEGas_check_switch_to_bailout(); | 312 tMEGas_check_switch_to_bailout(); |
337 return EXIT_TO_HOME; | 313 return EXIT_TO_HOME; |
338 } | 314 } |
339 if(action == ACTION_BUTTON_NEXT) | 315 if(action == ACTION_BUTTON_NEXT) |
340 { | 316 { |
355 } | 331 } |
356 | 332 |
357 | 333 |
358 void tMEGas_check_switch_to_bailout(void) | 334 void tMEGas_check_switch_to_bailout(void) |
359 { | 335 { |
360 SDiveState *pState; | 336 if(stateUsed->diveSettings.diveMode == DIVEMODE_CCR) |
361 | 337 { |
362 if(actual_menu_content == MENU_DIVE_REAL) | 338 stateUsedWrite->diveSettings.diveMode = DIVEMODE_OC; |
363 pState = stateRealGetPointerWrite(); | |
364 else | |
365 pState = stateSimGetPointerWrite(); | |
366 | |
367 if(pState->diveSettings.diveMode == DIVEMODE_CCR) | |
368 { | |
369 pState->diveSettings.diveMode = DIVEMODE_OC; | |
370 block_diluent_page(); | 339 block_diluent_page(); |
371 } | 340 } |
372 } | 341 } |
373 | 342 |
374 | 343 |