38
+ − 1 ///////////////////////////////////////////////////////////////////////////////
+ − 2 /// -*- coding: UTF-8 -*-
+ − 3 ///
+ − 4 /// \file Discovery/Src/t7.c
+ − 5 /// \brief Main Template file for dive mode 7x
+ − 6 /// \author Heinrichs Weikamp gmbh
+ − 7 /// \date 23-April-2014
+ − 8 ///
+ − 9 /// \details
+ − 10 ///
+ − 11 /// $Id$
+ − 12 ///////////////////////////////////////////////////////////////////////////////
+ − 13 /// \par Copyright (c) 2014-2018 Heinrichs Weikamp gmbh
+ − 14 ///
+ − 15 /// This program is free software: you can redistribute it and/or modify
+ − 16 /// it under the terms of the GNU General Public License as published by
+ − 17 /// the Free Software Foundation, either version 3 of the License, or
+ − 18 /// (at your option) any later version.
+ − 19 ///
+ − 20 /// This program is distributed in the hope that it will be useful,
+ − 21 /// but WITHOUT ANY WARRANTY; without even the implied warranty of
+ − 22 /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ − 23 /// GNU General Public License for more details.
+ − 24 ///
+ − 25 /// You should have received a copy of the GNU General Public License
+ − 26 /// along with this program. If not, see <http://www.gnu.org/licenses/>.
+ − 27 //////////////////////////////////////////////////////////////////////////////
+ − 28
+ − 29 /* Includes ------------------------------------------------------------------*/
737
+ − 30 #include <stdlib.h>
+ − 31
38
+ − 32 #include "t7.h"
595
+ − 33 #include "t3.h"
527
+ − 34 #include "settings.h"
38
+ − 35 #include "data_exchange_main.h"
868
+ − 36 #include "data_central.h"
38
+ − 37 #include "decom.h"
+ − 38 #include "gfx_fonts.h"
+ − 39 #include "logbook_miniLive.h"
+ − 40 #include "math.h"
662
+ − 41 #include "tComm.h"
38
+ − 42 #include "tHome.h"
+ − 43 #include "simulation.h"
+ − 44 #include "timer.h"
+ − 45 #include "unit.h"
369
+ − 46 #include "motion.h"
527
+ − 47 #include "configuration.h"
740
+ − 48 #include "base.h"
775
46c6d2380d4e
Add a shortcuts to change the setpoint to the loop to the 'normal' display when diving. It is only shown when diving in CCR mode and on the loop.
heinrichsweikamp
diff
changeset
+ − 49 #include "tMenuEditSetpoint.h"
907
+ − 50 #include "vpm.h"
38
+ − 51
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 52 #define TIMER_ACTION_DELAY_S 10
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 53
38
+ − 54 /* Private function prototypes -----------------------------------------------*/
+ − 55
+ − 56 void t7_refresh_surface(void);
+ − 57 void t7_refresh_surface_debugmode(void);
+ − 58 void t7_refresh_divemode(void);
+ − 59 void t7_refresh_sleep_design_fun(void);
+ − 60 void t7_refresh_divemode_userselected_left_lower_corner(void);
+ − 61 void t7_refresh_customview(void);
405
+ − 62 uint8_t t7_customview_disabled(uint8_t view);
38
+ − 63
+ − 64 void draw_frame(_Bool PluginBoxHeader, _Bool LinesOnTheSides, uint8_t colorBox, uint8_t colorLinesOnTheSide);
+ − 65
+ − 66 void t7_tissues(const SDiveState * pState);
+ − 67 void t7_compass(uint16_t ActualHeading, uint16_t UserSetHeading);
+ − 68 void t7_SummaryOfLeftCorner(void);
+ − 69 void t7_debug(void);
+ − 70
+ − 71 void t7_miniLiveLogProfile(void);
+ − 72 void t7_logo_OSTC(void);
672
+ − 73 void t7_ChargerView(void);
38
+ − 74
+ − 75 uint8_t t7_test_customview_warnings(void);
+ − 76 void t7_show_customview_warnings(void);
+ − 77
+ − 78 uint8_t t7_test_customview_warnings_surface_mode(void);
+ − 79 void t7_show_customview_warnings_surface_mode(void);
+ − 80
+ − 81 uint8_t t7_customtextPrepare(char * text);
+ − 82
882
+ − 83 static void t7_drawAcentGraph(uint8_t color);
+ − 84 static uint8_t t7_drawSlowExitGraph(void);
899
+ − 85 static void t7_showPosition(void);
882
+ − 86
193
+ − 87 /* Imported function prototypes ---------------------------------------------*/
38
+ − 88 extern uint8_t write_gas(char *text, uint8_t oxygen, uint8_t helium);
+ − 89
+ − 90 /* Exported variables --------------------------------------------------------*/
+ − 91
+ − 92 /* Private variables ---------------------------------------------------------*/
+ − 93
+ − 94 GFX_DrawCfgScreen t7screen;
+ − 95 GFX_DrawCfgScreen t7screenCompass;
+ − 96
+ − 97 /* left 3 fields
+ − 98 * right 3 fields
+ − 99 * centered one field on top of customview, one below
+ − 100 * customview header + customview + warning
+ − 101 */
+ − 102 GFX_DrawCfgWindow t7l1, t7l2, t7l3;
+ − 103 GFX_DrawCfgWindow t7r1, t7r2, t7r3;
+ − 104 GFX_DrawCfgWindow t7c1, t7batt, t7c2, t7charge, t7voltage;
+ − 105 GFX_DrawCfgWindow t7cH, t7cC, t7cW, t7cY0free;
+ − 106 GFX_DrawCfgWindow t7pCompass;
+ − 107 GFX_DrawCfgWindow t7surfaceL, t7surfaceR;
+ − 108
442
+ − 109 uint8_t selection_customview = LLC_Temperature;
38
+ − 110
+ − 111 uint8_t updateNecessary = 0;
+ − 112
+ − 113 typedef struct{
+ − 114 uint32_t pointer;
+ − 115 uint32_t x0;
+ − 116 uint32_t y0;
+ − 117 uint32_t width;
+ − 118 uint32_t height;
+ − 119 } SBackground;
+ − 120
+ − 121 SBackground background =
+ − 122 {
166
+ − 123 .pointer = 0,
38
+ − 124 };
+ − 125
+ − 126
+ − 127 /* Private types -------------------------------------------------------------*/
+ − 128
882
+ − 129 typedef enum
+ − 130 {
+ − 131 SE_INIT = 0,
907
+ − 132 SE_REINIT,
882
+ − 133 SE_ACTIVE,
+ − 134 SE_END
+ − 135 } SSlowExitState;
+ − 136
38
+ − 137 const uint8_t customviewsSurfaceStandard[] =
+ − 138 {
+ − 139 // CVIEW_CompassDebug,
+ − 140 CVIEW_Hello,
+ − 141 CVIEW_sensors,
+ − 142 CVIEW_Compass,
+ − 143 CVIEW_Tissues,
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 144 CVIEW_Gaslist,
38
+ − 145 CVIEW_sensors_mV,
672
+ − 146 CVIEW_Charger,
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 147 CVIEW_CcrSummary,
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 148 CVIEW_Timer,
899
+ − 149 #ifdef ENABLE_GNSS
+ − 150 CVIEW_Position,
+ − 151 #endif
38
+ − 152 CVIEW_END
+ − 153 };
+ − 154
442
+ − 155
+ − 156 static uint8_t selection_custom_field = LLC_Temperature;
+ − 157
837
+ − 158 const uint8_t *customviewsDive = cv_changelist;
38
+ − 159 const uint8_t *customviewsSurface = customviewsSurfaceStandard;
+ − 160
656
+ − 161 #define TEXTSIZE 30
38
+ − 162 /* offset includes line: 2 = line +1
+ − 163 * box (line) is 300 px
+ − 164 * inside is 296 px
+ − 165 * left of box are 249 px ( 0..248)
+ − 166 * right of box are 249 px (551 .. 799)
+ − 167 */
+ − 168
+ − 169 #define CUSTOMBOX_LINE_LEFT (250)
+ − 170 #define CUSTOMBOX_LINE_RIGHT (549)
110
+ − 171 #define CUSTOMBOX_LINE_TOP (0)
+ − 172 #define CUSTOMBOX_LINE_MIDDLE (142)
+ − 173 #define CUSTOMBOX_LINE_BOTTOM (318)
38
+ − 174 #define CUSTOMBOX_INSIDE_OFFSET (2)
+ − 175 #define CUSTOMBOX_OUTSIDE_OFFSET (2)
+ − 176 #define CUSTOMBOX_SPACE_INSIDE (CUSTOMBOX_LINE_RIGHT + 1 - (CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + CUSTOMBOX_INSIDE_OFFSET))
110
+ − 177 #define TOP_LINE_HIGHT (25)
38
+ − 178
336
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 179 #define SHOW_AMBIENTE_SURFACE_DELTA (0.02f)
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 180 #define SHOW_AMBIENTE_DEBOUNCE (0.003f)
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 181
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 182 #define MAX_NUM_SUMMARY_LINES 6
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 183
38
+ − 184 /* Exported functions --------------------------------------------------------*/
+ − 185
+ − 186 void t7_init(void)
+ − 187 {
110
+ − 188
+ − 189 SSettings* pSettings;
+ − 190 pSettings = settingsGetPointer();
+ − 191
442
+ − 192 selection_custom_field = LLC_Temperature;
38
+ − 193 selection_customview = customviewsSurface[0];
+ − 194
+ − 195 t7screen.FBStartAdress = 0;
+ − 196 t7screen.ImageHeight = 480;
+ − 197 t7screen.ImageWidth = 800;
+ − 198 t7screen.LayerIndex = 1;
+ − 199
+ − 200 t7screenCompass.FBStartAdress = 0;
+ − 201 t7screenCompass.ImageHeight = 240;
+ − 202 t7screenCompass.ImageWidth = 1600;
+ − 203 t7screenCompass.LayerIndex = 0;
+ − 204
110
+ − 205 if(!pSettings->FlipDisplay)
+ − 206 {
+ − 207 t7l1.Image = &t7screen;
+ − 208 t7l1.WindowNumberOfTextLines = 2;
+ − 209 t7l1.WindowLineSpacing = 19; // Abstand von Y0
+ − 210 t7l1.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
+ − 211 t7l1.WindowX0 = 0;
+ − 212 t7l1.WindowX1 = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET;
+ − 213 t7l1.WindowY0 = 318;
+ − 214 t7l1.WindowY1 = 479;
+ − 215
+ − 216 t7l2.Image = &t7screen;
+ − 217 t7l2.WindowNumberOfTextLines = 2;
884
+ − 218 t7l2.WindowLineSpacing = 12; // Abstand von Y0
110
+ − 219 t7l2.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
+ − 220 t7l2.WindowX0 = 0;
+ − 221 t7l2.WindowX1 = t7l1.WindowX1;
+ − 222 t7l2.WindowY0 = 142;
+ − 223 t7l2.WindowY1 = t7l1.WindowY0 - 5;
+ − 224
+ − 225 t7l3.Image = &t7screen;
+ − 226 t7l3.WindowNumberOfTextLines = 2;
+ − 227 t7l3.WindowLineSpacing = 58; // Abstand von Y0
+ − 228 t7l3.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
+ − 229 t7l3.WindowX0 = 0;
+ − 230 t7l3.WindowX1 = t7l1.WindowX1;
+ − 231 t7l3.WindowY0 = 0;
+ − 232 t7l3.WindowY1 = t7l2.WindowY0 - 5;
+ − 233
+ − 234 t7r1.Image = &t7screen;
+ − 235 t7r1.WindowNumberOfTextLines = 2;
+ − 236 t7r1.WindowLineSpacing = t7l1.WindowLineSpacing;
+ − 237 t7r1.WindowTab = 100;
+ − 238 t7r1.WindowX0 = 550;
+ − 239 t7r1.WindowX1 = 799;
+ − 240 t7r1.WindowY0 = t7l1.WindowY0;
+ − 241 t7r1.WindowY1 = 479;
+ − 242
+ − 243 t7r2.Image = &t7screen;
+ − 244 t7r2.WindowNumberOfTextLines = 2;
+ − 245 t7r2.WindowLineSpacing = t7l2.WindowLineSpacing;
+ − 246 t7r2.WindowTab = 100;
+ − 247 t7r2.WindowX0 = 550;
+ − 248 t7r2.WindowX1 = 799;
+ − 249 t7r2.WindowY0 = t7l2.WindowY0;
+ − 250 t7r2.WindowY1 = t7l2.WindowY1;
+ − 251
+ − 252 t7r3.Image = &t7screen;
+ − 253 t7r3.WindowNumberOfTextLines = 2;
+ − 254 t7r3.WindowLineSpacing = 0;//t7l3.WindowLineSpacing;
+ − 255 t7r3.WindowTab = 100;
+ − 256 t7r3.WindowX0 = CUSTOMBOX_LINE_RIGHT + CUSTOMBOX_OUTSIDE_OFFSET;
+ − 257 t7r3.WindowX1 = 799;
+ − 258 t7r3.WindowY0 = t7l3.WindowY0;
+ − 259 t7r3.WindowY1 = t7l3.WindowY1;
+ − 260
+ − 261 t7cC.Image = &t7screen;
+ − 262 t7cC.WindowNumberOfTextLines = 3;
+ − 263 t7cC.WindowLineSpacing = 95; // Abstand von Y0
+ − 264 t7cC.WindowTab = 100;
+ − 265 t7cC.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 266 t7cC.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 267 t7cC.WindowY0 = 90;
+ − 268 t7cC.WindowY1 = 434 - 95;
+ − 269
+ − 270 t7cH.Image = &t7screen;
+ − 271 t7cH.WindowNumberOfTextLines = 1;
+ − 272 t7cH.WindowLineSpacing = 95; // Abstand von Y0
+ − 273 t7cH.WindowTab = 100;
+ − 274 t7cH.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 275 t7cH.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 276 t7cH.WindowY0 = 434 - 94;
+ − 277 t7cH.WindowY1 = 434;
+ − 278
+ − 279 t7cW.Image = &t7screen;
+ − 280 t7cW.WindowNumberOfTextLines = 3;
+ − 281 t7cW.WindowLineSpacing = 95; // Abstand von Y0
+ − 282 t7cW.WindowTab = 100;
+ − 283 t7cW.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 284 t7cW.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 285 t7cW.WindowY0 = 90;
+ − 286 t7cW.WindowY1 = 434 - 95;
+ − 287
+ − 288
+ − 289 t7surfaceL.Image = &t7screen;
+ − 290 t7surfaceL.WindowNumberOfTextLines = 9;
+ − 291 t7surfaceL.WindowLineSpacing = 53;
+ − 292 t7surfaceL.WindowTab = 100;
+ − 293 t7surfaceL.WindowX0 = 0;
+ − 294 t7surfaceL.WindowX1 = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET;
+ − 295 t7surfaceL.WindowY0 = 0;
+ − 296 t7surfaceL.WindowY1 = 480;
+ − 297
+ − 298 t7surfaceR.Image = &t7screen;
+ − 299 t7surfaceR.WindowNumberOfTextLines = 9;
+ − 300 t7surfaceR.WindowLineSpacing = 53;
+ − 301 t7surfaceR.WindowTab = 100;
+ − 302 t7surfaceR.WindowX0 = CUSTOMBOX_LINE_RIGHT + CUSTOMBOX_OUTSIDE_OFFSET;
+ − 303 t7surfaceR.WindowX1 = 800;
+ − 304 t7surfaceR.WindowY0 = 0;
+ − 305 t7surfaceR.WindowY1 = 480;
+ − 306
+ − 307 t7cY0free.Image = &t7screen;
+ − 308 t7cY0free.WindowNumberOfTextLines = 1;
+ − 309 t7cY0free.WindowLineSpacing = 95;
+ − 310 t7cY0free.WindowTab = 100;
+ − 311 t7cY0free.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 312 t7cY0free.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 313 t7cY0free.WindowY0 = 90;
+ − 314 t7cY0free.WindowY1 = 434 - 95;
+ − 315
+ − 316 t7batt.Image = &t7screen;
+ − 317 t7batt.WindowNumberOfTextLines = 1;
+ − 318 t7batt.WindowLineSpacing = 10;
+ − 319 t7batt.WindowTab = 100;
+ − 320 t7batt.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 321 t7batt.WindowX0 = t7batt.WindowX1 - (52+52);
+ − 322 t7batt.WindowY1 = 479;
+ − 323 t7batt.WindowY0 = t7batt.WindowY1 - 25;
+ − 324
+ − 325 t7charge.Image = &t7screen;
+ − 326 t7charge.WindowNumberOfTextLines = 1;
+ − 327 t7charge.WindowLineSpacing = 10;
+ − 328 t7charge.WindowTab = 100;
+ − 329 t7charge.WindowX1 = t7batt.WindowX1 - 18;
+ − 330 t7charge.WindowX0 = t7charge.WindowX1 - 14;
+ − 331 t7charge.WindowY1 = 479;
+ − 332 t7charge.WindowY0 = t7batt.WindowY1 - 25;
+ − 333
+ − 334 t7voltage.Image = &t7screen;
+ − 335 t7voltage.WindowNumberOfTextLines = 1;
+ − 336 t7voltage.WindowLineSpacing = 10;
+ − 337 t7voltage.WindowTab = 100;
145
+ − 338 t7voltage.WindowX0 = t7charge.WindowX0 - 10;
110
+ − 339 t7voltage.WindowX1 = t7voltage.WindowX0 + (18*3)+ 9;
+ − 340 t7voltage.WindowY1 = 479;
+ − 341 t7voltage.WindowY0 = t7batt.WindowY1 - 25;
+ − 342
+ − 343 t7c1.Image = &t7screen;
+ − 344 t7c1.WindowNumberOfTextLines = 1;
+ − 345 t7c1.WindowLineSpacing = 10;
+ − 346 t7c1.WindowTab = 100;
+ − 347 t7c1.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 348 t7c1.WindowX1 = t7batt.WindowX0 - 18;
+ − 349 t7c1.WindowY0 = 435;
+ − 350 t7c1.WindowY1 = 479;
+ − 351
+ − 352 t7c2.Image = &t7screen;
+ − 353 t7c2.WindowNumberOfTextLines = 1;
+ − 354 t7c2.WindowLineSpacing = 0; // Abstand von Y0
+ − 355 t7c2.WindowTab = 100;
+ − 356 t7c2.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 357 t7c2.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
+ − 358 t7c2.WindowY0 = 0;
+ − 359 t7c2.WindowY1 = 69;
+ − 360
+ − 361 t7pCompass.Image = &t7screenCompass;
+ − 362 t7pCompass.WindowNumberOfTextLines = 1;
+ − 363 t7pCompass.WindowLineSpacing = 100; // Abstand von Y0
+ − 364 t7pCompass.WindowTab = 100;
+ − 365 t7pCompass.WindowX0 = 0;
+ − 366 t7pCompass.WindowX1 = 1600-1;
+ − 367 t7pCompass.WindowY0 = 0;
+ − 368 t7pCompass.WindowY1 = 100-1;
+ − 369 }
+ − 370 else
+ − 371 {
+ − 372 /* 6 segments (left / right) used to show data during dive */
+ − 373
38
+ − 374 t7l1.Image = &t7screen;
+ − 375 t7l1.WindowNumberOfTextLines = 2;
+ − 376 t7l1.WindowLineSpacing = 19; // Abstand von Y0
+ − 377 t7l1.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
110
+ − 378 t7l1.WindowX0 = CUSTOMBOX_LINE_RIGHT + CUSTOMBOX_OUTSIDE_OFFSET;
+ − 379 t7l1.WindowX1 = 799;
+ − 380 t7l1.WindowY0 = CUSTOMBOX_LINE_TOP;
+ − 381 t7l1.WindowY1 = 150 + TOP_LINE_HIGHT;
38
+ − 382
+ − 383 t7l2.Image = &t7screen;
+ − 384 t7l2.WindowNumberOfTextLines = 2;
884
+ − 385 t7l2.WindowLineSpacing = 12; // Abstand von Y0
38
+ − 386 t7l2.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
110
+ − 387 t7l2.WindowX0 = t7l1.WindowX0;
38
+ − 388 t7l2.WindowX1 = t7l1.WindowX1;
110
+ − 389 t7l2.WindowY0 = t7l1.WindowY1 + 5;
+ − 390 t7l2.WindowY1 = t7l2.WindowY0 + 146;
38
+ − 391
+ − 392 t7l3.Image = &t7screen;
+ − 393 t7l3.WindowNumberOfTextLines = 2;
+ − 394 t7l3.WindowLineSpacing = 58; // Abstand von Y0
+ − 395 t7l3.WindowTab = 100; // vermtl. ohne Verwendung in diesem Fenster
110
+ − 396 t7l3.WindowX0 = t7l1.WindowX0;
+ − 397 t7l3.WindowX1 = t7l1.WindowX1;;
+ − 398 t7l3.WindowY0 = 479 - 150;
+ − 399 t7l3.WindowY1 = 479;
38
+ − 400
+ − 401 t7r1.Image = &t7screen;
+ − 402 t7r1.WindowNumberOfTextLines = 2;
+ − 403 t7r1.WindowLineSpacing = t7l1.WindowLineSpacing;
+ − 404 t7r1.WindowTab = 100;
110
+ − 405 t7r1.WindowX0 = 0;
+ − 406 t7r1.WindowX1 = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET;
38
+ − 407 t7r1.WindowY0 = t7l1.WindowY0;
110
+ − 408 t7r1.WindowY1 = t7l1.WindowY1;
38
+ − 409
+ − 410 t7r2.Image = &t7screen;
+ − 411 t7r2.WindowNumberOfTextLines = 2;
+ − 412 t7r2.WindowLineSpacing = t7l2.WindowLineSpacing;
+ − 413 t7r2.WindowTab = 100;
110
+ − 414 t7r2.WindowX0 = t7r1.WindowX0;
+ − 415 t7r2.WindowX1 = t7r1.WindowX1;
38
+ − 416 t7r2.WindowY0 = t7l2.WindowY0;
+ − 417 t7r2.WindowY1 = t7l2.WindowY1;
+ − 418
+ − 419 t7r3.Image = &t7screen;
+ − 420 t7r3.WindowNumberOfTextLines = 2;
+ − 421 t7r3.WindowLineSpacing = 0;//t7l3.WindowLineSpacing;
+ − 422 t7r3.WindowTab = 100;
110
+ − 423 t7r3.WindowX0 = t7r1.WindowX0;
+ − 424 t7r3.WindowX1 = t7r1.WindowX1;
38
+ − 425 t7r3.WindowY0 = t7l3.WindowY0;
+ − 426 t7r3.WindowY1 = t7l3.WindowY1;
+ − 427
110
+ − 428 /* screen for CustomText / serial number */
38
+ − 429 t7cC.Image = &t7screen;
+ − 430 t7cC.WindowNumberOfTextLines = 3;
+ − 431 t7cC.WindowLineSpacing = 95; // Abstand von Y0
+ − 432 t7cC.WindowTab = 100;
+ − 433 t7cC.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 434 t7cC.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
110
+ − 435 t7cC.WindowY0 = 165; //90;
+ − 436 t7cC.WindowY1 = 415;
+ − 437
+ − 438 /* used by warning message box */
38
+ − 439 t7cH.Image = &t7screen;
+ − 440 t7cH.WindowNumberOfTextLines = 1;
+ − 441 t7cH.WindowLineSpacing = 95; // Abstand von Y0
+ − 442 t7cH.WindowTab = 100;
+ − 443 t7cH.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 444 t7cH.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
110
+ − 445 t7cH.WindowY0 = 46; //480 - 434;
+ − 446 t7cH.WindowY1 = 390 - 46;// - 90; //46 + 390; //480 - (434 - 94); //434;
+ − 447
+ − 448 /* used by warning custom box */
38
+ − 449 t7cW.Image = &t7screen;
+ − 450 t7cW.WindowNumberOfTextLines = 3;
+ − 451 t7cW.WindowLineSpacing = 95; // Abstand von Y0
+ − 452 t7cW.WindowTab = 100;
+ − 453 t7cW.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 454 t7cW.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
110
+ − 455 t7cW.WindowY0 = 480 - (434 - 90);
+ − 456 t7cW.WindowY1 = 480 - 90; //434 - 95;
+ − 457
+ − 458 /* time and environment */
38
+ − 459 t7surfaceL.Image = &t7screen;
+ − 460 t7surfaceL.WindowNumberOfTextLines = 9;
+ − 461 t7surfaceL.WindowLineSpacing = 53;
+ − 462 t7surfaceL.WindowTab = 100;
110
+ − 463 t7surfaceL.WindowX0 = CUSTOMBOX_LINE_RIGHT + CUSTOMBOX_OUTSIDE_OFFSET;
+ − 464 t7surfaceL.WindowX1 = 799;
38
+ − 465 t7surfaceL.WindowY0 = 0;
110
+ − 466 t7surfaceL.WindowY1 = 479;
38
+ − 467
+ − 468 t7surfaceR.Image = &t7screen;
+ − 469 t7surfaceR.WindowNumberOfTextLines = 9;
+ − 470 t7surfaceR.WindowLineSpacing = 53;
+ − 471 t7surfaceR.WindowTab = 100;
110
+ − 472 t7surfaceR.WindowX0 = 0;
+ − 473 t7surfaceR.WindowX1 = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET;
38
+ − 474 t7surfaceR.WindowY0 = 0;
110
+ − 475 t7surfaceR.WindowY1 = 479;
+ − 476
+ − 477 /* info screen in the middle */
38
+ − 478 t7cY0free.Image = &t7screen;
+ − 479 t7cY0free.WindowNumberOfTextLines = 1;
+ − 480 t7cY0free.WindowLineSpacing = 95;
+ − 481 t7cY0free.WindowTab = 100;
+ − 482 t7cY0free.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 483 t7cY0free.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
110
+ − 484 t7cY0free.WindowY0 = 115;
+ − 485 t7cY0free.WindowY1 = 365;
+ − 486
+ − 487 /* voltage value (V or %) */
+ − 488 t7voltage.Image = &t7screen;
+ − 489 t7voltage.WindowNumberOfTextLines = 1;
+ − 490 t7voltage.WindowLineSpacing = 10;
+ − 491 t7voltage.WindowTab = 100;
+ − 492 t7voltage.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 493 t7voltage.WindowX1 = t7voltage.WindowX0 + (18*3) +9;
+ − 494 t7voltage.WindowY1 = TOP_LINE_HIGHT;
+ − 495 t7voltage.WindowY0 = 0;
+ − 496
+ − 497 /* battery symbol */
38
+ − 498 t7batt.Image = &t7screen;
+ − 499 t7batt.WindowNumberOfTextLines = 1;
+ − 500 t7batt.WindowLineSpacing = 10;
+ − 501 t7batt.WindowTab = 100;
110
+ − 502 t7batt.WindowX0 = t7voltage.WindowX1;
+ − 503 t7batt.WindowX1 = t7batt.WindowX0 + (52);
+ − 504 t7batt.WindowY1 = TOP_LINE_HIGHT;
+ − 505 t7batt.WindowY0 = 0;
+ − 506
+ − 507 /* charger symbol */
38
+ − 508 t7charge.Image = &t7screen;
+ − 509 t7charge.WindowNumberOfTextLines = 1;
+ − 510 t7charge.WindowLineSpacing = 10;
+ − 511 t7charge.WindowTab = 100;
110
+ − 512 t7charge.WindowX1 = t7batt.WindowX0 - 18;
38
+ − 513 t7charge.WindowX0 = t7charge.WindowX1 - 14;
110
+ − 514
+ − 515 t7charge.WindowY1 = TOP_LINE_HIGHT;
+ − 516 t7charge.WindowY0 = 0;
+ − 517
+ − 518 /* show dive mode OC / CC */
38
+ − 519 t7c1.Image = &t7screen;
+ − 520 t7c1.WindowNumberOfTextLines = 1;
+ − 521 t7c1.WindowLineSpacing = 10;
+ − 522 t7c1.WindowTab = 100;
110
+ − 523 t7c1.WindowX0 = t7batt.WindowX1 + 18; //CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 524 t7c1.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET; //t7batt.WindowX1 + 18;
+ − 525 t7c1.WindowY0 = 0;
+ − 526 t7c1.WindowY1 = 479 - 435;
+ − 527
+ − 528 /* Gas warnings and exit Sim*/
38
+ − 529 t7c2.Image = &t7screen;
+ − 530 t7c2.WindowNumberOfTextLines = 1;
+ − 531 t7c2.WindowLineSpacing = 0; // Abstand von Y0
+ − 532 t7c2.WindowTab = 100;
+ − 533 t7c2.WindowX0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 534 t7c2.WindowX1 = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_INSIDE_OFFSET;
110
+ − 535 t7c2.WindowY0 = 480 - 69;
+ − 536 t7c2.WindowY1 = 479;
+ − 537
+ − 538 /* Rotating compass */
38
+ − 539 t7pCompass.Image = &t7screenCompass;
+ − 540 t7pCompass.WindowNumberOfTextLines = 1;
+ − 541 t7pCompass.WindowLineSpacing = 100; // Abstand von Y0
+ − 542 t7pCompass.WindowTab = 100;
+ − 543 t7pCompass.WindowX0 = 0;
+ − 544 t7pCompass.WindowX1 = 1600-1;
110
+ − 545 t7pCompass.WindowY0 = 479 - 75;
+ − 546 t7pCompass.WindowY1 = 479;
+ − 547
+ − 548 }
38
+ − 549
+ − 550 init_t7_compass();
+ − 551 }
+ − 552
+ − 553
+ − 554 void t7_refresh_sleepmode_fun(void)
+ − 555 {
+ − 556 uint32_t oldScreen;
+ − 557
+ − 558 oldScreen = t7screen.FBStartAdress;
+ − 559 t7screen.FBStartAdress = getFrame(22);
+ − 560
+ − 561 t7_refresh_sleep_design_fun();
+ − 562
+ − 563 if(get_globalState() == StStop)
+ − 564 {
166
+ − 565 GFX_SetFramesTopBottom(t7screen.FBStartAdress, 0,480);
38
+ − 566 }
+ − 567 releaseFrame(22,oldScreen);
+ − 568 }
+ − 569
+ − 570
+ − 571 void t7_refresh(void)
+ − 572 {
+ − 573 static uint8_t last_mode = MODE_SURFACE;
+ − 574 SStateList status;
+ − 575 get_globalStateList(&status);
+ − 576
+ − 577 t7screen.FBStartAdress = getFrame(22);
+ − 578
+ − 579 background.pointer = 0;
+ − 580
+ − 581 if(stateUsed->mode == MODE_DIVE)
+ − 582 {
837
+ − 583 /* T7 refresh is usally called at start of dive. Based on divesettings the design will be changed and T7 no longer called */
38
+ − 584 if(stateUsed->diveSettings.diveMode == DIVEMODE_Gauge)
+ − 585 {
+ − 586 settingsGetPointer()->design = 5;
+ − 587 releaseAllFramesExcept(22,t7screen.FBStartAdress);
+ − 588 releaseFrame(22,t7screen.FBStartAdress);
+ − 589 return;
+ − 590 }
+ − 591 else if(stateUsed->diveSettings.diveMode == DIVEMODE_Apnea)
+ − 592 {
+ − 593 settingsGetPointer()->design = 6;
+ − 594 releaseAllFramesExcept(22,t7screen.FBStartAdress);
+ − 595 releaseFrame(22,t7screen.FBStartAdress);
+ − 596 return;
+ − 597 }
+ − 598 else
+ − 599 {
837
+ − 600 if(last_mode != MODE_DIVE)
+ − 601 {
+ − 602 last_mode = MODE_DIVE;
+ − 603 /* lower left corner primary */
+ − 604 selection_custom_field = settingsGetPointer()->tX_userselectedLeftLowerCornerPrimary;
+ − 605 /* custom view primary OR debug if automatic return is off | T7 is default dive view => also initialize big font view */
+ − 606 if((settingsGetPointer()->tX_customViewTimeout == 0) && (settingsGetPointer()->showDebugInfo))
+ − 607 {
+ − 608 selection_customview = CVIEW_noneOrDebug;
+ − 609 t3_select_customview(CVIEW_noneOrDebug);
+ − 610 }
+ − 611 else
+ − 612 {
+ − 613 selection_customview = settingsGetPointer()->tX_customViewPrimary;
+ − 614 }
+ − 615 t7_change_customview(ACTION_END);
+ − 616
+ − 617 if((settingsGetPointer()->MotionDetection != MOTION_DETECT_OFF))
+ − 618 {
+ − 619 InitMotionDetection();
+ − 620 }
+ − 621
+ − 622 if((settingsGetPointer()->extraDisplay == EXTRADISPLAY_BFACTIVE) && ( settingsGetPointer()->design == 7))
+ − 623 {
+ − 624 settingsGetPointer()->design = 3;
+ − 625 t3_set_customview_to_primary();
+ − 626 releaseAllFramesExcept(22,t7screen.FBStartAdress);
+ − 627 releaseFrame(22,t7screen.FBStartAdress);
+ − 628 set_globalState(StD);
+ − 629 return;
+ − 630 }
+ − 631 }
+ − 632
+ − 633 if(status.page == PageSurface)
+ − 634 set_globalState(StD);
+ − 635
+ − 636 t7_refresh_divemode();
+ − 637 }
38
+ − 638 }
+ − 639 else // from if(stateUsed->mode == MODE_DIVE)
+ − 640 {
+ − 641 if(last_mode != MODE_SURFACE)
+ − 642 {
+ − 643 last_mode = MODE_SURFACE;
+ − 644 selection_customview = customviewsSurface[0];
369
+ − 645 InitMotionDetection();
553
+ − 646 resetFocusState();
38
+ − 647 }
+ − 648 if(status.page == PageDive)
+ − 649 set_globalState(StS);
+ − 650
+ − 651 if(settingsGetPointer()->showDebugInfo)
+ − 652 t7_refresh_surface_debugmode();
+ − 653 else
+ − 654 t7_refresh_surface();
+ − 655 }
+ − 656
+ − 657 tHome_show_lost_connection_count(&t7screen);
+ − 658
+ − 659 if(status.base == BaseHome)
+ − 660 {
+ − 661 if(background.pointer)
+ − 662 {
+ − 663 GFX_SetFrameTop(t7screen.FBStartAdress);
+ − 664 GFX_SetFrameBottom(background.pointer,background.x0 , background.y0, background.width, background.height);
+ − 665 }
+ − 666 else
166
+ − 667 GFX_SetFramesTopBottom(t7screen.FBStartAdress, 0,480);
38
+ − 668 }
+ − 669
+ − 670 releaseAllFramesExcept(22,t7screen.FBStartAdress);
+ − 671 }
+ − 672
+ − 673 /* Private functions ---------------------------------------------------------*/
+ − 674
+ − 675 void t7_fill_surfacetime_helper(SSurfacetime *outArray, uint32_t inputMinutes, uint32_t inputSeconds)
+ − 676 {
+ − 677 inputSeconds += inputMinutes * 60;
+ − 678
+ − 679 outArray->Total = inputSeconds;
+ − 680
+ − 681 outArray->Days = inputSeconds / 86400;// (24*60*60);
+ − 682 inputSeconds -= 86400 * (uint32_t)outArray->Days;
+ − 683
+ − 684 outArray->Hours = inputSeconds / 3600;// (60*60);
+ − 685 inputSeconds -= 3600 * (uint32_t)outArray->Hours;
+ − 686
+ − 687 outArray->Minutes = inputSeconds / 60;;
+ − 688 inputSeconds -= 60 * (uint32_t)outArray->Minutes;
+ − 689
+ − 690 outArray->Seconds = inputSeconds;
+ − 691 }
+ − 692
+ − 693 void t7_refresh_sleep_design_fun(void)
+ − 694 {
+ − 695 static uint16_t state = 0;
+ − 696 uint16_t ytop = 0;
+ − 697
+ − 698 state +=1;
+ − 699 if(state > 800)
+ − 700 state = 1;
+ − 701
+ − 702 if(state > 400)
+ − 703 ytop = 800 - state;
+ − 704 else
+ − 705 ytop = 0 + state;
178
d36596281501
Minor: Replace stupid "Sleep Sleep Sleep" message with something more meaningful
heinrichsweikamp
diff
changeset
+ − 706 Gfx_write_label_var(&t7screen, 300,800, ytop,&FontT48,CLUT_Font020,"Shutting down...");
38
+ − 707 }
+ − 708
+ − 709 void t7_refresh_surface(void)
+ − 710 {
336
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 711 static float debounceAmbientPressure = 0;
672
+ − 712 static uint8_t lastChargeStatus = 0;
38
+ − 713 char text[256];
567
+ − 714 char timeSuffix;
+ − 715 uint8_t hours;
527
+ − 716 uint8_t loop, textIdx;
38
+ − 717 uint8_t date[3], year,month,day;
+ − 718 uint32_t color;
+ − 719 uint8_t customview_warnings = 0;
740
+ − 720 SButtonLock ButtonLockState;
38
+ − 721
+ − 722 RTC_DateTypeDef Sdate;
+ − 723 RTC_TimeTypeDef Stime;
+ − 724 RTC_DateTypeDef SdateFirmware;
+ − 725
+ − 726 uint8_t dateNotSet = 0;
+ − 727
+ − 728 uint8_t oxygen_percentage, gasOffset, actualGasID;
457
+ − 729 #ifdef ENABLE_BOTTLE_SENSOR
442
+ − 730 uint16_t bottleFirstGas_bar;
457
+ − 731 #endif
38
+ − 732 point_t start, stop;//, other;
+ − 733
110
+ − 734 SSettings* pSettings;
+ − 735 pSettings = settingsGetPointer();
+ − 736
+ − 737
38
+ − 738 // update in all customview modes
+ − 739 if(DataEX_check_RTE_version__needs_update() || font_update_required())
+ − 740 updateNecessary = 1;
+ − 741 else
+ − 742 updateNecessary = 0;
+ − 743
+ − 744 /* buttons */
740
+ − 745 ButtonLockState = get_ButtonLock();
+ − 746 if(ButtonLockState == LOCK_OFF)
+ − 747 {
+ − 748 text[0] = TXT_2BYTE;
+ − 749 text[1] = TXT2BYTE_ButtonLogbook;
+ − 750 text[2] = 0;
+ − 751 write_content_simple(&t7screen, 0, 799, 479-TOP_LINE_HIGHT, &FontT24,text,CLUT_ButtonSurfaceScreen);
+ − 752
+ − 753 text[0] = '\001';
+ − 754 text[1] = TXT_2BYTE;
+ − 755 text[2] = TXT2BYTE_ButtonView;
+ − 756 text[3] = 0;
+ − 757 write_content_simple(&t7screen, 0, 799, 479-TOP_LINE_HIGHT, &FontT24,text,CLUT_ButtonSurfaceScreen);
+ − 758
+ − 759 text[0] = '\002';
+ − 760 text[1] = TXT_2BYTE;
+ − 761 text[2] = TXT2BYTE_ButtonMenu;
+ − 762 text[3] = 0;
+ − 763 write_content_simple(&t7screen, 0, 799, 479-TOP_LINE_HIGHT, &FontT24,text,CLUT_ButtonSurfaceScreen);
+ − 764 }
+ − 765 else
+ − 766 {
+ − 767 switch(ButtonLockState)
+ − 768 {
+ − 769 default:
+ − 770 case LOCK_1: snprintf(text,255,"\a\001 ");
+ − 771 break;
+ − 772 case LOCK_2: snprintf(text,255,"\a\002 ");
+ − 773 break;
+ − 774 case LOCK_3: snprintf(text,255,"\a ");
+ − 775 break;
+ − 776 }
+ − 777 write_content_simple(&t7screen, 0, 799, 479-TOP_LINE_HIGHT, &FontT24,text,CLUT_ButtonSurfaceScreen);
+ − 778 // GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 779 }
38
+ − 780 /* was power on reset */
+ − 781 //.....
+ − 782 /* removed hw 160802 in V1.1.1
+ − 783 if(errorsInSettings)
+ − 784 {
+ − 785 sprintf(text,"Settings: %u",errorsInSettings);
+ − 786 GFX_write_string_color(&FontT42,&t7surfaceR,text,4,CLUT_WarningRed);
+ − 787 }
+ − 788 else
+ − 789 */
662
+ − 790 if(DataEX_was_power_on()) {
38
+ − 791 GFX_write_string_color(&FontT42,&t7surfaceR,"cold start",4,CLUT_WarningRed);
662
+ − 792 }
38
+ − 793
+ − 794 /* time and date */
+ − 795 translateDate(stateUsed->lifeData.dateBinaryFormat, &Sdate);
+ − 796 translateTime(stateUsed->lifeData.timeBinaryFormat, &Stime);
+ − 797
+ − 798 firmwareGetDate(&SdateFirmware);
+ − 799 if(tHome_DateCode(&Sdate) < tHome_DateCode(&SdateFirmware))
+ − 800 dateNotSet = 1;
+ − 801 else
+ − 802 dateNotSet = 0;
+ − 803 /*
+ − 804 if(Stime.Seconds % 2)
+ − 805 snprintf(text,255,"\001%02d:%02d",Stime.Hours,Stime.Minutes);
+ − 806 else
527
+ − 807 snprintf(text,255,"\001%02d\031:\020%02d",Stime.Hours,Stime.Minutes);
38
+ − 808 GFX_write_string(&FontT54,&t7surfaceR,text,3);
+ − 809 */
+ − 810 // debug version:
567
+ − 811
+ − 812 if (settingsGetPointer()->amPMTime)
+ − 813 {
+ − 814 if (Stime.Hours > 11)
+ − 815 {
+ − 816 timeSuffix = 'P';
+ − 817 }
+ − 818 else
+ − 819 {
+ − 820 timeSuffix = 'A';
+ − 821 }
+ − 822
+ − 823 if (Stime.Hours % 12 == 0)
+ − 824 {
+ − 825 hours = 12;
+ − 826 }
+ − 827 else
+ − 828 {
+ − 829 hours = (Stime.Hours % 12);
+ − 830 }
+ − 831
+ − 832 if(Stime.Seconds % 2)
+ − 833 snprintf(text,255,"\001%02d:%02d:%02d\016\016%cM\017",hours,Stime.Minutes,Stime.Seconds,timeSuffix);
+ − 834 else if(dateNotSet)
+ − 835 snprintf(text,255,"\001\031%02d:%02d:%02d\016\016%cM\017\020",hours,Stime.Minutes,Stime.Seconds,timeSuffix);
+ − 836 else
+ − 837 snprintf(text,255,"\001%02d\031:\020%02d:%02d\016\016%cM\017",hours,Stime.Minutes,Stime.Seconds,timeSuffix);
+ − 838 GFX_write_string(&FontT48,&t7surfaceR,text,3);
+ − 839 }
38
+ − 840 else
567
+ − 841 {
+ − 842 if(Stime.Seconds % 2)
+ − 843 snprintf(text,255,"\001%02d:%02d:%02d",Stime.Hours,Stime.Minutes,Stime.Seconds);
+ − 844 else if(dateNotSet)
+ − 845 snprintf(text,255,"\001\031%02d:%02d:%02d\020",Stime.Hours,Stime.Minutes,Stime.Seconds);
+ − 846 else
+ − 847 snprintf(text,255,"\001%02d\031:\020%02d:%02d",Stime.Hours,Stime.Minutes,Stime.Seconds);
+ − 848 GFX_write_string(&FontT54,&t7surfaceR,text,3);
+ − 849 }
38
+ − 850
+ − 851 if(settingsGetPointer()->date_format == DDMMYY)
+ − 852 {
+ − 853 day = 0;
+ − 854 month = 1;
+ − 855 year = 2;
+ − 856 }
+ − 857 else
+ − 858 if(settingsGetPointer()->date_format == MMDDYY)
+ − 859 {
+ − 860 day = 1;
+ − 861 month = 0;
+ − 862 year = 2;
+ − 863 }
+ − 864 else
+ − 865 {
+ − 866 day = 2;
+ − 867 month = 1;
+ − 868 year = 0;
+ − 869 }
+ − 870 date[day] = Sdate.Date;
+ − 871 date[month] = Sdate.Month;
+ − 872 date[year] = Sdate.Year;
+ − 873
+ − 874 if((Stime.Seconds % 2) || (dateNotSet == 0))
+ − 875 snprintf(text,255,"\001%02d.%02d.%02d",date[0],date[1],date[2]);
+ − 876 else
527
+ − 877 snprintf(text,255,"\001\031%02d.%02d.%02d",date[0],date[1],date[2]);
38
+ − 878
+ − 879 GFX_write_string(&FontT54,&t7surfaceR,text,5);
+ − 880
+ − 881 if(!DataEX_was_power_on() && !errorsInSettings)
+ − 882 {
+ − 883 text[0] = '\001';
+ − 884 text[1] = '\004';
481
+ − 885 text[2] = '\016';
+ − 886 text[3] = '\016';
+ − 887 text[4] = TXT_2BYTE;
+ − 888 text[5] = TXT2BYTE_Sunday;
+ − 889 text[6] = 0;
38
+ − 890 if(Sdate.WeekDay != RTC_WEEKDAY_SUNDAY)
481
+ − 891 text[5] += Sdate.WeekDay;
38
+ − 892
+ − 893 if(!(Stime.Seconds % 2) && (dateNotSet == 1))
527
+ − 894 text[1] = '\031';
38
+ − 895
481
+ − 896 GFX_write_string(&FontT48,&t7surfaceR,text,4);
38
+ − 897 }
+ − 898
+ − 899 /* DEBUG uTick Pressure and Compass */
+ − 900 /*
+ − 901 snprintf(text,255,"\001%u",stateRealGetPointer()->pressure_uTick_new - stateRealGetPointer()->pressure_uTick_old);
+ − 902 GFX_write_string(&FontT42,&t7surfaceR,text,1);
+ − 903 snprintf(text,255,"\001%u",HAL_GetTick() - stateRealGetPointer()->pressure_uTick_local_new);
+ − 904 GFX_write_string(&FontT42,&t7surfaceR,text,2);
+ − 905
+ − 906 snprintf(text,255,"\001%u",stateRealGetPointer()->compass_uTick_new - stateRealGetPointer()->compass_uTick_old);
+ − 907 GFX_write_string(&FontT42,&t7surfaceR,text,6);
+ − 908 snprintf(text,255,"\001%u",HAL_GetTick() - stateRealGetPointer()->compass_uTick_local_new);
+ − 909 GFX_write_string(&FontT42,&t7surfaceR,text,7);
+ − 910
+ − 911 static uint32_t bildschirmRefresh = 0;
+ − 912 snprintf(text,255,"\001%u",HAL_GetTick() - bildschirmRefresh);
+ − 913 GFX_write_string(&FontT42,&t7surfaceR,text,8);
+ − 914 bildschirmRefresh = HAL_GetTick();
+ − 915
+ − 916 static uint16_t bildschirmRefreshCount = 1;
+ − 917 if(bildschirmRefreshCount>10)
+ − 918 bildschirmRefreshCount = 1;
+ − 919 for(int i=0;i<bildschirmRefreshCount;i++)
+ − 920 text[i] = '.';
+ − 921 text[bildschirmRefreshCount++] = 0;
+ − 922 GFX_write_string(&FontT42,&t7surfaceR,text,4);
+ − 923 */
+ − 924
+ − 925 /* noFlyTime or DesaturationTime */
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 926 if((stateUsed->lifeData.no_fly_time_minutes) && ((!display_count_high_time) || (stateUsed->lifeData.desaturation_time_minutes == 0)))
38
+ − 927 {
+ − 928 SSurfacetime NoFlyTime = {0,0,0,0};
+ − 929 t7_fill_surfacetime_helper(&NoFlyTime,stateUsed->lifeData.no_fly_time_minutes, 0);
+ − 930
+ − 931 if(NoFlyTime.Days)
+ − 932 {
+ − 933 snprintf(text,30,"\001%02d\016\016d\017 %02d\016\016h\017",NoFlyTime.Days, NoFlyTime.Hours);
+ − 934 }
+ − 935 else
+ − 936 {
+ − 937 snprintf(text,20,"\001%02d:%02d",NoFlyTime.Hours, NoFlyTime.Minutes);
+ − 938 }
+ − 939
+ − 940 GFX_write_string(&FontT54,&t7surfaceR,text,7);
+ − 941
+ − 942 text[0] = '\001';
+ − 943 text[1] = '\022';
+ − 944 text[2] = '\016';
+ − 945 text[3] = '\016';
+ − 946 text[4] = TXT_2BYTE;
+ − 947 text[5] = TXT2BYTE_noFly;
+ − 948 text[6] = 0;
+ − 949 GFX_write_string(&FontT48,&t7surfaceR,text,6);
+ − 950 }
+ − 951 else
+ − 952 if(stateUsed->lifeData.desaturation_time_minutes)
+ − 953 {
+ − 954 SSurfacetime DesatTime = {0,0,0,0};
+ − 955 t7_fill_surfacetime_helper(&DesatTime,stateUsed->lifeData.desaturation_time_minutes, 0);
+ − 956
+ − 957 if(DesatTime.Days)
+ − 958 {
+ − 959 snprintf(text,30,"\001%02d\016\016d\017 %02d\016\016h\017",DesatTime.Days, DesatTime.Hours);
+ − 960 }
+ − 961 else
+ − 962 {
+ − 963 snprintf(text,20,"\001%02d:%02d",DesatTime.Hours, DesatTime.Minutes);
+ − 964 }
+ − 965 GFX_write_string(&FontT54,&t7surfaceR,text,7);
+ − 966
+ − 967 text[0] = '\001';
+ − 968 text[1] = '\022';
+ − 969 text[2] = '\016';
+ − 970 text[3] = '\016';
+ − 971 text[4] = TXT_2BYTE;
+ − 972 text[5] = TXT2BYTE_Desaturation;
+ − 973 text[6] = 0;
+ − 974 GFX_write_string(&FontT48,&t7surfaceR,text,6);
+ − 975 }
+ − 976
+ − 977 /* Time since last dive */
+ − 978 if(stateUsed->lifeData.surface_time_seconds)
+ − 979 {
+ − 980 SSurfacetime SurfTime = {0,0,0,0};
+ − 981 t7_fill_surfacetime_helper(&SurfTime, 0, stateUsed->lifeData.surface_time_seconds);
+ − 982
+ − 983 if(SurfTime.Days == 0)
+ − 984 {
+ − 985 snprintf(text,20,"\001\022%02d:%02d",SurfTime.Hours, SurfTime.Minutes);
+ − 986 }
+ − 987 else
+ − 988 {
+ − 989 snprintf(text,30,"\001\022%02d\016\016d\017 %02d\016\016h\017",SurfTime.Days, SurfTime.Hours);
+ − 990 }
+ − 991
+ − 992 GFX_write_string(&FontT54,&t7surfaceR,text,2);
+ − 993
+ − 994
+ − 995 text[0] = '\001';
+ − 996 text[1] = '\022';
+ − 997 text[2] = '\016';
+ − 998 text[3] = '\016';
+ − 999 text[4] = TXT_2BYTE;
+ − 1000 text[5] = TXT2BYTE_TimeSinceLastDive;
+ − 1001 text[6] = 0;
+ − 1002 GFX_write_string(&FontT48,&t7surfaceR,text,1);
+ − 1003 }
+ − 1004
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1005 if (stateUsed->timerState == TIMER_STATE_RUNNING && selection_customview != CVIEW_Timer) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1006 int timerRemainingS = pSettings->timerDurationS - (current_second() - stateUsed->timerStartedS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1007 snprintf(text, 20, "\001%u:%02u", timerRemainingS / 60, timerRemainingS % 60);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1008 GFX_write_string(&FontT54, &t7surfaceR, text, 8);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1009 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 1010
38
+ − 1011 /* beta version */
+ − 1012 if( firmwareDataGetPointer()->versionBeta )
+ − 1013 {
+ − 1014 snprintf(text,255,"\025 BETA");
+ − 1015 GFX_write_string(&FontT48,&t7surfaceL,text,2);
+ − 1016 }
+ − 1017
+ − 1018 /* surface pressure and temperature */
+ − 1019 if(stateUsed->sensorErrorsRTE == 0)
+ − 1020 {
336
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1021 if(fabs(stateUsed->lifeData.pressure_surface_bar - stateUsed->lifeData.pressure_ambient_bar) < SHOW_AMBIENTE_SURFACE_DELTA) /* show ambient pressure if difference to surface is significant*/
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1022 {
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1023 snprintf(text,30,"%01.0f\022\016\016 %s", stateUsed->lifeData.pressure_surface_bar * 1000.0f,TEXT_PRESSURE_UNIT);
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1024 }
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1025 else
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1026 {
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1027 if(fabsf(debounceAmbientPressure - stateUsed->lifeData.pressure_ambient_bar) > SHOW_AMBIENTE_DEBOUNCE) /* there might be a jitter ~+-1 HPa on the pressure signal => update only if delta is bigger */
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1028 {
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1029 debounceAmbientPressure = stateUsed->lifeData.pressure_ambient_bar;
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1030 }
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1031 snprintf(text,30,"%01.0f\022\016\016 %s", debounceAmbientPressure * 1000.0f,TEXT_PRESSURE_UNIT);
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1032 }
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1033
38
+ − 1034 GFX_write_string(&FontT48,&t7surfaceL,text,3);
+ − 1035
+ − 1036 if(settingsGetPointer()->nonMetricalSystem)
+ − 1037 snprintf(text,40,"%01.0f\140\022\016\016 fahrenheit",unit_temperature_float(stateUsed->lifeData.temperature_celsius));
+ − 1038 else
+ − 1039 snprintf(text,30,"%01.0f\140\022\016\016 celsius",stateUsed->lifeData.temperature_celsius);
+ − 1040 GFX_write_string(&FontT48,&t7surfaceL,text,4);
+ − 1041 }
+ − 1042 else
+ − 1043 {
103
+ − 1044 snprintf(text,30,"ERR\022\016\016 %s",TEXT_PRESSURE_UNIT);
38
+ − 1045 GFX_write_string(&FontT48,&t7surfaceL,text,3);
+ − 1046
+ − 1047 if(settingsGetPointer()->nonMetricalSystem)
+ − 1048 snprintf(text,40,"ERR\022\016\016 fahrenheit");
+ − 1049 else
+ − 1050 snprintf(text,30,"ERR\022\016\016 celsius");
+ − 1051 GFX_write_string(&FontT48,&t7surfaceL,text,4);
+ − 1052 }
+ − 1053
+ − 1054
+ − 1055 /* gas mix and selection */
+ − 1056 if((stateUsed->diveSettings.diveMode == DIVEMODE_Gauge) || (stateUsed->diveSettings.diveMode == DIVEMODE_Apnea))
+ − 1057 {
+ − 1058 if(stateUsed->diveSettings.diveMode == DIVEMODE_Gauge)
+ − 1059 text[0] = TXT_Gauge;
+ − 1060 else
+ − 1061 text[0] = TXT_Apnoe;
+ − 1062
+ − 1063 text[1] = 0;
+ − 1064 GFX_write_string(&FontT48,&t7surfaceL,text,6);
+ − 1065 }
+ − 1066 else
+ − 1067 {
527
+ − 1068 textIdx = 0;
662
+ − 1069 if(isLoopMode(stateUsed->diveSettings.diveMode))
38
+ − 1070 gasOffset = NUM_OFFSET_DILUENT;
+ − 1071 else
+ − 1072 gasOffset = 0;
527
+ − 1073
+ − 1074 /* Display gas setup */
+ − 1075 for(loop = 1; loop <= NUM_GASES; loop++)
+ − 1076 {
+ − 1077 #ifdef ENABLE_UNUSED_GAS_HIDING
+ − 1078 if(stateUsed->diveSettings.gas[loop+gasOffset].note.ub.off)
+ − 1079 {
+ − 1080 text[textIdx++] = '\021';
+ − 1081 }
+ − 1082 else
+ − 1083 #endif
+ − 1084 if(stateUsed->diveSettings.gas[loop+gasOffset].note.ub.active)
+ − 1085 {
+ − 1086 text[textIdx++]= '\020';
+ − 1087 }
+ − 1088 else
+ − 1089 {
+ − 1090 text[textIdx++]= '\031';
+ − 1091 }
+ − 1092
+ − 1093 text[textIdx++] = '0' + loop;
+ − 1094 text[textIdx++] = '\177';
+ − 1095 text[textIdx++] = '\177';
+ − 1096 text[textIdx++] = 10;
+ − 1097 }
+ − 1098 text[textIdx++] = 0;
38
+ − 1099 GFX_write_string(&FontT48,&t7surfaceL,text,6);
+ − 1100
+ − 1101
+ − 1102 oxygen_percentage = 100;
+ − 1103 oxygen_percentage -= stateUsed->lifeData.actualGas.nitrogen_percentage;
+ − 1104 oxygen_percentage -= stateUsed->lifeData.actualGas.helium_percentage;
+ − 1105
+ − 1106 tHome_gas_writer(oxygen_percentage,stateUsed->lifeData.actualGas.helium_percentage,&text[0]);
+ − 1107 GFX_write_string(&FontT48,&t7surfaceL,text,7);
+ − 1108
+ − 1109 actualGasID = stateUsed->lifeData.actualGas.GasIdInSettings;
442
+ − 1110
448
+ − 1111 #ifdef ENABLE_BOTTLE_SENSOR
38
+ − 1112 bottleFirstGas_bar = stateUsed->lifeData.bottle_bar[actualGasID];
+ − 1113 if(bottleFirstGas_bar)
+ − 1114 {
+ − 1115 snprintf(text,255,"%3u\022\016\016 bar",bottleFirstGas_bar);
+ − 1116 GFX_write_string(&FontT48,&t7surfaceL,text,8);
+ − 1117 }
448
+ − 1118 #endif
38
+ − 1119 // after gas name :-)
+ − 1120 if(actualGasID > gasOffset) // security
+ − 1121 {
110
+ − 1122 if(!pSettings->FlipDisplay)
+ − 1123 {
+ − 1124 start.y = t7surfaceL.WindowY0 + (3 * t7surfaceL.WindowLineSpacing);
+ − 1125 start.x = t7surfaceL.WindowX0 + ((stateUsed->lifeData.actualGas.GasIdInSettings - gasOffset - 1) * 35);
+ − 1126 }
+ − 1127 else
+ − 1128 {
+ − 1129 start.y = t7surfaceR.WindowY0 + (3 * t7surfaceR.WindowLineSpacing);
+ − 1130 start.x = t7surfaceR.WindowX0 + ((stateUsed->lifeData.actualGas.GasIdInSettings - gasOffset - 1) * 35);
+ − 1131 }
+ − 1132
38
+ − 1133 stop.x = start.x + 25;
+ − 1134 stop.y = start.y + 52;
+ − 1135 GFX_draw_box2(&t7screen, start, stop, CLUT_Font020, 1);
+ − 1136 }
+ − 1137 }
+ − 1138
+ − 1139 /* dive mode */
193
+ − 1140 switch (stateUsed->diveSettings.diveMode) {
+ − 1141 case DIVEMODE_CCR:
+ − 1142 GFX_write_string(&FontT24, &t7c1, "\f\002" "CCR", 0);
+ − 1143 break;
662
+ − 1144 case DIVEMODE_PSCR:
+ − 1145 GFX_write_string(&FontT24, &t7c1, "\f\002" "PSCR", 0);
+ − 1146 break;
193
+ − 1147 case DIVEMODE_OC:
+ − 1148 GFX_write_string(&FontT24, &t7c1, "\f\002" "OC", 0);
+ − 1149 break;
+ − 1150 case DIVEMODE_Gauge:
+ − 1151 GFX_write_string(&FontT24, &t7c1, "\f\002" "Gauge", 0);
+ − 1152 break;
+ − 1153 case DIVEMODE_Apnea:
+ − 1154 GFX_write_string(&FontT24, &t7c1, "\f\002" "Apnea", 0);
+ − 1155 break;
+ − 1156 default:
+ − 1157 GFX_write_string(&FontT24, &t7c1, "\f\002" "OC", 0);
+ − 1158 }
38
+ − 1159
+ − 1160 /*battery */
+ − 1161
+ − 1162 text[0] = '3';
+ − 1163 text[1] = '1';
+ − 1164 text[2] = '1';
+ − 1165 text[3] = '1';
+ − 1166 text[4] = '1';
+ − 1167 text[5] = '1';
+ − 1168 text[6] = '1';
+ − 1169 text[7] = '1';
+ − 1170 text[8] = '1';
+ − 1171 text[9] = '1';
+ − 1172 text[10] = '1';
+ − 1173 text[11] = '0';
+ − 1174 text[12] = 0;
+ − 1175
+ − 1176 for(int i=1;i<=10;i++)
+ − 1177 {
+ − 1178 if( stateUsed->lifeData.battery_charge > (9 * i))
+ − 1179 text[i] += 1;
+ − 1180 }
+ − 1181
+ − 1182 if(stateUsed->chargeStatus == CHARGER_off)
+ − 1183 {
+ − 1184 if(stateUsed->warnings.lowBattery)
+ − 1185 {
+ − 1186 if(warning_count_high_time)
+ − 1187 {
+ − 1188 for(int i=1;i<=10;i++)
+ − 1189 text[i] = '1';
+ − 1190 }
+ − 1191 else
+ − 1192 {
+ − 1193 text[1] = '2';
+ − 1194 }
+ − 1195 GFX_write_string_color(&Batt24,&t7batt,text,0,CLUT_WarningRed);
+ − 1196 if((stateUsed->lifeData.battery_charge > 0) && (stateUsed->lifeData.battery_charge < 140))
+ − 1197 {
448
+ − 1198 #ifdef ALWAYS_SHOW_VOLTAGE
432
+ − 1199 // show battery percent and voltage
+ − 1200 snprintf(text,16,"\f\002%u%% \f%.1fV",(uint8_t)stateUsed->lifeData.battery_charge,stateUsed->lifeData.battery_voltage);
448
+ − 1201 #else
+ − 1202 snprintf(text,16,"\004\025\f\002%u%%",(uint8_t)stateUsed->lifeData.battery_charge);
+ − 1203 #endif
38
+ − 1204 if(warning_count_high_time)
+ − 1205 text[0] = '\a';
110
+ − 1206 GFX_write_string(&FontT24,&t7voltage,text,0);
38
+ − 1207 }
+ − 1208 else
+ − 1209 {
+ − 1210 snprintf(text,6,"\f%.1fV",stateUsed->lifeData.battery_voltage);
+ − 1211 GFX_write_string(&FontT24,&t7voltage,text,0);
+ − 1212 }
+ − 1213 }
+ − 1214 else
+ − 1215 {
+ − 1216 GFX_write_string_color(&Batt24,&t7batt,text,0,CLUT_BatteryStandard);
+ − 1217
+ − 1218 if((stateUsed->lifeData.battery_charge > 0) && (stateUsed->lifeData.battery_charge < 140))
+ − 1219 {
448
+ − 1220 #ifdef ALWAYS_SHOW_VOLTAGE
432
+ − 1221 // show battery percent and voltage
+ − 1222 snprintf(text,16,"\f\002%u%% \f%.1fV",(uint8_t)stateUsed->lifeData.battery_charge,stateUsed->lifeData.battery_voltage);
448
+ − 1223 #else
+ − 1224 snprintf(text,16,"\f\002%u%%",(uint8_t)stateUsed->lifeData.battery_charge);
+ − 1225 #endif
110
+ − 1226 GFX_write_string(&FontT24,&t7voltage,text,0);
38
+ − 1227 }
+ − 1228 else
+ − 1229 {
+ − 1230 snprintf(text,6,"\f%.1fV",stateUsed->lifeData.battery_voltage);
+ − 1231 GFX_write_string(&FontT24,&t7voltage,text,0);
+ − 1232 }
+ − 1233 }
+ − 1234 }
+ − 1235 else
+ − 1236 {
672
+ − 1237 if(lastChargeStatus == CHARGER_off)
+ − 1238 {
+ − 1239 t7_select_customview(CVIEW_Charger);
+ − 1240 }
+ − 1241
38
+ − 1242 GFX_write_string_color(&Batt24,&t7batt,text,0,CLUT_BatteryCharging);
+ − 1243
+ − 1244 switch(stateUsed->chargeStatus)
+ − 1245 {
+ − 1246 case CHARGER_running:
+ − 1247 default:
+ − 1248 color = CLUT_BatteryStandard;
+ − 1249 break;
+ − 1250 case CHARGER_complete:
+ − 1251 color = CLUT_BatteryCharging;
+ − 1252 break;
+ − 1253 case CHARGER_lostConnection:
+ − 1254 color = CLUT_BatteryProblem;
+ − 1255 break;
+ − 1256 }
+ − 1257 text[0] = '4';
+ − 1258 text[1] = 0;
+ − 1259 GFX_write_string_color(&Batt24,&t7charge,text,0,color);
+ − 1260 }
+ − 1261
672
+ − 1262 lastChargeStatus = stateUsed->chargeStatus;
38
+ − 1263
+ − 1264
+ − 1265 customview_warnings = t7_test_customview_warnings_surface_mode();
+ − 1266 if(customview_warnings && warning_count_high_time)
+ − 1267 t7_show_customview_warnings_surface_mode();
+ − 1268 else
+ − 1269 t7_refresh_customview();
+ − 1270 draw_frame(0,0, CLUT_pluginboxSurface, CLUT_Font020);
+ − 1271 }
+ − 1272
+ − 1273 void t7_refresh_surface_debugmode(void)
+ − 1274 {
+ − 1275 // could be warning, now just to set RTE variables
+ − 1276 DataEX_check_RTE_version__needs_update();
+ − 1277
+ − 1278
+ − 1279 char TextL1[4*TEXTSIZE];
+ − 1280 uint32_t color;
+ − 1281 // uint8_t gasIdFirst;
+ − 1282 SSettings* pSettings = settingsGetPointer();
198
+ − 1283 SDataExchangeSlaveToMaster *dataIn = get_dataInPointer();
38
+ − 1284
+ − 1285 SWindowGimpStyle windowGimp;
+ − 1286
+ − 1287 RTC_DateTypeDef Sdate;
+ − 1288 RTC_TimeTypeDef Stime;
+ − 1289
+ − 1290 translateDate(stateUsed->lifeData.dateBinaryFormat, &Sdate);
+ − 1291 translateTime(stateUsed->lifeData.timeBinaryFormat, &Stime);
+ − 1292
+ − 1293
+ − 1294 if(stateUsed->data_old__lost_connection_to_slave)
+ − 1295 {
+ − 1296 Gfx_write_label_var(&t7screen, 500,800, 0,&FontT42,CLUT_DiveMainLabel,"old");
198
+ − 1297 snprintf(TextL1,TEXTSIZE,"%X %X %X %X",dataIn->header.checkCode[0],dataIn->header.checkCode[1],dataIn->header.checkCode[2],dataIn->header.checkCode[3]);
38
+ − 1298 Gfx_write_label_var(&t7screen, 500,800, 45,&FontT48,CLUT_Font020,TextL1);
+ − 1299 }
+ − 1300 else
+ − 1301 if(DataEX_lost_connection_count())
+ − 1302 {
336
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1303 snprintf(TextL1,TEXTSIZE,"\002%ld",DataEX_lost_connection_count());
38
+ − 1304 Gfx_write_label_var(&t7screen, 600,800, 45,&FontT48,CLUT_Font020,TextL1);
+ − 1305 }
+ − 1306
+ − 1307 snprintf(TextL1,TEXTSIZE,"\002%i",blockedFramesCount());
+ − 1308 Gfx_write_label_var(&t7screen, 600,800, 0,&FontT48,CLUT_Font020,TextL1);
+ − 1309
+ − 1310 if(stateUsed->lifeData.compass_DX_f | stateUsed->lifeData.compass_DY_f | stateUsed->lifeData.compass_DZ_f)
+ − 1311 {
+ − 1312 snprintf(TextL1,TEXTSIZE,"X %i",stateUsed->lifeData.compass_DX_f);
+ − 1313 Gfx_write_label_var(&t7screen, 0,400, 45,&FontT48,CLUT_Font020,TextL1);
+ − 1314 snprintf(TextL1,TEXTSIZE,"Y %i",stateUsed->lifeData.compass_DY_f);
+ − 1315 Gfx_write_label_var(&t7screen, 0,400,145,&FontT48,CLUT_Font020,TextL1);
+ − 1316 snprintf(TextL1,TEXTSIZE,"Z %i",stateUsed->lifeData.compass_DZ_f);
+ − 1317 Gfx_write_label_var(&t7screen, 0,400,255,&FontT48,CLUT_Font020,TextL1);
+ − 1318 return;
+ − 1319 }
103
+ − 1320 snprintf(TextL1,TEXTSIZE,"%01.0f %s",stateUsed->lifeData.pressure_ambient_bar * 1000.0f,TEXT_PRESSURE_UNIT);
38
+ − 1321 Gfx_write_label_var(&t7screen, 0,400, 0,&FontT42,CLUT_DiveMainLabel,"Ambient Pressure");
+ − 1322 Gfx_write_label_var(&t7screen, 0,400, 45,&FontT48,CLUT_Font020,TextL1);
+ − 1323
+ − 1324 snprintf(TextL1,TEXTSIZE,"%01.2f C",stateUsed->lifeData.temperature_celsius);
+ − 1325 Gfx_write_label_var(&t7screen, 0,400,100,&FontT42,CLUT_DiveMainLabel,"Temperature");
+ − 1326 Gfx_write_label_var(&t7screen, 0,400,145,&FontT48,CLUT_Font020,TextL1);
+ − 1327
+ − 1328 snprintf(TextL1,TEXTSIZE,"%03.0f %03.0f %03.0f",stateUsed->lifeData.compass_heading,stateUsed->lifeData.compass_roll,stateUsed->lifeData.compass_pitch);
+ − 1329 Gfx_write_label_var(&t7screen, 0,400,200,&FontT42,CLUT_DiveMainLabel,"Heading Roll Pitch");
+ − 1330 Gfx_write_label_var(&t7screen, 0,400,255,&FontT48,CLUT_Font020,TextL1);
+ − 1331
103
+ − 1332 snprintf(TextL1,TEXTSIZE,"%01.0f %s",stateUsed->lifeData.pressure_surface_bar * 1000.0f,TEXT_PRESSURE_UNIT);
38
+ − 1333 Gfx_write_label_var(&t7screen, 0,400,310,&FontT42,CLUT_DiveMainLabel,"Surface Pressure");
+ − 1334 Gfx_write_label_var(&t7screen, 0,400,355,&FontT48,CLUT_Font020,TextL1);
+ − 1335
+ − 1336 // gasIdFirst = stateUsed->lifeData.actualGas.GasIdInSettings;
198
+ − 1337 snprintf(TextL1,TEXTSIZE,"%u.%u",dataIn->RTE_VERSION_high,dataIn->RTE_VERSION_low);
38
+ − 1338 Gfx_write_label_var(&t7screen, 320,500,100,&FontT42,CLUT_DiveMainLabel,"RTE");
+ − 1339 Gfx_write_label_var(&t7screen, 320,500,145,&FontT48,CLUT_Font020,TextL1);
+ − 1340
+ − 1341 Gfx_write_label_var(&t7screen, 500,800,100,&FontT42,CLUT_DiveMainLabel,"Battery");
+ − 1342 snprintf(TextL1,TEXTSIZE,"%01.4f V",stateUsed->lifeData.battery_voltage);
+ − 1343 Gfx_write_label_var(&t7screen, 500,800,145,&FontT48,CLUT_Font020,TextL1);
+ − 1344 snprintf(TextL1,TEXTSIZE,"%03.1f %%",stateUsed->lifeData.battery_charge);
+ − 1345 Gfx_write_label_var(&t7screen, 500,800,200,&FontT48,CLUT_Font020,TextL1);
+ − 1346 if(stateUsed->chargeStatus != CHARGER_off)
+ − 1347 {
+ − 1348 switch(stateUsed->chargeStatus)
+ − 1349 {
+ − 1350 case CHARGER_running:
+ − 1351 default:
+ − 1352 color = CLUT_BatteryStandard;
+ − 1353 break;
+ − 1354 case CHARGER_complete:
+ − 1355 color = CLUT_BatteryCharging;
+ − 1356 break;
+ − 1357 case CHARGER_lostConnection:
+ − 1358 color = CLUT_BatteryProblem;
+ − 1359 break;
+ − 1360 }
+ − 1361 TextL1[0] = '4';
+ − 1362 TextL1[1] = 0;
+ − 1363 Gfx_write_label_var(&t7screen, 660,800,200,&Batt24,color,TextL1);
+ − 1364 }
+ − 1365
+ − 1366 extern uint32_t base_tempLightLevel;
+ − 1367
336
449e9e9632e4
Show actual instead of surface (30minute old) pressure if the actual differs significant (e.g. in plane or during pressure testing)
ideenmodellierer
diff
changeset
+ − 1368 snprintf(TextL1,TEXTSIZE,"# %u (%ld)",stateUsed->lifeData.ambient_light_level, base_tempLightLevel);
38
+ − 1369 Gfx_write_label_var(&t7screen, 401,600,310,&FontT42,CLUT_DiveMainLabel,"Light");
+ − 1370 Gfx_write_label_var(&t7screen, 401,800,355,&FontT48,CLUT_Font020,TextL1);
+ − 1371
+ − 1372 // snprintf(TextL1,TEXTSIZE,"# %u",stateUsed->lifeData.ambient_light_level);
+ − 1373 // Gfx_write_label_var(&t7screen, 601,800,310,&FontT42,CLUT_DiveMainLabel,"Light");
+ − 1374 // Gfx_write_label_var(&t7screen, 601,800,355,&FontT48,CLUT_Font020,TextL1);
+ − 1375
348
+ − 1376 /* show surface pressure state */
+ − 1377 if(stateUsed->lifeData.bool_temp1 )
+ − 1378 {
+ − 1379 snprintf(TextL1,TEXTSIZE,"stable");
+ − 1380 }
+ − 1381 else
+ − 1382 {
+ − 1383 snprintf(TextL1,TEXTSIZE,"unstable");
+ − 1384 }
+ − 1385 Gfx_write_label_var(&t7screen, 500,800,400,&FontT48,CLUT_Font020,TextL1);
38
+ − 1386
+ − 1387
+ − 1388 if(Sdate.Year < 15)
+ − 1389 {
+ − 1390 if(warning_count_high_time)
+ − 1391 {
+ − 1392 snprintf(TextL1,4*TEXTSIZE,"\017 %02d-%02d-%02d %02d:%02d:%02d", Sdate.Date, Sdate.Month, 2000 + Sdate.Year,Stime.Hours, Stime.Minutes, Stime.Seconds);
+ − 1393 Gfx_write_label_var(&t7screen, 0,800,420,&FontT48,CLUT_Font020,TextL1);
+ − 1394 }
+ − 1395 }
+ − 1396 else
+ − 1397 {
+ − 1398 if(pSettings->customtext[0])
+ − 1399 {
+ − 1400 if(pSettings->customtext[59])
+ − 1401 pSettings->customtext[59] = 0;
+ − 1402 Gfx_write_label_var(&t7screen, 0,400,420,&FontT24,CLUT_Font020,pSettings->customtext);
+ − 1403 }
+ − 1404 else
+ − 1405 {
+ − 1406 snprintf(TextL1,4*TEXTSIZE,"\017 %02d-%02d-%02d %02d:%02d:%02d Dives: %u", Sdate.Date, Sdate.Month, 2000 + Sdate.Year,Stime.Hours, Stime.Minutes, Stime.Seconds,pSettings->totalDiveCounter );
+ − 1407 Gfx_write_label_var(&t7screen, 0,800,420,&FontT48,CLUT_Font020,TextL1);
+ − 1408 }
+ − 1409 }
+ − 1410
+ − 1411 windowGimp.left = 400;
+ − 1412 windowGimp.top = 0;
+ − 1413 GFX_draw_image_monochrome(&t7screen, windowGimp, &ImgOSTC, 0);
+ − 1414 }
+ − 1415
+ − 1416 /* CUSTOMVIEW
+ − 1417 * in the middle of the screen
+ − 1418 */
+ − 1419
+ − 1420 uint8_t t7_test_customview_warnings(void)
+ − 1421 {
+ − 1422 uint8_t count = 0;
+ − 1423
+ − 1424 count = 0;
+ − 1425 count += stateUsed->warnings.decoMissed;
+ − 1426 count += stateUsed->warnings.ppO2Low;
+ − 1427 count += stateUsed->warnings.ppO2High;
+ − 1428 //count += stateUsed->warnings.lowBattery;
+ − 1429 count += stateUsed->warnings.sensorLinkLost;
+ − 1430 count += stateUsed->warnings.fallback;
756
+ − 1431 count += stateUsed->warnings.co2High;
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1432 #ifdef ENABLE_BOTTLE_SENSOR
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1433 if(stateUsed->warnings.newPressure)
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1434 {
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1435 count++;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1436 }
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1437 #endif
857
+ − 1438 #ifdef HAVE_DEBUG_WARNINGS
+ − 1439 count += stateUsed->warnings.debug;
+ − 1440 #endif
38
+ − 1441 return count;
+ − 1442 }
+ − 1443
+ − 1444
+ − 1445 uint8_t t7_test_customview_warnings_surface_mode(void)
+ − 1446 {
+ − 1447 uint8_t count = 0;
+ − 1448 count = 0;
+ − 1449 count += stateUsed->cnsHigh_at_the_end_of_dive;
+ − 1450 count += stateUsed->decoMissed_at_the_end_of_dive;
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1451 #ifdef ENABLE_BOTTLE_SENSOR
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1452 if(stateUsed->warnings.newPressure)
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1453 {
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1454 count++;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1455 }
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1456 #endif
38
+ − 1457 return count;
+ − 1458 }
+ − 1459
+ − 1460
+ − 1461 void t7_show_customview_warnings_surface_mode(void)
+ − 1462 {
+ − 1463 char text[256];
+ − 1464 uint8_t textpointer, lineFree;
+ − 1465
+ − 1466 text[0] = '\025';
+ − 1467 text[1] = '\f';
+ − 1468 text[2] = '\001';
+ − 1469 text[3] = TXT_Warning;
+ − 1470 text[4] = 0;
+ − 1471 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 1472
+ − 1473 textpointer = 0;
+ − 1474 lineFree = 5;
+ − 1475
+ − 1476 if(stateUsed->decoMissed_at_the_end_of_dive)
+ − 1477 {
+ − 1478 text[textpointer++] = TXT_2BYTE;
+ − 1479 text[textpointer++] = TXT2BYTE_WarnDecoMissed;
+ − 1480 text[textpointer++] = '\n';
+ − 1481 text[textpointer++] = '\r';
+ − 1482 text[textpointer] = 0;
+ − 1483 lineFree--;
+ − 1484 }
+ − 1485
+ − 1486 if(stateUsed->cnsHigh_at_the_end_of_dive)
+ − 1487 {
+ − 1488 text[textpointer++] = TXT_2BYTE;
+ − 1489 text[textpointer++] = TXT2BYTE_WarnCnsHigh;
+ − 1490 text[textpointer++] = '\n';
+ − 1491 text[textpointer++] = '\r';
+ − 1492 text[textpointer] = 0;
+ − 1493 lineFree--;
+ − 1494 }
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1495 #ifdef ENABLE_BOTTLE_SENSOR
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1496 if(stateUsed->warnings.newPressure)
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1497 {
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1498 sprintf(&text[textpointer] ," %u Bar\n", stateUsed->warnings.newPressure);
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1499 textpointer++;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1500 lineFree--;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1501 }
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1502 #endif
38
+ − 1503 if(textpointer != 0)
+ − 1504 GFX_write_string(&FontT48,&t7cW,text,1);
+ − 1505 }
+ − 1506
+ − 1507
+ − 1508 void t7_show_customview_warnings(void)
+ − 1509 {
+ − 1510 char text[256];
+ − 1511 uint8_t textpointer, lineFree;
857
+ − 1512 uint8_t index = 0;
38
+ − 1513
+ − 1514 text[0] = '\025';
+ − 1515 text[1] = '\f';
+ − 1516 text[2] = '\001';
+ − 1517 text[3] = TXT_Warning;
+ − 1518 text[4] = 0;
+ − 1519 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 1520
+ − 1521 textpointer = 0;
+ − 1522 lineFree = 5;
564
+ − 1523
38
+ − 1524 if(lineFree && stateUsed->warnings.decoMissed)
+ − 1525 {
564
+ − 1526 text[textpointer++] = '\001';
38
+ − 1527 text[textpointer++] = TXT_2BYTE;
+ − 1528 text[textpointer++] = TXT2BYTE_WarnDecoMissed;
+ − 1529 text[textpointer++] = '\n';
+ − 1530 text[textpointer++] = '\r';
+ − 1531 text[textpointer] = 0;
+ − 1532 lineFree--;
+ − 1533 }
+ − 1534
+ − 1535 if(lineFree && stateUsed->warnings.fallback)
+ − 1536 {
564
+ − 1537 text[textpointer++] = '\001';
38
+ − 1538 text[textpointer++] = TXT_2BYTE;
+ − 1539 text[textpointer++] = TXT2BYTE_WarnFallback;
+ − 1540 text[textpointer++] = '\n';
+ − 1541 text[textpointer++] = '\r';
+ − 1542 text[textpointer] = 0;
+ − 1543 lineFree--;
+ − 1544 }
+ − 1545
+ − 1546 if(lineFree && stateUsed->warnings.ppO2Low)
+ − 1547 {
564
+ − 1548 text[textpointer++] = '\001';
38
+ − 1549 text[textpointer++] = TXT_2BYTE;
+ − 1550 text[textpointer++] = TXT2BYTE_WarnPPO2Low;
+ − 1551 text[textpointer++] = '\n';
+ − 1552 text[textpointer++] = '\r';
+ − 1553 text[textpointer] = 0;
+ − 1554 lineFree--;
+ − 1555 }
+ − 1556
+ − 1557 if(lineFree && stateUsed->warnings.ppO2High)
+ − 1558 {
564
+ − 1559 text[textpointer++] = '\001';
38
+ − 1560 text[textpointer++] = TXT_2BYTE;
+ − 1561 text[textpointer++] = TXT2BYTE_WarnPPO2High;
+ − 1562 text[textpointer++] = '\n';
+ − 1563 text[textpointer++] = '\r';
+ − 1564 text[textpointer] = 0;
+ − 1565 lineFree--;
+ − 1566 }
+ − 1567
+ − 1568 if(lineFree && stateUsed->warnings.sensorLinkLost)
+ − 1569 {
564
+ − 1570 text[textpointer++] = '\001';
38
+ − 1571 text[textpointer++] = TXT_2BYTE;
+ − 1572 text[textpointer++] = TXT2BYTE_WarnSensorLinkLost;
+ − 1573 text[textpointer++] = '\n';
+ − 1574 text[textpointer++] = '\r';
+ − 1575 text[textpointer] = 0;
+ − 1576 lineFree--;
+ − 1577 }
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1578 #ifdef ENABLE_BOTTLE_SENSOR
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1579 if(stateUsed->warnings.newPressure)
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1580 {
564
+ − 1581 text[textpointer++] = '\001';
477
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1582 sprintf(&text[textpointer]," %u Bar\n", stateUsed->warnings.newPressure);
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1583 textpointer++;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1584 lineFree--;
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1585 }
5e6a612d03b5
Only switch between "no fly" and "desaturation" in case there is desaturation time left:
ideenmodellierer
diff
changeset
+ − 1586 #endif
756
+ − 1587 #ifdef ENABLE_CO2_SUPPORT
+ − 1588 if(lineFree && stateUsed->warnings.co2High)
+ − 1589 {
+ − 1590 text[textpointer++] = '\001';
+ − 1591 text[textpointer++] = TXT_2BYTE;
+ − 1592 text[textpointer++] = TXT2BYTE_WarnCO2High;
+ − 1593 text[textpointer++] = '\n';
+ − 1594 text[textpointer++] = '\r';
+ − 1595 text[textpointer] = 0;
+ − 1596 lineFree--;
+ − 1597 }
+ − 1598 #endif
857
+ − 1599 #ifdef HAVE_DEBUG_WARNINGS
+ − 1600 if(lineFree && stateUsed->warnings.debug)
+ − 1601 {
+ − 1602 for(index=0; index<3; index++)
+ − 1603 {
+ − 1604 if(((stateUsed->lifeData.extIf_sensor_map[index] == SENSOR_DIGO2M) && (((SSensorDataDiveO2*)(stateUsed->lifeData.extIf_sensor_data[index]))->status & DVO2_FATAL_ERROR)))
+ − 1605 {
+ − 1606 textpointer += snprintf(&text[textpointer],32,"\001Debug: %lx\n",((SSensorDataDiveO2*)(stateUsed->lifeData.extIf_sensor_data[index]))->status);
+ − 1607 }
+ − 1608 }
+ − 1609 lineFree--;
+ − 1610 }
+ − 1611 #endif
38
+ − 1612 /*
+ − 1613 if(lineFree && stateUsed->warnings.lowBattery)
+ − 1614 {
+ − 1615 text[textpointer++] = TXT_2BYTE;
+ − 1616 text[textpointer++] = TXT2BYTE_WarnBatteryLow;
+ − 1617 text[textpointer++] = '\n';
+ − 1618 text[textpointer++] = '\r';
+ − 1619 text[textpointer] = 0;
+ − 1620 lineFree--;
+ − 1621 }
+ − 1622 */
+ − 1623 GFX_write_string(&FontT48,&t7cW,text,1);
+ − 1624 }
+ − 1625
+ − 1626
+ − 1627 void t7_set_customview_to_primary(void)
+ − 1628 {
+ − 1629 if(stateUsed->mode == MODE_DIVE)
+ − 1630 selection_customview = settingsGetPointer()->tX_customViewPrimary;
+ − 1631 }
+ − 1632
369
+ − 1633 uint8_t t7_GetEnabled_customviews()
38
+ − 1634 {
379
+ − 1635 int8_t i;
369
+ − 1636 uint8_t *pViews;
+ − 1637 uint8_t increment = 1;
+ − 1638
+ − 1639 uint8_t enabledViewCnt = 0;
+ − 1640 uint32_t cv_config = settingsGetPointer()->cv_configuration;
+ − 1641
530
+ − 1642 pViews = (uint8_t*)customviewsDive;
369
+ − 1643
+ − 1644 while((*pViews != CVIEW_END))
+ − 1645 {
+ − 1646 increment = 1;
+ − 1647 /* check if view is enabled */
379
+ − 1648 i=0;
+ − 1649 do
369
+ − 1650 {
379
+ − 1651 if(*pViews == cv_changelist[i])
369
+ − 1652 {
379
+ − 1653 if(!CHECK_BIT_THOME(cv_config, cv_changelist[i]))
+ − 1654 {
+ − 1655 increment = 0;
+ − 1656 }
+ − 1657 break;
369
+ − 1658 }
379
+ − 1659 i++;
+ − 1660 } while(cv_changelist[i] != CVIEW_END);
+ − 1661 if(cv_changelist[i] == CVIEW_END)
+ − 1662 {
+ − 1663 increment = 0;
+ − 1664 }
369
+ − 1665 if (((*pViews == CVIEW_sensors) || (*pViews == CVIEW_sensors_mV)) &&
564
+ − 1666 ((stateUsed->diveSettings.ppo2sensors_deactivated == 0x07) || (stateUsed->diveSettings.ccrOption == 0)))
369
+ − 1667 {
+ − 1668 increment = 0;
+ − 1669 }
+ − 1670
+ − 1671 pViews++;
+ − 1672 enabledViewCnt += increment;
+ − 1673 }
+ − 1674 return enabledViewCnt;
+ − 1675 }
+ − 1676
405
+ − 1677 uint8_t t7_customview_disabled(uint8_t view)
+ − 1678 {
+ − 1679 uint8_t i = 0;
+ − 1680 uint8_t cv_disabled = 0;
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1681 SSettings *settings = settingsGetPointer();
405
+ − 1682
+ − 1683 while(cv_changelist[i] != CVIEW_END)
+ − 1684 {
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1685 if((view == cv_changelist[i]) && !CHECK_BIT_THOME(settings->cv_configuration, cv_changelist[i]))
405
+ − 1686 {
+ − 1687 cv_disabled = 1;
+ − 1688 break;
+ − 1689 }
+ − 1690 i++;
+ − 1691 }
+ − 1692
+ − 1693 if (((view == CVIEW_sensors) || (view == CVIEW_sensors_mV)) &&
582
+ − 1694 ((stateUsed->diveSettings.ppo2sensors_deactivated == 0x07) || (stateUsed->diveSettings.ccrOption == 0) || (stateUsed->warnings.fallback)))
405
+ − 1695 {
+ − 1696 cv_disabled = 1;
+ − 1697 }
672
+ − 1698
+ − 1699 if ((view == CVIEW_Charger) && (stateUsed->chargeStatus != CHARGER_running) && (stateUsed->chargeStatus != CHARGER_lostConnection))
+ − 1700 {
+ − 1701 cv_disabled = 1;
+ − 1702 }
+ − 1703
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1704 if (view == CVIEW_CcrSummary && !isLoopMode(settings->dive_mode)) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1705 cv_disabled = 1;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1706 }
672
+ − 1707
405
+ − 1708 return cv_disabled;
+ − 1709 }
+ − 1710
592
+ − 1711 uint8_t t7_change_customview(uint8_t action)
38
+ − 1712 {
365
+ − 1713 uint8_t *pViews;
662
+ − 1714 uint8_t *pStartView,*pLastView;
+ − 1715 uint8_t *pCurView = NULL;
38
+ − 1716 _Bool cv_disabled = 0;
+ − 1717
+ − 1718 if(stateUsed->mode == MODE_DIVE)
374
+ − 1719 pViews = (uint8_t*)customviewsDive;
38
+ − 1720 else
374
+ − 1721 pViews = (uint8_t*)customviewsSurface;
38
+ − 1722
361
+ − 1723 pStartView = pViews;
+ − 1724 /* set pointer to currently selected view and count number of entries */
+ − 1725 while((*pViews != CVIEW_END))
+ − 1726 {
+ − 1727 if (*pViews == selection_customview)
+ − 1728 {
+ − 1729 pCurView = pViews;
+ − 1730 }
+ − 1731 pViews++;
+ − 1732 }
+ − 1733 pLastView = pViews;
+ − 1734 pViews = pCurView;
+ − 1735
366
+ − 1736 do
+ − 1737 {
495
+ − 1738 switch(action)
+ − 1739 {
+ − 1740 case ACTION_BUTTON_ENTER:
+ − 1741 case ACTION_PITCH_POS:
510
+ − 1742 if(*pViews != CVIEW_END)
495
+ − 1743 pViews++;
510
+ − 1744 if(*pViews == CVIEW_END)
366
+ − 1745 {
+ − 1746 pViews = pStartView;
+ − 1747 }
495
+ − 1748 break;
+ − 1749 case ACTION_PITCH_NEG:
+ − 1750 if(pViews == pStartView)
+ − 1751 {
+ − 1752 pViews = pLastView - 1;
+ − 1753 }
+ − 1754 else
+ − 1755 {
+ − 1756 pViews--;
+ − 1757 }
+ − 1758 break;
+ − 1759 default:
+ − 1760 break;
+ − 1761 }
+ − 1762
+ − 1763 cv_disabled = t7_customview_disabled(*pViews);
+ − 1764 if((cv_disabled) && (action == ACTION_END))
+ − 1765 {
+ − 1766 action = ACTION_BUTTON_ENTER;
+ − 1767 }
366
+ − 1768 } while(cv_disabled);
+ − 1769
38
+ − 1770 selection_customview = *pViews;
592
+ − 1771 return *pViews;
38
+ − 1772 }
+ − 1773
577
+ − 1774 void t7_select_customview(uint8_t selectedCustomview)
+ − 1775 {
+ − 1776 if(selectedCustomview < CVIEW_END)
+ − 1777 {
+ − 1778 selection_customview = selectedCustomview;
+ − 1779 }
+ − 1780 }
38
+ − 1781
+ − 1782 uint8_t t7_get_length_of_customtext(void)
+ − 1783 {
+ − 1784 uint8_t i = 0;
+ − 1785 settingsGetPointer()->customtext[60-1] = 0;
+ − 1786 while(settingsGetPointer()->customtext[i] > 0)
+ − 1787 i++;
+ − 1788 return i;
+ − 1789 }
+ − 1790
+ − 1791
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1792 static bool setpointIsActive(SSettings *settings, unsigned setpointIndex)
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1793 {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1794 if (settings->autoSetpoint && setpointIndex == SETPOINT_INDEX_AUTO_DECO) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1795 return settings->setpoint[setpointIndex].note.ub.active;
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1796 }
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1797
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1798 return true;
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1799 }
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1800
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1801
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1802 static void t7_CcrSummary(SSettings *settings)
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1803 {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1804 unsigned numLines = 1; // CCR Mode
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1805
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1806 SGasLine *diluentsToShow[MAX_NUM_SUMMARY_LINES - 1] = { NULL };
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1807 unsigned i = NUM_OFFSET_DILUENT + 1;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1808 // Add diluent at start of dive
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1809 while (i <= NUM_OFFSET_DILUENT + 1 + NUM_GASES) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1810 if (settings->gas[i].note.ub.active && settings->gas[i].note.ub.first) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1811 diluentsToShow[0] = &settings->gas[i];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1812 numLines++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1813
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1814 break;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1815 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1816
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1817 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1818 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1819
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1820 bool showScrubberTime = false;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1821 if (settings->scrubTimerMode != SCRUB_TIMER_OFF) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1822 numLines++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1823 showScrubberTime = true;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1824 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1825
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1826 bool showManualSetpoints = false;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1827 unsigned offset;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1828 SSetpointLine *setpointsToShow[MAX_NUM_SUMMARY_LINES - 1] = { NULL };
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1829 if (settings->CCR_Mode == CCRMODE_FixedSetpoint || settings->fallbackToFixedSetpoint) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1830 offset = numLines;
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1831 if (settings->autoSetpoint) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1832 setpointsToShow[numLines++ - offset] = &settings->setpoint[SETPOINT_INDEX_AUTO_LOW];
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1833 setpointsToShow[numLines++ - offset] = &settings->setpoint[SETPOINT_INDEX_AUTO_HIGH];
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1834 if (setpointIsActive(settings, SETPOINT_INDEX_AUTO_DECO)) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1835 setpointsToShow[numLines++ - offset] = &settings->setpoint[SETPOINT_INDEX_AUTO_DECO];
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1836 }
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1837 } else {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1838 // Add setpoint at start of dive
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1839 i = 1;
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1840 while (i <= NUM_GASES) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1841 if (setpointIsActive(settings, i) && settings->setpoint[i].note.ub.first) {
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1842 setpointsToShow[numLines - offset] = &settings->setpoint[i];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1843 numLines++;
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1844
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1845 break;
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1846 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1847
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1848 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1849 }
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1850
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1851 showManualSetpoints = true;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1852 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1853 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1854
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1855 // Add remaining active diluents
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1856 i = NUM_OFFSET_DILUENT + 1;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1857 offset = numLines;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1858 if (diluentsToShow[0]) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1859 offset--;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1860 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1861 while (i < NUM_OFFSET_DILUENT + 1 + NUM_GASES && numLines < MAX_NUM_SUMMARY_LINES) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1862 if (settings->gas[i].note.ub.active && !settings->gas[i].note.ub.first) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1863 diluentsToShow[numLines - offset] = &settings->gas[i];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1864 numLines++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1865 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1866
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1867 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1868 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1869
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1870 if (showManualSetpoints) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1871 // Fill up the remaining lines with setpoints
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1872 offset = numLines;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1873 if (setpointsToShow[0]) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1874 offset--;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1875 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1876 i = 2;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1877 while (i <= NUM_GASES && numLines < MAX_NUM_SUMMARY_LINES) {
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1878 if (setpointIsActive(settings, i) && !settings->setpoint[i].note.ub.first) {
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1879 setpointsToShow[numLines - offset] = &settings->setpoint[i];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1880 numLines++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1881 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1882
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1883 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1884 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1885 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1886
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1887 char heading[128];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1888 unsigned headingIndex = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1889
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1890 char data[128];
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1891 unsigned dataIndex = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1892
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1893 heading[headingIndex++] = '\032';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1894 heading[headingIndex++] = '\016';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1895 heading[headingIndex++] = '\016';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1896 heading[headingIndex++] = TXT_CCRmode;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1897
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1898 data[dataIndex++] = '\t';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1899 char *modeText;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1900 if (settings->CCR_Mode == CCRMODE_Sensors) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1901 if (settings->fallbackToFixedSetpoint) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1902 modeText = (char *)&"Sens/FB";
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1903 } else {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1904 modeText = (char *)&"Sensor";
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1905 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1906 } else {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1907 modeText = (char *)&"Fixed";
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1908 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1909 dataIndex += snprintf(&data[dataIndex], 10, "\020%s", modeText);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1910
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1911 i = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1912 while (setpointsToShow[i] != NULL && i < MAX_NUM_SUMMARY_LINES - 1) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1913 heading[headingIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1914 heading[headingIndex++] = '\r';
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1915 if (settings->autoSetpoint) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1916 heading[headingIndex++] = TXT_2BYTE;
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1917 heading[headingIndex++] = TXT2BYTE_SetpointShort;
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1918 headingIndex += printSetpointName(&heading[headingIndex], i + 1, settings, true);
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1919 } else if (i == 0) {
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1920 heading[headingIndex++] = TXT_2BYTE;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1921 heading[headingIndex++] = TXT2BYTE_Setpoint;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1922 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1923
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1924 data[dataIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1925 data[dataIndex++] = '\r';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1926 data[dataIndex++] = '\t';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1927 dataIndex += snprintf(&data[dataIndex], 10, "\020%01.2f", setpointsToShow[i]->setpoint_cbar / 100.0);
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1928 if (setpointsToShow[i]->depth_meter && !(settings->autoSetpoint && i + 1 == SETPOINT_INDEX_AUTO_DECO)) {
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1929 bool setpointDelayed = settings->autoSetpoint && i + 1 == SETPOINT_INDEX_AUTO_LOW && settings->delaySetpointLow;
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 1930 dataIndex += snprintf(&data[dataIndex], 10, "\016\016 %um%s\017", setpointsToShow[i]->depth_meter, setpointDelayed ? "(d)" : "");
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1931 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1932
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1933 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1934 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1935
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1936 i = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1937 while (diluentsToShow[i] != NULL && i < MAX_NUM_SUMMARY_LINES - 1) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1938 heading[headingIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1939 heading[headingIndex++] = '\r';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1940 if (i == 0) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1941 heading[headingIndex++] = TXT_Diluent_Gas_Edit;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1942 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1943
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1944 data[dataIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1945 data[dataIndex++] = '\r';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1946 data[dataIndex++] = '\t';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1947 data[dataIndex++] = '\020';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1948 dataIndex += write_gas(&data[dataIndex], diluentsToShow[i]->oxygen_percentage, diluentsToShow[i]->helium_percentage);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1949 if (diluentsToShow[i]->note.ub.deco) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1950 char *space = " ";
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1951 if (diluentsToShow[i]->depth_meter > 99) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1952 space = (char *)"";
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1953 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1954 dataIndex += snprintf(&data[dataIndex], 10, "\016\016%s%um\017", space, diluentsToShow[i]->depth_meter);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1955 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1956
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1957 i++;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1958 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1959
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1960 if (showScrubberTime) {
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1961 heading[headingIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1962 heading[headingIndex++] = '\r';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1963 heading[headingIndex++] = TXT_2BYTE;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1964 heading[headingIndex++] = TXT2BYTE_Scrubber;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1965
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1966 data[dataIndex++] = '\n';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1967 data[dataIndex++] = '\r';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1968 data[dataIndex++] = '\t';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1969 dataIndex += printScrubberText(&data[dataIndex], 10, settings);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1970 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1971
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1972 heading[headingIndex++] = '\017';
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1973 heading[headingIndex++] = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1974
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1975 data[dataIndex++] = 0;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1976
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1977 t7cY0free.WindowLineSpacing = 48;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1978 t7cY0free.WindowNumberOfTextLines = 6;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1979 t7cY0free.WindowTab = 375;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1980
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1981 if (!settings->FlipDisplay) {
824
+ − 1982 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1983 t7cY0free.WindowX0 += 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1984 t7cY0free.WindowY0 += 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1985 t7cY0free.WindowY1 = 355;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1986 GFX_write_string(&FontT24, &t7cY0free, heading, 1);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1987 t7cY0free.WindowX0 -= 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1988 t7cY0free.WindowY0 -= 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1989 } else {
824
+ − 1990 t7cY0free.WindowY1 = 400;
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1991 t7cY0free.WindowY1 -= 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1992 t7cY0free.WindowX1 -= 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1993 GFX_write_string(&FontT24, &t7cY0free, heading, 1);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1994 t7cY0free.WindowY1 += 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1995 t7cY0free.WindowX1 += 10;
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1996 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1997
868
+ − 1998 Gfx_colorsscheme_mod(data, 0);
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 1999
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2000 GFX_write_string(&FontT42, &t7cY0free, data, 1);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2001 }
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2002
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2003
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2004 static void setTimerPrestart(int startTimeS)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2005 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2006 stateUsedWrite->timerState = TIMER_STATE_PRESTART;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2007 stateUsedWrite->timerStartedS = startTimeS;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2008 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2009
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2010
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2011 static void setTimerFinished(int startTimeS)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2012 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2013 stateUsedWrite->timerState = TIMER_STATE_FINISHED;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2014 stateUsedWrite->timerStartedS = startTimeS;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2015 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2016
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2017
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2018 static void updateTimer(SSettings *settings, int nowS, bool switchedToTimerView)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2019 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2020 int timerElapsedS = nowS - stateUsed->timerStartedS;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2021
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2022 if (stateUsed->timerState && timerElapsedS < 0) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2023 disableTimer();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2024 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2025 switch (stateUsed->timerState) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2026 case TIMER_STATE_OFF:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2027 if (switchedToTimerView) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2028 setTimerPrestart(nowS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2029 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2030
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2031 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2032 case TIMER_STATE_PRESTART:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2033 if (timerElapsedS <= TIMER_ACTION_DELAY_S) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2034 if (switchedToTimerView) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2035 setTimerPrestart(nowS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2036 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2037 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2038 if (selection_customview == CVIEW_Timer) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2039 stateUsedWrite->timerState = TIMER_STATE_RUNNING;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2040 stateUsedWrite->timerStartedS = stateUsed->timerStartedS + TIMER_ACTION_DELAY_S;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2041 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2042 disableTimer();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2043 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2044 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2045
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2046 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2047 case TIMER_STATE_RUNNING:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2048 if (timerElapsedS >= settings->timerDurationS) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2049 if (selection_customview == CVIEW_Timer) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2050 setTimerFinished(stateUsed->timerStartedS + settings->timerDurationS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2051 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2052 stateUsedWrite->timerState = TIMER_STATE_WAIT_FINISHED;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2053 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2054 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2055
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2056 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2057 case TIMER_STATE_WAIT_FINISHED:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2058 if (switchedToTimerView) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2059 setTimerFinished(nowS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2060 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2061
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2062 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2063 case TIMER_STATE_FINISHED:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2064 if (timerElapsedS <= TIMER_ACTION_DELAY_S) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2065 if (switchedToTimerView) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2066 setTimerPrestart(stateUsed->timerStartedS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2067 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2068 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2069 disableTimer();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2070 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2071
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2072 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2073 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2074 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2075 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2076
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2077
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2078 bool t7_isTimerRunning(bool includeBackground)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2079 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2080 return stateUsed->timerState && (selection_customview == CVIEW_Timer || (includeBackground && stateUsed->timerState == TIMER_STATE_RUNNING));
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2081 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2082
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2083
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2084 static void showTimer(SSettings *settings, int nowS)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2085 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2086 char heading[32];
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2087 unsigned headingIndex = 0;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2088
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2089 char data[32];
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2090 unsigned dataIndex = 0;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2091
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2092 heading[headingIndex++] = '\032';
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2093 heading[headingIndex++] = '\016';
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2094 heading[headingIndex++] = '\016';
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2095
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2096 data[dataIndex++] = '\t';
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2097
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2098 int timerRemainingS = settings->timerDurationS;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2099 switch (stateUsed->timerState) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2100 case TIMER_STATE_RUNNING:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2101 timerRemainingS = settings->timerDurationS - (nowS - stateUsed->timerStartedS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2102
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2103 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2104 case TIMER_STATE_PRESTART:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2105 case TIMER_STATE_FINISHED:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2106 if (stateUsed->timerState == TIMER_STATE_PRESTART) {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2107 heading[headingIndex++] = TXT_2BYTE;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2108 heading[headingIndex++] = TXT2BYTE_Starting;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2109 } else {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2110 heading[headingIndex++] = TXT_2BYTE;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2111 heading[headingIndex++] = TXT2BYTE_Finished;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2112
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2113 timerRemainingS = 0;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2114 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2115
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2116 dataIndex += snprintf(&data[dataIndex], 10, "\020%u", TIMER_ACTION_DELAY_S - (nowS - stateUsed->timerStartedS));
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2117
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2118 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2119 default:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2120
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2121 break;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2122 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2123
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2124 char timer[16];
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2125 snprintf(timer, 10, "\001\020%u:%02u", timerRemainingS / 60, timerRemainingS % 60);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2126
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2127 heading[headingIndex++] = 0;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2128
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2129 data[dataIndex++] = 0;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2130
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2131 t7cY0free.WindowLineSpacing = 48;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2132 t7cY0free.WindowNumberOfTextLines = 6;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2133 t7cY0free.WindowTab = 375;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2134
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2135 if (!settings->FlipDisplay) {
824
+ − 2136 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2137 t7cY0free.WindowX0 += 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2138 t7cY0free.WindowY0 += 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2139 t7cY0free.WindowY1 = 355;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2140 GFX_write_string(&FontT24, &t7cY0free, heading, 1);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2141 t7cY0free.WindowX0 -= 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2142 t7cY0free.WindowY0 -= 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2143 } else {
824
+ − 2144 t7cY0free.WindowY1 = 400;
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2145 t7cY0free.WindowY1 -= 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2146 t7cY0free.WindowX1 -= 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2147 GFX_write_string(&FontT24, &t7cY0free, heading, 1);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2148 t7cY0free.WindowY1 += 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2149 t7cY0free.WindowX1 += 10;
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2150 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2151
868
+ − 2152 Gfx_colorsscheme_mod(data, 0);
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2153
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2154 GFX_write_string(&FontT42, &t7cY0free, data, 1);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2155
868
+ − 2156 Gfx_colorsscheme_mod(timer, 0);
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2157
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2158 GFX_write_string(&FontT105, &t7cY0free, timer, 4);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2159 }
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2160
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2161
38
+ − 2162 void t7_refresh_customview(void)
+ − 2163 {
405
+ − 2164 static uint8_t last_customview = CVIEW_END;
38
+ − 2165
+ − 2166 char text[256];
567
+ − 2167 char timeSuffix;
+ − 2168 uint8_t hoursToDisplay;
662
+ − 2169 #ifdef ENABLE_PSCR_MODE
+ − 2170 uint8_t showSimPPO2 = 1;
+ − 2171 #endif
38
+ − 2172 uint16_t textpointer = 0;
539
+ − 2173 uint16_t heading = 0;
38
+ − 2174 int16_t start;
51
+ − 2175 uint8_t lineCountCustomtext = 0;
38
+ − 2176 int16_t shiftWindowY0;
+ − 2177 RTC_DateTypeDef Sdate;
+ − 2178 RTC_TimeTypeDef Stime;
+ − 2179 float fPpO2limitHigh, fPpO2limitLow, fPpO2ofGasAtThisDepth; // CVIEW_Gaslist
+ − 2180 const SGasLine * pGasLine; // CVIEW_Gaslist
+ − 2181 uint8_t oxygen, helium; // CVIEW_Gaslist
+ − 2182 float depth, surface, fraction_nitrogen, fraction_helium, ead, end; // CVIEW_EADTime
819
+ − 2183 SSettingsStatus SettingsStatus;
110
+ − 2184 SSettings* pSettings;
+ − 2185 pSettings = settingsGetPointer();
907
+ − 2186 uint8_t decoPlanEntries = 6;
110
+ − 2187
701
+ − 2188 uint8_t local_ppo2sensors_deactivated = 0;
+ − 2189
+ − 2190 if(stateUsed->mode == MODE_DIVE) /* show sensors based on current dive settings */
+ − 2191 {
+ − 2192 local_ppo2sensors_deactivated = stateUsed->diveSettings.ppo2sensors_deactivated;
+ − 2193 }
+ − 2194 else
+ − 2195 {
907
+ − 2196 local_ppo2sensors_deactivated = pSettings->ppo2sensors_deactivated;
701
+ − 2197 }
+ − 2198
405
+ − 2199 if(last_customview != selection_customview) /* check if current selection is disabled and should be skipped */
+ − 2200 {
+ − 2201 if(t7_customview_disabled(selection_customview))
+ − 2202 {
+ − 2203 t7_change_customview(ACTION_BUTTON_ENTER);
+ − 2204 }
+ − 2205 }
38
+ − 2206 switch(selection_customview)
+ − 2207 {
+ − 2208 case CVIEW_noneOrDebug:
+ − 2209 if(settingsGetPointer()->showDebugInfo)
+ − 2210 {
+ − 2211 // header
+ − 2212 strcpy(text,"\032\f\001Debug");
+ − 2213 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2214 // content
+ − 2215 t7_debug();
+ − 2216 }
+ − 2217 break;
+ − 2218
672
+ − 2219 case CVIEW_Charger:
+ − 2220 snprintf(text,100,"\032\f\001%c",TXT_Charging);
+ − 2221 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2222 t7_ChargerView();
+ − 2223
+ − 2224 break;
+ − 2225
38
+ − 2226 case CVIEW_SummaryOfLeftCorner:
+ − 2227 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_Summary);
+ − 2228 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2229 // content
+ − 2230 t7_SummaryOfLeftCorner();
+ − 2231 break;
+ − 2232
+ − 2233 case CVIEW_CompassDebug:
+ − 2234 snprintf(text,100,"\032\f\001Compass raw");
+ − 2235 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2236 snprintf(text,255,"%1.1f\n\r%1.1f\n\r%1.1f\n\r%i\n\r%i\n\r%i"
+ − 2237 ,stateUsed->lifeData.compass_heading
+ − 2238 ,stateUsed->lifeData.compass_roll
+ − 2239 ,stateUsed->lifeData.compass_pitch
+ − 2240 ,stateUsed->lifeData.compass_DX_f
+ − 2241 ,stateUsed->lifeData.compass_DY_f
+ − 2242 ,stateUsed->lifeData.compass_DZ_f
+ − 2243 );
+ − 2244
+ − 2245 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
+ − 2246 t7cY0free.WindowLineSpacing = 48;
+ − 2247 t7cY0free.WindowNumberOfTextLines = 6;
+ − 2248 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 2249 break;
+ − 2250
+ − 2251 case CVIEW_Hello:
+ − 2252 t7_logo_OSTC();
+ − 2253 t7cC.WindowLineSpacing = 53;
+ − 2254 t7cC.WindowNumberOfTextLines = 5;
+ − 2255 shiftWindowY0 = 18;
+ − 2256
+ − 2257 if(updateNecessary)//if(DataEX_check_RTE_version__needs_update() || font_update_required())
+ − 2258 {
+ − 2259 if(warning_count_high_time)
+ − 2260 {
+ − 2261 shiftWindowY0 += 20;
+ − 2262 t7cC.WindowY0 -= shiftWindowY0;
+ − 2263 textpointer = 0;
+ − 2264 text[textpointer++] = TXT_2BYTE;
+ − 2265 text[textpointer++] = TXT2BYTE_PleaseUpdate;
+ − 2266 text[textpointer++] = '\n';
+ − 2267 text[textpointer++] = '\r';
+ − 2268 if(DataEX_check_RTE_version__needs_update())
+ − 2269 {
+ − 2270 text[textpointer++] = TXT_2BYTE;
+ − 2271 text[textpointer++] = TXT2BYTE_RTE;
+ − 2272 text[textpointer++] = '\n';
+ − 2273 text[textpointer++] = '\r';
+ − 2274 }
+ − 2275 if(font_update_required())
+ − 2276 {
+ − 2277 text[textpointer++] = TXT_2BYTE;
+ − 2278 text[textpointer++] = TXT2BYTE_Fonts;
+ − 2279 }
+ − 2280 text[textpointer++] = 0;
+ − 2281 GFX_write_string_color(&FontT42,&t7cC,text,1, CLUT_WarningRed);
+ − 2282 t7cC.WindowY0 += shiftWindowY0;
+ − 2283 }
+ − 2284 t7cC.WindowNumberOfTextLines = 3;
+ − 2285 }
662
+ − 2286 else if(isSettingsWarning())
+ − 2287 {
+ − 2288 if(warning_count_high_time)
+ − 2289 {
819
+ − 2290 get_CorrectionStatus(&SettingsStatus);
662
+ − 2291 shiftWindowY0 += 20;
+ − 2292 t7cC.WindowY0 -= shiftWindowY0;
+ − 2293 textpointer = 0;
819
+ − 2294 snprintf(text,255,"\001%c%c\n\r\001%d|%d",TXT_2BYTE,TXT2BYTE_CheckSettings,SettingsStatus.FirstCorrection,SettingsStatus.Corrections);
662
+ − 2295 GFX_write_string_color(&FontT42,&t7cC,text,1, CLUT_WarningRed);
+ − 2296 t7cC.WindowY0 += shiftWindowY0;
+ − 2297 }
+ − 2298 t7cC.WindowNumberOfTextLines = 1;
+ − 2299 }
759
+ − 2300 else if(!isCompassCalibrated()) {
+ − 2301 if(warning_count_high_time) {
+ − 2302 shiftWindowY0 += 20;
+ − 2303 t7cC.WindowY0 -= shiftWindowY0;
+ − 2304 textpointer = 0;
+ − 2305 text[textpointer++] = '\001';
+ − 2306 text[textpointer++] = TXT_2BYTE;
+ − 2307 text[textpointer++] = TXT2BYTE_Compass;
+ − 2308 text[textpointer++] = '\n';
+ − 2309 text[textpointer++] = '\r';
+ − 2310 text[textpointer++] = '\001';
+ − 2311 text[textpointer++] = TXT_2BYTE;
+ − 2312 text[textpointer++] = TXT2BYTE_NotCalibrated;
+ − 2313 text[textpointer++] = '\n';
+ − 2314 text[textpointer++] = '\r';
+ − 2315 text[textpointer++] = 0;
+ − 2316 GFX_write_string_color(&FontT42, &t7cC,text, 1, CLUT_WarningRed);
+ − 2317 t7cC.WindowY0 += shiftWindowY0;
+ − 2318 }
+ − 2319 t7cC.WindowNumberOfTextLines = 2;
+ − 2320 }
38
+ − 2321 else // customtext
+ − 2322 {
+ − 2323 lineCountCustomtext = t7_customtextPrepare(text);
+ − 2324 if(lineCountCustomtext <= 2)
+ − 2325 shiftWindowY0 += 20+26; // nach unten
+ − 2326 else
+ − 2327 if(lineCountCustomtext <= 3)
+ − 2328 shiftWindowY0 += 20; // nach unten
+ − 2329 t7cC.WindowY0 -= shiftWindowY0;
+ − 2330
+ − 2331 GFX_write_string(&FontT42,&t7cC,text,1);
+ − 2332 t7cC.WindowNumberOfTextLines = 3;
+ − 2333 t7cC.WindowY0 += shiftWindowY0;
+ − 2334 }
+ − 2335 if(lineCountCustomtext <= 4)
+ − 2336 {
+ − 2337 snprintf(text,100,"\001#%0u V%01u.%01u.%01u",
+ − 2338 settingsGetPointer()->serialLow + (256 * settingsGetPointer()->serialHigh),
+ − 2339 firmwareDataGetPointer()->versionFirst,
+ − 2340 firmwareDataGetPointer()->versionSecond,
+ − 2341 firmwareDataGetPointer()->versionThird
+ − 2342 );
+ − 2343 GFX_write_string(&FontT24,&t7cC,text,0);
+ − 2344 }
+ − 2345 break;
+ − 2346
+ − 2347 case CVIEW_Gaslist:
+ − 2348 // a lot of code taken from tMenuGas.c
+ − 2349 // header
+ − 2350 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_Gaslist);
+ − 2351 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2352 // content
+ − 2353 textpointer = 0;
110
+ − 2354
+ − 2355 if(!pSettings->FlipDisplay)
+ − 2356 {
+ − 2357 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
+ − 2358 }
+ − 2359 else
+ − 2360 {
+ − 2361 t7cY0free.WindowY1 = 400;
+ − 2362 }
38
+ − 2363 t7cY0free.WindowLineSpacing = 48+9;
+ − 2364 t7cY0free.WindowNumberOfTextLines = 5; // NUM_GASES == 5
+ − 2365 t7cY0free.WindowTab = 420;
+ − 2366
+ − 2367 pGasLine = settingsGetPointer()->gas;
+ − 2368 if(actualLeftMaxDepth(stateUsed))
+ − 2369 fPpO2limitHigh = (float)(settingsGetPointer()->ppO2_max_deco) / 100;
+ − 2370 else
+ − 2371 fPpO2limitHigh = (float)(settingsGetPointer()->ppO2_max_std) / 100;
+ − 2372 fPpO2limitLow = (float)(settingsGetPointer()->ppO2_min) / 100;
+ − 2373 for(int gasId=1;gasId<=NUM_GASES;gasId++)
+ − 2374 {
+ − 2375 textpointer = 0;
527
+ − 2376 #ifdef ENABLE_UNUSED_GAS_HIDING
+ − 2377 if(!pGasLine[gasId].note.ub.off)
+ − 2378 {
+ − 2379 #endif
38
+ − 2380 fPpO2ofGasAtThisDepth = (stateUsed->lifeData.pressure_ambient_bar - WATER_VAPOUR_PRESSURE) * pGasLine[gasId].oxygen_percentage / 100;
+ − 2381 if(pGasLine[gasId].note.ub.active == 0)
527
+ − 2382 strcpy(&text[textpointer++],"\031");
517
+ − 2383 else if(stateUsed->lifeData.actualGas.GasIdInSettings == gasId) /* actual selected gas */
+ − 2384 {
+ − 2385 strcpy(&text[textpointer++],"\030");
+ − 2386 }
38
+ − 2387 else if((fPpO2ofGasAtThisDepth > fPpO2limitHigh) || (fPpO2ofGasAtThisDepth < fPpO2limitLow))
+ − 2388 strcpy(&text[textpointer++],"\025");
517
+ − 2389 else if(actualBetterGasId() == gasId)
+ − 2390 {
+ − 2391 strcpy(&text[textpointer++],"\026"); /* Highlight better gas */
+ − 2392 }
38
+ − 2393 else
517
+ − 2394 strcpy(&text[textpointer++],"\023");
38
+ − 2395
+ − 2396 text[textpointer++] = ' ';
+ − 2397 oxygen = pGasLine[gasId].oxygen_percentage;
+ − 2398 helium = pGasLine[gasId].helium_percentage;
+ − 2399 textpointer += write_gas(&text[textpointer], oxygen, helium);
+ − 2400 // Wechseltiefe
+ − 2401 if(pGasLine[gasId].depth_meter)
+ − 2402 {
631
+ − 2403 textpointer += snprintf(&text[textpointer],10,"\t%u %c%c",unit_depth_integer(pGasLine[gasId].depth_meter), unit_depth_char1(), unit_depth_char2());
38
+ − 2404 }
+ − 2405 GFX_write_string(&FontT42, &t7cY0free, text, gasId);
527
+ − 2406 #ifdef ENABLE_UNUSED_GAS_HIDING
+ − 2407 }
+ − 2408 #endif
38
+ − 2409 }
+ − 2410 break;
+ − 2411
+ − 2412 case CVIEW_EADTime:
+ − 2413 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_Info );
+ − 2414 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2415 textpointer = 0;
+ − 2416
+ − 2417 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
110
+ − 2418 if(pSettings->FlipDisplay)
+ − 2419 {
+ − 2420 t7cY0free.WindowY1 = 400;
+ − 2421 }
38
+ − 2422 t7cY0free.WindowLineSpacing = 48;
+ − 2423 t7cY0free.WindowNumberOfTextLines = 6;
+ − 2424
+ − 2425 // time
+ − 2426 snprintf(text,100,"\032\001%c%c",TXT_2BYTE,TXT2BYTE_Clock );
+ − 2427 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 2428
+ − 2429 translateDate(stateRealGetPointer()->lifeData.dateBinaryFormat, &Sdate);
+ − 2430 translateTime(stateRealGetPointer()->lifeData.timeBinaryFormat, &Stime);
567
+ − 2431
+ − 2432 if (settingsGetPointer()->amPMTime)
+ − 2433 {
+ − 2434 if (Stime.Hours > 11)
+ − 2435 {
+ − 2436 timeSuffix = 'P';
+ − 2437 }
+ − 2438 else
+ − 2439 {
+ − 2440 timeSuffix = 'A';
+ − 2441 }
+ − 2442
+ − 2443 if (Stime.Hours % 12 == 0)
+ − 2444 {
+ − 2445 hoursToDisplay = 12;
+ − 2446 }
+ − 2447 else
+ − 2448 {
+ − 2449 hoursToDisplay = (Stime.Hours % 12);
+ − 2450 }
+ − 2451
+ − 2452 if(Stime.Seconds % 2)
+ − 2453 textpointer += snprintf(&text[textpointer],100,"\030\001%02d:%02d %cM",hoursToDisplay,Stime.Minutes,timeSuffix);
+ − 2454 else
+ − 2455 textpointer += snprintf(&text[textpointer],100,"\030\001%02d\031:\030%02d %cM",hoursToDisplay,Stime.Minutes,timeSuffix);
+ − 2456 }
38
+ − 2457 else
567
+ − 2458 {
+ − 2459 if(Stime.Seconds % 2)
+ − 2460 textpointer += snprintf(&text[textpointer],100,"\030\001%02d:%02d",Stime.Hours,Stime.Minutes);
+ − 2461 else
+ − 2462 textpointer += snprintf(&text[textpointer],100,"\030\001%02d\031:\030%02d",Stime.Hours,Stime.Minutes);
+ − 2463 }
+ − 2464
38
+ − 2465 GFX_write_string(&FontT42, &t7cY0free, text, 2);
+ − 2466
+ − 2467 // EAD / END
+ − 2468 // The equivalent air depth can be calculated for depths in metres as follows:
+ − 2469 // EAD = (Depth + 10) � Fraction of N2 / 0.79 - 10 (wikipedia)
+ − 2470 // The equivalent narcotic depth can be calculated for depths in metres as follows:
+ − 2471 // END = (Depth + 10) � (1 - Fraction of helium) - 10 (wikipedia)
+ − 2472 decom_get_inert_gases((float)stateUsed->lifeData.pressure_ambient_bar,&(stateUsed->lifeData.actualGas),&fraction_nitrogen,&fraction_helium);
+ − 2473 depth = stateUsed->lifeData.pressure_ambient_bar;
+ − 2474 surface = stateUsed->lifeData.pressure_surface_bar;
+ − 2475 ead = 10.f * ((depth * fraction_nitrogen/0.79f) - surface);
+ − 2476 end = 10.0f * ((depth * (1.f - fraction_helium)) - surface);
+ − 2477 if(ead < 0)
+ − 2478 ead = 0;
+ − 2479 if(end < 0)
+ − 2480 end = 0;
+ − 2481
+ − 2482 snprintf(text,100,"\032\001EAD");
+ − 2483 GFX_write_string(&FontT42, &t7cY0free, text, 3);
+ − 2484 snprintf(text,100,"\030\001%01.1f %c%c"
+ − 2485 , unit_depth_float(ead)
+ − 2486 , unit_depth_char1()
+ − 2487 , unit_depth_char2()
+ − 2488 );
+ − 2489 GFX_write_string(&FontT42, &t7cY0free, text, 4);
+ − 2490
+ − 2491 snprintf(text,100,"\032\001END");
+ − 2492 GFX_write_string(&FontT42, &t7cY0free, text, 5);
+ − 2493 snprintf(text,100,"\030\001%01.1f %c%c"
+ − 2494 , unit_depth_float(ead)
+ − 2495 , unit_depth_char1()
+ − 2496 , unit_depth_char2()
+ − 2497 );
+ − 2498 GFX_write_string(&FontT42, &t7cY0free, text, 6);
+ − 2499 break;
+ − 2500
+ − 2501 case CVIEW_Profile:
+ − 2502 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_Profile);
+ − 2503 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2504 textpointer = 0;
+ − 2505 t7_miniLiveLogProfile();
+ − 2506 break;
+ − 2507
+ − 2508 case CVIEW_Tissues:
+ − 2509 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_Tissues);
+ − 2510 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2511 textpointer = 0;
+ − 2512 t7_tissues(stateUsed);
+ − 2513 break;
+ − 2514
+ − 2515 case CVIEW_sensors:
+ − 2516 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_O2monitor);
+ − 2517 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2518 textpointer = 0;
+ − 2519 text[textpointer++] = '\030'; // main color
+ − 2520 for(int i=0;i<3;i++)
+ − 2521 {
701
+ − 2522 if((local_ppo2sensors_deactivated & (1<<i)) || (stateUsed->lifeData.ppO2Sensor_bar[i] == 0.0))
38
+ − 2523 {
662
+ − 2524 #ifdef ENABLE_PSCR_MODE
+ − 2525 if((stateUsed->diveSettings.diveMode == DIVEMODE_PSCR) && (showSimPPO2) && (stateUsed->mode == MODE_DIVE)) /* display ppo2 sim in blue letters in case a slot is not used in the ppo2 custom view */
+ − 2526 {
+ − 2527 text[textpointer++] = '\023';
+ − 2528 textpointer += snprintf(&text[textpointer],100,"\001%01.2f\n\r\030",stateUsed->lifeData.ppo2Simulated_bar);
+ − 2529 showSimPPO2 = 0;
+ − 2530 }
+ − 2531 else
+ − 2532 #endif
+ − 2533 {
+ − 2534 text[textpointer++] = '\031'; // labelcolor
+ − 2535 text[textpointer++] = '\001';
+ − 2536 text[textpointer++] = '-';
+ − 2537 text[textpointer++] = '\n';
+ − 2538 text[textpointer++] = '\r';
+ − 2539 text[textpointer++] = '\030'; // main color
+ − 2540 text[textpointer] = 0;
+ − 2541 }
38
+ − 2542 }
+ − 2543 else
+ − 2544 {
+ − 2545 if(stateUsed->warnings.sensorOutOfBounds[i])
+ − 2546 text[textpointer++] = '\025'; // Warning Red
+ − 2547 textpointer += snprintf(&text[textpointer],100,"\001%01.2f\n\r\030",stateUsed->lifeData.ppO2Sensor_bar[i]);
+ − 2548 }
+ − 2549 }
+ − 2550 t7cC.WindowLineSpacing = 95;
+ − 2551 t7cC.WindowNumberOfTextLines = 3;
+ − 2552 text[textpointer] = 0;
315
+ − 2553 if(pSettings->FlipDisplay)
+ − 2554 {
+ − 2555 t7cC.WindowY1 -= 40;
+ − 2556 }
38
+ − 2557 GFX_write_string(&FontT105,&t7cC,text,1);
315
+ − 2558 if(pSettings->FlipDisplay)
+ − 2559 {
+ − 2560 t7cC.WindowY1 += 40;
+ − 2561 }
38
+ − 2562 break;
+ − 2563
+ − 2564 case CVIEW_sensors_mV:
+ − 2565 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE,TXT2BYTE_O2voltage);
+ − 2566 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2567 textpointer = 0;
+ − 2568 text[textpointer++] = '\030';
+ − 2569 for(int i=0;i<3;i++)
+ − 2570 {
701
+ − 2571 if(local_ppo2sensors_deactivated & (1<<i))
38
+ − 2572 {
+ − 2573 text[textpointer++] = '\031';
+ − 2574 text[textpointer++] = '\001';
+ − 2575 text[textpointer++] = '-';
+ − 2576 text[textpointer++] = '\n';
+ − 2577 text[textpointer++] = '\r';
+ − 2578 text[textpointer++] = '\030';
+ − 2579 text[textpointer] = 0;
+ − 2580 }
+ − 2581 else
+ − 2582 {
+ − 2583 if(stateUsed->warnings.sensorOutOfBounds[i])
+ − 2584 text[textpointer++] = '\025';
+ − 2585 textpointer += snprintf(&text[textpointer],100,"\001%01.1f mV\n\r\030",(stateUsed->lifeData.sensorVoltage_mV[i]));
+ − 2586 }
+ − 2587 }
+ − 2588 t7cC.WindowLineSpacing = 95;
+ − 2589 t7cC.WindowNumberOfTextLines = 3;
+ − 2590 text[textpointer] = 0;
315
+ − 2591 if(pSettings->FlipDisplay)
+ − 2592 {
+ − 2593 t7cC.WindowY1 -= 40;
+ − 2594 }
38
+ − 2595 GFX_write_string(&FontT48,&t7cC,text,1);
315
+ − 2596 if(pSettings->FlipDisplay)
+ − 2597 {
+ − 2598 t7cC.WindowY1 += 40;
+ − 2599 }
38
+ − 2600 break;
+ − 2601
+ − 2602 case CVIEW_Compass:
+ − 2603 default:
539
+ − 2604
+ − 2605 if(pSettings->compassInertia)
+ − 2606 {
+ − 2607 heading = (uint16_t)compass_getCompensated();
+ − 2608 }
+ − 2609 else
+ − 2610 {
+ − 2611 heading = (uint16_t)stateUsed->lifeData.compass_heading;
+ − 2612 }
38
+ − 2613 snprintf(text,100,"\032\f\001%c%c",TXT_2BYTE, TXT2BYTE_Compass);
+ − 2614 GFX_write_string(&FontT42,&t7cH,text,0);
539
+ − 2615 t7_compass(heading, stateUsed->diveSettings.compassHeading);
110
+ − 2616
+ − 2617 if(!pSettings->FlipDisplay)
+ − 2618 {
+ − 2619 t7cY0free.WindowX0 += 15;
+ − 2620 t7cY0free.WindowY0 = 230;
+ − 2621 }
+ − 2622 else
+ − 2623 {
+ − 2624 t7cY0free.WindowX0 -= 15;
+ − 2625 t7cY0free.WindowY0 = 0;
+ − 2626 t7cY0free.WindowY1 = 250;
+ − 2627 }
539
+ − 2628 snprintf(text,100,"\030\001%03i`",heading);
38
+ − 2629 GFX_write_string(&FontT54,&t7cY0free,text,0);
110
+ − 2630 if(!pSettings->FlipDisplay)
+ − 2631 {
+ − 2632 t7cY0free.WindowX0 -= 15;
+ − 2633 }
+ − 2634 else
+ − 2635 {
+ − 2636 t7cY0free.WindowX0 += 15;
+ − 2637 }
38
+ − 2638 break;
+ − 2639
+ − 2640 case CVIEW_Decolist:
911
+ − 2641
907
+ − 2642
+ − 2643 if(settingsGetPointer()->VPM_conservatism.ub.alternative == 0)
+ − 2644 {
911
+ − 2645 text[0] = '\032';
907
+ − 2646 }
+ − 2647 else
+ − 2648 {
+ − 2649 switch(vpm_get_TableState())
+ − 2650 {
911
+ − 2651 case VPM_TABLE_MISSED: text[0] = '\025';
907
+ − 2652 break;
911
+ − 2653 case VPM_TABLE_WARNING: text[0] = '\024';
907
+ − 2654 break;
+ − 2655 case VPM_TABLE_ACTIVE:
+ − 2656 case VPM_TABLE_INIT:
911
+ − 2657 default: text[0] = '\032';
907
+ − 2658 break;
+ − 2659 }
+ − 2660 }
911
+ − 2661 snprintf(&text[1],100,"\f\001 %c%c", TXT_2BYTE, TXT2BYTE_Decolist);
+ − 2662 GFX_write_string(&FontT42,&t7cH,text,0);
+ − 2663
38
+ − 2664 uint8_t depthNext, depthLast, depthSecond, depthInc;
+ − 2665
+ − 2666 depthLast = (uint8_t)(stateUsed->diveSettings.last_stop_depth_bar * 10);
+ − 2667 depthSecond = (uint8_t)(stateUsed->diveSettings.input_second_to_last_stop_depth_bar * 10);
+ − 2668 depthInc = (uint8_t)(stateUsed->diveSettings.input_next_stop_increment_depth_bar * 10);
+ − 2669
+ − 2670 if(settingsGetPointer()->nonMetricalSystem)
+ − 2671 {
+ − 2672 depthLast = (uint8_t)unit_depth_integer(depthLast);
+ − 2673 depthSecond = (uint8_t)unit_depth_integer(depthSecond);
+ − 2674 depthInc = (uint8_t)unit_depth_integer(depthInc);
+ − 2675 }
907
+ − 2676 if(stateUsed->diveSettings.deco_type.ub.standard == VPM_MODE) /* show additional VPM data in last slot */
+ − 2677 {
+ − 2678 decoPlanEntries = 5;
+ − 2679 }
38
+ − 2680
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 2681 const SDecoinfo * pDecoinfo = getDecoInfo();
38
+ − 2682 for(start=DECOINFO_STRUCT_MAX_STOPS-1; start>0; start--)
+ − 2683 if(pDecoinfo->output_stop_length_seconds[start]) break;
907
+ − 2684 start -= decoPlanEntries;
38
+ − 2685 if(start < 0) start = 0;
+ − 2686
+ − 2687 textpointer = 0;
907
+ − 2688 for(int i=start;i<decoPlanEntries+start;i++)
38
+ − 2689 {
+ − 2690 if(i == 0)
+ − 2691 depthNext = depthLast;
+ − 2692 else
+ − 2693 depthNext = depthSecond + (( i - 1 )* depthInc);
+ − 2694
+ − 2695 if(pDecoinfo->output_stop_length_seconds[i])
+ − 2696 textpointer += snprintf(&text[textpointer],20,"\030\034 %2u\016\016%c%c\017%3i'\n\r",depthNext, unit_depth_char1(), unit_depth_char2(), (pDecoinfo->output_stop_length_seconds[i]+59)/60);
+ − 2697 else
+ − 2698 textpointer += snprintf(&text[textpointer],20,"\031\034 %2u\016\016%c%c\017\n\r",depthNext, unit_depth_char1(), unit_depth_char2());
+ − 2699 if(textpointer > 200) break;
+ − 2700 }
907
+ − 2701 if(decoPlanEntries == 5) /* add VPM deco zone */
+ − 2702 {
911
+ − 2703 textpointer += snprintf(&text[textpointer],30,"\031\034 Zone %2u\016\016%c%c\017\n\r",vpm_get_decozone(), unit_depth_char1(), unit_depth_char2());
907
+ − 2704 }
110
+ − 2705 if(!pSettings->FlipDisplay)
+ − 2706 {
+ − 2707 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
+ − 2708 }
+ − 2709 else
+ − 2710 {
+ − 2711 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
+ − 2712 t7cY0free.WindowY1 = 400;
+ − 2713 }
+ − 2714
38
+ − 2715 t7cY0free.WindowLineSpacing = 48;
+ − 2716 t7cY0free.WindowNumberOfTextLines = 6;
+ − 2717 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 2718 break;
770
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2719 case CVIEW_CcrSummary:
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2720 snprintf(text, 100, "\032\f\001%c%c", TXT_2BYTE, TXT2BYTE_CcrSummary);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2721 GFX_write_string(&FontT42, &t7cH, text, 0);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2722 t7_CcrSummary(pSettings);
8deb28b2d4da
CCR overview in surface mode. Makes it easy to quickly check that all settings (mode, setpoints, diluent, scrubber timer) are correct when preparing to dive (also makes the OC gas list available in surface mode for the same reason).
heinrichsweikamp
diff
changeset
+ − 2723 break;
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2724 case CVIEW_Timer:
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2725 snprintf(text, 100, "\032\f\001%c%c", TXT_2BYTE, TXT2BYTE_Timer);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2726 GFX_write_string(&FontT42, &t7cH, text, 0);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2727
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2728 int nowS = current_second();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2729
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2730 updateTimer(pSettings, nowS, last_customview != CVIEW_Timer);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2731
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2732 showTimer(pSettings, nowS);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2733
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2734 break;
899
+ − 2735
+ − 2736 case CVIEW_Position:
+ − 2737 snprintf(text, 100, "\032\f\001%c%c", TXT_2BYTE, TXT2BYTE_Position);
+ − 2738 GFX_write_string(&FontT42, &t7cH, text, 0);
+ − 2739 t7_showPosition();
38
+ − 2740 }
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2741
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 2742 last_customview = selection_customview;
38
+ − 2743 }
+ − 2744
+ − 2745
+ − 2746 /* DIVE MODE
+ − 2747 */
+ − 2748 void t7_refresh_divemode(void)
+ − 2749 {
+ − 2750 char TextL1[TEXTSIZE];
+ − 2751 char TextL2[TEXTSIZE];
+ − 2752
+ − 2753 char TextR1[TEXTSIZE];
+ − 2754 char TextR2[TEXTSIZE];
+ − 2755 char TextR3[TEXTSIZE];
+ − 2756
+ − 2757 char TextC1[2*TEXTSIZE];
+ − 2758 char TextC2[TEXTSIZE];
+ − 2759 uint8_t textPointer;
+ − 2760
884
+ − 2761 uint8_t color = 0;
38
+ − 2762 int textlength;
+ − 2763
+ − 2764 uint16_t nextstopLengthSeconds = 0;
+ − 2765 uint8_t nextstopDepthMeter = 0;
+ − 2766 uint8_t oxygen_percentage = 0;
+ − 2767 SDivetime Divetime = {0,0,0, 0};
+ − 2768 SDivetime SafetyStopTime = {0,0,0,0};
+ − 2769 SDivetime TimeoutTime = {0,0,0,0};
+ − 2770 uint8_t customview_warnings = 0;
+ − 2771
110
+ − 2772 SSettings* pSettings;
+ − 2773 pSettings = settingsGetPointer();
+ − 2774
38
+ − 2775 Divetime.Total = stateUsed->lifeData.dive_time_seconds_without_surface_time;
+ − 2776 Divetime.Minutes = Divetime.Total / 60;
+ − 2777 Divetime.Seconds = Divetime.Total - ( Divetime.Minutes * 60 );
+ − 2778
+ − 2779 SafetyStopTime.Total = timer_Safetystop_GetCountDown();
+ − 2780 SafetyStopTime.Minutes = SafetyStopTime.Total / 60;
+ − 2781 SafetyStopTime.Seconds = SafetyStopTime.Total - (SafetyStopTime.Minutes * 60);
+ − 2782
882
+ − 2783 TimeoutTime.Total = pSettings->timeoutDiveReachedZeroDepth - stateUsed->lifeData.counterSecondsShallowDepth;
+ − 2784 if(TimeoutTime.Total > pSettings->timeoutDiveReachedZeroDepth)
38
+ − 2785 {
+ − 2786 TimeoutTime.Total = 0;
+ − 2787 }
+ − 2788 TimeoutTime.Minutes = TimeoutTime.Total / 60;
+ − 2789 TimeoutTime.Seconds = TimeoutTime.Total - (TimeoutTime.Minutes * 60);
+ − 2790
788
4abfb8a2a435
Define explicit setpoints for low / high / deco. Add an option to delay the switch to SPlow until all decompression has been cleared. (mikeller)
heinrichsweikamp
diff
changeset
+ − 2791 const SDecoinfo * pDecoinfo = getDecoInfo();
38
+ − 2792 if(pDecoinfo->output_time_to_surface_seconds)
+ − 2793 {
+ − 2794 tHome_findNextStop(pDecoinfo->output_stop_length_seconds, &nextstopDepthMeter, &nextstopLengthSeconds);
+ − 2795 }
+ − 2796 else
+ − 2797 {
+ − 2798 nextstopDepthMeter = 0;
+ − 2799 nextstopLengthSeconds = 0;
+ − 2800 }
+ − 2801
882
+ − 2802
+ − 2803 /* max depth */
+ − 2804 snprintf(TextL2,TEXTSIZE,"\032\f%c",TXT_MaxDepth);
+ − 2805 GFX_write_string(&FontT42,&t7l2,TextL2,0);
+ − 2806
+ − 2807 if(unit_depth_float(stateUsed->lifeData.max_depth_meter) < 100)
+ − 2808 snprintf(TextL2,TEXTSIZE,"\020%01.1f",unit_depth_float(stateUsed->lifeData.max_depth_meter));
+ − 2809 else
+ − 2810 snprintf(TextL2,TEXTSIZE,"\020%01.0f",unit_depth_float(stateUsed->lifeData.max_depth_meter));
+ − 2811
+ − 2812 Gfx_colorsscheme_mod(TextL2, 0);
+ − 2813 GFX_write_string(&FontT105,&t7l2,TextL2,1);
+ − 2814
+ − 2815 /* ascent rate graph */
+ − 2816
915
+ − 2817 if((pSettings->slowExitTime != 0) && (nextstopDepthMeter == 0) && (stateUsed->lifeData.depth_meter < pSettings->last_stop_depth_meter))
882
+ − 2818 {
+ − 2819 color = t7_drawSlowExitGraph();
+ − 2820 }
+ − 2821 else if(stateUsed->lifeData.ascent_rate_meter_per_min > 1) /* a value < 1 would cause a bar in negative direction brush rectangle of 12 and step width of 6 */
+ − 2822 {
+ − 2823 color = drawingColor_from_ascentspeed(stateUsed->lifeData.ascent_rate_meter_per_min);
+ − 2824 t7_drawAcentGraph(color);
+ − 2825 }
+ − 2826
+ − 2827
38
+ − 2828 /* depth */
174
+ − 2829 float depth = unit_depth_float(stateUsed->lifeData.depth_meter);
38
+ − 2830
+ − 2831 if(depth <= 0.3f)
+ − 2832 depth = 0;
+ − 2833
+ − 2834 if(settingsGetPointer()->nonMetricalSystem)
+ − 2835 snprintf(TextL1,TEXTSIZE,"\032\f[feet]");
+ − 2836 else
+ − 2837 snprintf(TextL1,TEXTSIZE,"\032\f%c",TXT_Depth);
868
+ − 2838
38
+ − 2839 GFX_write_string(&FontT24,&t7l1,TextL1,0);
+ − 2840
+ − 2841 if((stateUsed->lifeData.ascent_rate_meter_per_min > 8) || (stateUsed->lifeData.ascent_rate_meter_per_min < -10))
+ − 2842 {
+ − 2843 snprintf(TextL1,TEXTSIZE,"\f\002%.0f %c%c/min "
+ − 2844 , unit_depth_float(stateUsed->lifeData.ascent_rate_meter_per_min)
+ − 2845 , unit_depth_char1()
+ − 2846 , unit_depth_char2()
+ − 2847 );
+ − 2848 GFX_write_string(&FontT24,&t7l1,TextL1,0);
+ − 2849 }
+ − 2850
+ − 2851 if( depth < 100)
+ − 2852 snprintf(TextL1,TEXTSIZE,"\020%01.1f",depth);
+ − 2853 else
+ − 2854 snprintf(TextL1,TEXTSIZE,"\020%01.0f",depth);
+ − 2855
868
+ − 2856 Gfx_colorsscheme_mod(TextL1, color);
+ − 2857
+ − 2858 GFX_write_string(&FontT144,&t7l1,TextL1,0);
38
+ − 2859
882
+ − 2860 /* divetime */
38
+ − 2861 if(stateUsed->lifeData.counterSecondsShallowDepth)
+ − 2862 {
+ − 2863 snprintf(TextR1,TEXTSIZE,"\f\002\136 %u:%02u",TimeoutTime.Minutes, TimeoutTime.Seconds);
+ − 2864 GFX_write_string(&FontT42,&t7r1,TextR1,0);
+ − 2865 }
+ − 2866 else
+ − 2867 {
+ − 2868 snprintf(TextR1,TEXTSIZE,"\032\f\002%c",TXT_Divetime);
+ − 2869 GFX_write_string(&FontT42,&t7r1,TextR1,0);
+ − 2870 }
+ − 2871
+ − 2872 if(Divetime.Minutes < 1000)
564
+ − 2873 snprintf(TextR1,TEXTSIZE,"\020\002\016%u:%02u",Divetime.Minutes, Divetime.Seconds);
38
+ − 2874 else
564
+ − 2875 snprintf(TextR1,TEXTSIZE,"\020\002\016%u'",Divetime.Minutes);
868
+ − 2876 Gfx_colorsscheme_mod(TextR1, 0);
38
+ − 2877 GFX_write_string(&FontT105,&t7r1,TextR1,1);
+ − 2878
+ − 2879 /* next deco stop */
+ − 2880 if(nextstopDepthMeter)
+ − 2881 {
911
+ − 2882 snprintf(TextR2,TEXTSIZE,"\032\f\002%c",TXT_Decostop);
+ − 2883 GFX_write_string(&FontT42,&t7r2,TextR2,0);
+ − 2884
+ − 2885 if((pSettings->VPM_conservatism.ub.alternative) && (fabs(stateUsed->lifeData.depth_meter - nextstopDepthMeter)) < 1.5)
+ − 2886 {
+ − 2887 TextR2[0] = '\026';
+ − 2888 textlength = 1;
+ − 2889 }
+ − 2890 else
+ − 2891 {
+ − 2892 TextR2[0] = '\020';
+ − 2893 textlength = 1;
+ − 2894 }
+ − 2895
+ − 2896 textlength += snprintf(&TextR2[textlength],TEXTSIZE,"\002%u%c%c %u'"
38
+ − 2897 , unit_depth_integer(nextstopDepthMeter)
+ − 2898 , unit_depth_char1_T105()
+ − 2899 , unit_depth_char2_T105()
+ − 2900 , (nextstopLengthSeconds+59)/60);
868
+ − 2901 Gfx_colorsscheme_mod(TextR2, 0);
38
+ − 2902 if(time_elapsed_ms(pDecoinfo->tickstamp, HAL_GetTick()) > MAX_AGE_DECOINFO_MS)
527
+ − 2903 TextR2[0] = '\031';
38
+ − 2904 if(textlength <= 9)
+ − 2905 GFX_write_string(&FontT105,&t7r2,TextR2,1);
567
+ − 2906 else if(textlength <= 10)
+ − 2907 GFX_write_string(&FontT84Spaced,&t7r2,TextR2,1);
38
+ − 2908 else
+ − 2909 GFX_write_string(&FontT54,&t7r2,TextR2,1);
+ − 2910 }
+ − 2911 else if(SafetyStopTime.Total && (depth > timer_Safetystop_GetDepthUpperLimit()))
+ − 2912 {
+ − 2913 snprintf(TextR2,TEXTSIZE,"\032\f\002%c%c",TXT_2BYTE,TXT2BYTE_SafetyStop2);
+ − 2914 GFX_write_string(&FontT42,&t7r2,TextR2,0);
564
+ − 2915 snprintf(TextR2,TEXTSIZE,"\020\002\016%u:%02u",SafetyStopTime.Minutes,SafetyStopTime.Seconds);
868
+ − 2916 Gfx_colorsscheme_mod(TextR2, 0);
38
+ − 2917 GFX_write_string(&FontT105,&t7r2,TextR2,1);
+ − 2918 }
+ − 2919
+ − 2920 /* tts - option 1
+ − 2921 * ndl - option 2
+ − 2922 * empty - option 3 */
+ − 2923 if(pDecoinfo->output_time_to_surface_seconds)
+ − 2924 {
+ − 2925 snprintf(TextR3,TEXTSIZE,"\032\f\002%c",TXT_TTS);
+ − 2926 GFX_write_string(&FontT42,&t7r3,TextR3,0);
+ − 2927 if(pDecoinfo->output_time_to_surface_seconds < 1000 * 60)
214
+ − 2928 snprintf(TextR3,TEXTSIZE,"\020\002%i'",(pDecoinfo->output_time_to_surface_seconds + 59)/ 60);
38
+ − 2929 else
214
+ − 2930 snprintf(TextR3,TEXTSIZE,"\020\002%ih",(pDecoinfo->output_time_to_surface_seconds + 59)/ 3600);
868
+ − 2931 Gfx_colorsscheme_mod(TextR3, 0);
38
+ − 2932 if(time_elapsed_ms(pDecoinfo->tickstamp, HAL_GetTick()) > MAX_AGE_DECOINFO_MS)
527
+ − 2933 TextR2[0] = '\031';
38
+ − 2934 GFX_write_string(&FontT105,&t7r3,TextR3,1);
+ − 2935 }
+ − 2936 else if(pDecoinfo->output_ndl_seconds)
+ − 2937 {
+ − 2938 snprintf(TextR3,TEXTSIZE,"\032\f\002%c",TXT_Nullzeit);
+ − 2939 GFX_write_string(&FontT42,&t7r3,TextR3,0);
+ − 2940 if(pDecoinfo->output_ndl_seconds < 1000 * 60)
+ − 2941 snprintf(TextR3,TEXTSIZE,"\020\002%i'",pDecoinfo->output_ndl_seconds/60);
+ − 2942 else
+ − 2943 snprintf(TextR3,TEXTSIZE,"\020\002%ih",pDecoinfo->output_ndl_seconds/3600);
868
+ − 2944 Gfx_colorsscheme_mod(TextR3, 0);
38
+ − 2945 if(time_elapsed_ms(pDecoinfo->tickstamp, HAL_GetTick()) > MAX_AGE_DECOINFO_MS)
527
+ − 2946 TextR2[0] = '\031';
38
+ − 2947 GFX_write_string(&FontT105,&t7r3,TextR3,1);
+ − 2948 }
+ − 2949
+ − 2950 /* Menu Selection (and gas mix) */
+ − 2951 if(get_globalState() == StDMGAS)
+ − 2952 {
+ − 2953 textPointer = 0;
+ − 2954 TextR1[textPointer++] = '\a';
+ − 2955 // TextR1[textPointer++] = '\f';
+ − 2956 TextR1[textPointer++] = '\001';
+ − 2957 TextR1[textPointer++] = ' ';
+ − 2958 textPointer += tHome_gas_writer(stateUsed->diveSettings.gas[actualBetterGasId()].oxygen_percentage,stateUsed->diveSettings.gas[actualBetterGasId()].helium_percentage,&TextR1[textPointer]);
+ − 2959 TextR1[textPointer++] = '?';
+ − 2960 TextR1[textPointer++] = ' ';
+ − 2961 TextR1[textPointer++] = 0;
+ − 2962 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 2963 }
+ − 2964 else if(get_globalState() == StDMSPT)
+ − 2965 {
+ − 2966 textPointer = 0;
+ − 2967 TextR1[textPointer++] = '\a';
+ − 2968 TextR1[textPointer++] = '\001';
+ − 2969 TextR1[textPointer++] = ' ';
680
+ − 2970 textPointer += snprintf(&TextR1[textPointer],TEXTSIZE,"%01.2f",(float)(stateUsed->diveSettings.setpoint[actualBetterSetpointId()].setpoint_cbar) / 100.0);
38
+ − 2971 TextR1[textPointer++] = '?';
+ − 2972 TextR1[textPointer++] = ' ';
+ − 2973 TextR1[textPointer++] = 0;
+ − 2974 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 2975 }
+ − 2976 else if(get_globalState() == StDMENU)
+ − 2977 {
+ − 2978 snprintf(TextR1,TEXTSIZE,"\a\001%c%c", TXT_2BYTE, TXT2BYTE_DiveMenuQ);
+ − 2979 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
773
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2980 } else if (get_globalState() == StDBAILOUT) {
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2981 if (isLoopMode(stateUsed->diveSettings.diveMode)) {
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2982 textPointer = snprintf(TextR1, TEXTSIZE, "\a\001 %c%c ", TXT_2BYTE, TXT2BYTE_BailoutShort);
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2983 textPointer += tHome_gas_writer(stateUsed->diveSettings.gas[actualBetterBailoutGasId()].oxygen_percentage, stateUsed->diveSettings.gas[actualBetterBailoutGasId()].helium_percentage, &TextR1[textPointer]);
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2984 TextR1[textPointer++] = ' ';
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2985 TextR1[textPointer++] = '?';
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2986 } else {
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2987 textPointer = snprintf(TextR1, TEXTSIZE, "\a\001 %c%c %01.2f/", TXT_2BYTE, TXT2BYTE_LoopShort, stateUsed->diveSettings.setpoint[actualBetterSetpointId()].setpoint_cbar / 100.0);
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2988 textPointer += tHome_gas_writer(stateUsed->diveSettings.gas[stateUsed->lifeData.lastDiluent_GasIdInSettings].oxygen_percentage, stateUsed->diveSettings.gas[stateUsed->lifeData.lastDiluent_GasIdInSettings].helium_percentage, &TextR1[textPointer]);
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2989 TextR1[textPointer++] = ' ';
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2990 TextR1[textPointer++] = '?';
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2991 }
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2992
2c243233c999
Menu shortcut for bailout / return to circuit when diving in CCR mode (mikeller)
heinrichsweikamp
diff
changeset
+ − 2993 GFX_write_string_color(&FontT48, &t7c2, TextR1, 0, CLUT_WarningYellow);
775
46c6d2380d4e
Add a shortcuts to change the setpoint to the loop to the 'normal' display when diving. It is only shown when diving in CCR mode and on the loop.
heinrichsweikamp
diff
changeset
+ − 2994 } else if (get_globalState() == StDSETPOINT) {
46c6d2380d4e
Add a shortcuts to change the setpoint to the loop to the 'normal' display when diving. It is only shown when diving in CCR mode and on the loop.
heinrichsweikamp
diff
changeset
+ − 2995 snprintf(TextR1, TEXTSIZE, "\a\001 %c%c %01.2f? ", TXT_2BYTE, TXT2BYTE_SetpointShort, getSwitchToSetpointCbar() / 100.0);
46c6d2380d4e
Add a shortcuts to change the setpoint to the loop to the 'normal' display when diving. It is only shown when diving in CCR mode and on the loop.
heinrichsweikamp
diff
changeset
+ − 2996
46c6d2380d4e
Add a shortcuts to change the setpoint to the loop to the 'normal' display when diving. It is only shown when diving in CCR mode and on the loop.
heinrichsweikamp
diff
changeset
+ − 2997 GFX_write_string_color(&FontT48, &t7c2, TextR1, 0, CLUT_WarningYellow);
38
+ − 2998 }
777
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 2999 else if(get_globalState() == StDBEAR)
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 3000 {
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 3001 snprintf(TextR1, TEXTSIZE, "\a\001 %c%c? ", TXT_2BYTE, TXT2BYTE_DiveBearingQ);
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 3002 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 3003 }
38
+ − 3004 else if(get_globalState() == StDSIM1)
+ − 3005 {
+ − 3006 snprintf(TextR1,TEXTSIZE,"\a\001%c%c", TXT_2BYTE, TXT2BYTE_DiveQuitQ);
+ − 3007 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 3008 }
+ − 3009 else if(get_globalState() == StDSIM2)
+ − 3010 {
+ − 3011 if(settingsGetPointer()->nonMetricalSystem)
+ − 3012 snprintf(TextR1,TEXTSIZE,"\a\001" " Sim:-3.33ft ");
+ − 3013 else
+ − 3014 snprintf(TextR1,TEXTSIZE,"\a\001" " Sim:-1m ");
+ − 3015 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 3016
+ − 3017 snprintf(TextR1,TEXTSIZE,"\a\f %u %c%c"
+ − 3018 , unit_depth_integer(simulation_get_aim_depth())
+ − 3019 , unit_depth_char1()
+ − 3020 , unit_depth_char2()
+ − 3021 );
+ − 3022 GFX_write_string_color(&FontT42,&t7l1,TextR1,0,CLUT_WarningYellow);
+ − 3023
+ − 3024 }
+ − 3025 else if(get_globalState() == StDSIM3)
+ − 3026 {
+ − 3027 if(settingsGetPointer()->nonMetricalSystem)
+ − 3028 snprintf(TextR1,TEXTSIZE,"\a\001" " Sim:+3.33ft ");
+ − 3029 else
+ − 3030 snprintf(TextR1,TEXTSIZE,"\a\001" " Sim:+1m ");
+ − 3031 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 3032 snprintf(TextR1,TEXTSIZE,"\a\f %u %c%c"
+ − 3033 , unit_depth_integer(simulation_get_aim_depth())
+ − 3034 , unit_depth_char1()
+ − 3035 , unit_depth_char2()
+ − 3036 );
+ − 3037 GFX_write_string_color(&FontT42,&t7l1,TextR1,0,CLUT_WarningYellow);
+ − 3038 }
+ − 3039 else if(get_globalState() == StDSIM4)
+ − 3040 {
+ − 3041 snprintf(TextR1,TEXTSIZE,"\a\001" " Sim:+5' ");
+ − 3042 GFX_write_string_color(&FontT48,&t7c2,TextR1,0,CLUT_WarningYellow);
+ − 3043 snprintf(TextR1,TEXTSIZE,"\a\f %u %c%c"
+ − 3044 , unit_depth_integer(simulation_get_aim_depth())
+ − 3045 , unit_depth_char1()
+ − 3046 , unit_depth_char2()
+ − 3047 );
+ − 3048 GFX_write_string_color(&FontT42,&t7l1,TextR1,0,CLUT_WarningYellow);
+ − 3049 }
+ − 3050 else
+ − 3051 {
+ − 3052 /* gas mix */
+ − 3053 oxygen_percentage = 100;
+ − 3054 oxygen_percentage -= stateUsed->lifeData.actualGas.nitrogen_percentage;
+ − 3055 oxygen_percentage -= stateUsed->lifeData.actualGas.helium_percentage;
+ − 3056
+ − 3057 textPointer = 0;
+ − 3058 TextC2[textPointer++] = '\020';
+ − 3059 if(stateUsed->warnings.betterGas && warning_count_high_time)
+ − 3060 {
+ − 3061 TextC2[textPointer++] = '\a';
+ − 3062 }
+ − 3063 else
+ − 3064 {
+ − 3065 float fPpO2limitHigh, fPpO2now;
+ − 3066
+ − 3067 if(actualLeftMaxDepth(stateUsed))
+ − 3068 fPpO2limitHigh = settingsGetPointer()->ppO2_max_deco;
+ − 3069 else
+ − 3070 fPpO2limitHigh = settingsGetPointer()->ppO2_max_std;
+ − 3071
+ − 3072 fPpO2now = (stateUsed->lifeData.pressure_ambient_bar - WATER_VAPOUR_PRESSURE) * oxygen_percentage;
+ − 3073
+ − 3074 if((fPpO2now > fPpO2limitHigh) || (fPpO2now < (float)(settingsGetPointer()->ppO2_min)))
+ − 3075 TextC2[textPointer++] = '\025';
+ − 3076 }
+ − 3077 TextC2[textPointer++] = '\002';
+ − 3078 textPointer += tHome_gas_writer(oxygen_percentage,stateUsed->lifeData.actualGas.helium_percentage,&TextC2[textPointer]);
+ − 3079
+ − 3080 if(stateUsed->warnings.betterGas && warning_count_high_time)
+ − 3081 {
+ − 3082 if(TextC2[0] == '\020')
+ − 3083 {
+ − 3084 TextC2[0] = '\004'; // NOP
+ − 3085 }
+ − 3086 GFX_write_string_color(&FontT48,&t7c2,TextC2,0,CLUT_WarningYellow);
+ − 3087 }
+ − 3088 else
+ − 3089 {
868
+ − 3090 Gfx_colorsscheme_mod(TextC2, 0);
38
+ − 3091 GFX_write_string(&FontT48,&t7c2,TextC2,0); // T54 has only numbers
+ − 3092 }
+ − 3093
+ − 3094 if(stateUsed->diveSettings.ccrOption)
+ − 3095 {
662
+ − 3096 if(isLoopMode(stateUsed->diveSettings.diveMode))
38
+ − 3097 {
+ − 3098 snprintf(TextC2,TEXTSIZE,"\020%01.2f",stateUsed->lifeData.ppO2);
662
+ − 3099
38
+ − 3100 if(stateUsed->warnings.betterSetpoint && warning_count_high_time && (stateUsed->diveSettings.diveMode == DIVEMODE_CCR))
+ − 3101 {
+ − 3102 TextC2[0] = '\a'; // inverse instead of color \020
+ − 3103 GFX_write_string_color(&FontT48,&t7c2,TextC2,0,CLUT_WarningYellow);
+ − 3104 }
+ − 3105 else
+ − 3106 {
868
+ − 3107 Gfx_colorsscheme_mod(TextC2, 0);
38
+ − 3108 GFX_write_string(&FontT48,&t7c2,TextC2,0);
+ − 3109 }
+ − 3110 }
+ − 3111 }
+ − 3112 else if(settingsGetPointer()->alwaysShowPPO2)
+ − 3113 {
+ − 3114 snprintf(TextC2,TEXTSIZE,"\020%01.2f",stateUsed->lifeData.ppO2);
868
+ − 3115 Gfx_colorsscheme_mod(TextC2, 0);
38
+ − 3116 GFX_write_string(&FontT48,&t7c2,TextC2,0);
+ − 3117 }
+ − 3118 }
+ − 3119
+ − 3120 /* algorithm, ccr, bailout and battery */
+ − 3121 /* and permanent warnings (CNS) */
+ − 3122
+ − 3123 if((stateUsed->warnings.cnsHigh) && display_count_high_time)
+ − 3124 {
+ − 3125 TextC2[0] = '\f';
+ − 3126 TextC2[1] = TXT_2BYTE;
+ − 3127 TextC2[2] = TXT2BYTE_WarnCnsHigh;
+ − 3128 TextC2[3] = 0;
662
+ − 3129 GFX_write_string_color(&FontT42,&t7c1,TextC2,0,CLUT_WarningRed);
38
+ − 3130 }
+ − 3131 else
+ − 3132 {
+ − 3133 if(stateUsed->warnings.aGf)
+ − 3134 {
+ − 3135 GFX_write_string_color(&FontT48,&t7c1,"\f" "aGF",0,CLUT_WarningYellow);
+ − 3136 }
+ − 3137 else if(stateUsed->diveSettings.deco_type.ub.standard == GF_MODE)
+ − 3138 {
+ − 3139 GFX_write_string(&FontT48,&t7c1,"\027\f" "GF",0);
+ − 3140 }
+ − 3141 else
+ − 3142 {
+ − 3143 GFX_write_string(&FontT48,&t7c1,"\027\f" "VPM",0);
+ − 3144 }
+ − 3145
+ − 3146 if(stateUsed->diveSettings.diveMode == DIVEMODE_CCR)
+ − 3147 GFX_write_string(&FontT24,&t7c1,"\027\f\002" "CCR",0);
+ − 3148 // GFX_write_string(&FontT24,&t7c1,"\f\177\177\x80" "CCR",0);
+ − 3149 else
662
+ − 3150 if(stateUsed->diveSettings.diveMode == DIVEMODE_PSCR)
+ − 3151 GFX_write_string(&FontT24,&t7c1,"\027\f\002" "PSCR",0);
+ − 3152 else
38
+ − 3153 if(stateUsed->diveSettings.ccrOption)
+ − 3154 GFX_write_string(&FontT24,&t7c1,"\f\002\024" "Bailout",0);
+ − 3155 // GFX_write_string(&FontT24,&t7c1,"\f\177\177\x80\024" "Bailout",0);
+ − 3156 }
+ − 3157 TextC1[0] = '\020';
+ − 3158 TextC1[1] = '3';
+ − 3159 TextC1[2] = '1';
+ − 3160 TextC1[3] = '1';
+ − 3161 TextC1[4] = '1';
+ − 3162 TextC1[5] = '1';
+ − 3163 TextC1[6] = '1';
+ − 3164 TextC1[7] = '1';
+ − 3165 TextC1[8] = '1';
+ − 3166 TextC1[9] = '1';
+ − 3167 TextC1[10] = '1';
+ − 3168 TextC1[11] = '1';
+ − 3169 TextC1[12] = '0';
+ − 3170 TextC1[13] = 0;
+ − 3171
+ − 3172 for(int i=1;i<=10;i++)
+ − 3173 {
+ − 3174 if( stateUsed->lifeData.battery_charge > (9 * i))
+ − 3175 TextC1[i+1] += 1;
+ − 3176 }
+ − 3177
+ − 3178 if(stateUsed->warnings.lowBattery)
+ − 3179 {
+ − 3180 TextC1[0] = '\025';
+ − 3181 if(warning_count_high_time)
+ − 3182 {
+ − 3183 for(int i=2;i<=11;i++)
+ − 3184 TextC1[i] = '1';
+ − 3185 }
+ − 3186 else
+ − 3187 {
+ − 3188 TextC1[2] = '2';
+ − 3189 }
+ − 3190 GFX_write_string(&Batt24,&t7batt,TextC1,0);
+ − 3191
+ − 3192 if((stateUsed->lifeData.battery_charge > 0) && (stateUsed->lifeData.battery_charge < 140))
+ − 3193 {
+ − 3194 snprintf(TextC1,16,"\004\025\f\002%u%%",(uint8_t)stateUsed->lifeData.battery_charge);
+ − 3195 if(warning_count_high_time)
+ − 3196 TextC1[0] = '\a';
110
+ − 3197 GFX_write_string(&FontT24,&t7voltage,TextC1,0);
38
+ − 3198 }
+ − 3199 }
+ − 3200 else
+ − 3201 {
868
+ − 3202 Gfx_colorsscheme_mod(TextC1, 0);
38
+ − 3203 GFX_write_string(&Batt24,&t7batt,TextC1,0);
+ − 3204
+ − 3205 if((stateUsed->lifeData.battery_charge > 0) && (stateUsed->lifeData.battery_charge < 140))
+ − 3206 {
+ − 3207 snprintf(TextC1,16,"\020\f\002%u%%",(uint8_t)stateUsed->lifeData.battery_charge);
868
+ − 3208 Gfx_colorsscheme_mod(TextC1, 0);
110
+ − 3209 GFX_write_string(&FontT24,&t7voltage,TextC1,0); // t7batt
38
+ − 3210 }
+ − 3211 }
+ − 3212
+ − 3213 /* customizable left lower corner */
+ − 3214 t7_refresh_divemode_userselected_left_lower_corner();
+ − 3215
+ − 3216
+ − 3217 /* customview - option 1
+ − 3218 * warning - option 2 */
+ − 3219 if(stateUsed->warnings.numWarnings)
+ − 3220 customview_warnings = t7_test_customview_warnings();
+ − 3221
166
+ − 3222 background.pointer = 0;
38
+ − 3223 if(customview_warnings && warning_count_high_time)
+ − 3224 t7_show_customview_warnings();
+ − 3225 else
+ − 3226 t7_refresh_customview();
+ − 3227
+ − 3228 /* the frame */
+ − 3229 draw_frame(1,1, CLUT_DIVE_pluginbox, CLUT_DIVE_FieldSeperatorLines);
+ − 3230 }
+ − 3231
+ − 3232 void t7_set_field_to_primary(void)
+ − 3233 {
+ − 3234 if(stateUsed->mode == MODE_DIVE)
+ − 3235 selection_custom_field = settingsGetPointer()->tX_userselectedLeftLowerCornerPrimary;
+ − 3236 }
+ − 3237
+ − 3238 void t7_change_field(void)
+ − 3239 {
+ − 3240 selection_custom_field++;
+ − 3241
442
+ − 3242 if((stateUsed->diveSettings.deco_type.ub.standard == VPM_MODE) && (selection_custom_field == LLC_GF)) /* no GF if in VPM mode */
+ − 3243 {
+ − 3244 selection_custom_field++;
+ − 3245 }
662
+ − 3246 if((selection_custom_field == LLC_ScrubberTime) && ((settingsGetPointer()->scrubTimerMode == SCRUB_TIMER_OFF) || (!isLoopMode(settingsGetPointer()->dive_mode))))
656
+ − 3247 {
+ − 3248 selection_custom_field++;
+ − 3249 }
662
+ − 3250 #ifdef ENABLE_PSCR_MODE
+ − 3251 if((selection_custom_field == LCC_SimPpo2) && (settingsGetPointer()->dive_mode != DIVEMODE_PSCR))
+ − 3252 {
+ − 3253 selection_custom_field++;
+ − 3254 }
+ − 3255 #endif
840
+ − 3256 #ifdef ENABLE_CO2_SUPPORT
+ − 3257 if((selection_custom_field == LCC_CO2) && (settingsGetPointer()->co2_sensor_active == 0))
+ − 3258 {
+ − 3259 selection_custom_field++;
+ − 3260 }
+ − 3261
+ − 3262 #endif
+ − 3263
442
+ − 3264 if(selection_custom_field >= LLC_END)
+ − 3265 {
+ − 3266 selection_custom_field = LLC_Empty;
+ − 3267 }
38
+ − 3268 }
+ − 3269
+ − 3270
+ − 3271 void t7_refresh_divemode_userselected_left_lower_corner(void)
+ − 3272 {
+ − 3273 if(!selection_custom_field)
+ − 3274 return;
+ − 3275
+ − 3276 char headerText[10];
+ − 3277 char text[TEXTSIZE];
+ − 3278 uint8_t textpointer = 0;
+ − 3279 _Bool tinyHeaderFont = 0;
+ − 3280 uint8_t line = 0;
457
+ − 3281 #ifdef ENABLE_BOTTLE_SENSOR
442
+ − 3282 uint16_t agedColor = 0;
457
+ − 3283 #endif
38
+ − 3284
+ − 3285 SDivetime Stopwatch = {0,0,0,0};
+ − 3286 float fAverageDepth, fAverageDepthAbsolute;
+ − 3287 const SDecoinfo * pDecoinfoStandard;
+ − 3288 const SDecoinfo * pDecoinfoFuture;
+ − 3289 float fCNS;
+ − 3290 float temperature;
710
+ − 3291 SSettings* pSettings = settingsGetPointer();
38
+ − 3292
+ − 3293 if(stateUsed->diveSettings.deco_type.ub.standard == GF_MODE)
+ − 3294 {
+ − 3295 pDecoinfoStandard = &stateUsed->decolistBuehlmann;
+ − 3296 pDecoinfoFuture = &stateUsed->decolistFutureBuehlmann;
+ − 3297 }
+ − 3298 else
+ − 3299 {
+ − 3300 pDecoinfoStandard = &stateUsed->decolistVPM;
+ − 3301 pDecoinfoFuture = &stateUsed->decolistFutureVPM;
+ − 3302 }
+ − 3303
+ − 3304 Stopwatch.Total = timer_Stopwatch_GetTime();
+ − 3305 Stopwatch.Minutes = Stopwatch.Total / 60;
+ − 3306 Stopwatch.Seconds = Stopwatch.Total - ( Stopwatch.Minutes * 60 );
+ − 3307 fAverageDepth = timer_Stopwatch_GetAvarageDepth_Meter();
+ − 3308 fAverageDepthAbsolute = stateUsed->lifeData.average_depth_meter;
+ − 3309
+ − 3310 headerText[0] = '\032';
+ − 3311 headerText[1] = '\f';
+ − 3312
+ − 3313 switch(selection_custom_field)
+ − 3314 {
+ − 3315 /* Temperature */
442
+ − 3316 case LLC_Temperature:
38
+ − 3317 default:
189
8b8074080d7b
Bugfix: average temperature on arrival from RTE instead of display time
Jan Mulder <jlmulder@xs4all.nl>
diff
changeset
+ − 3318 temperature = unit_temperature_float(stateUsed->lifeData.temperature_celsius);
38
+ − 3319 headerText[2] = TXT_Temperature;
+ − 3320 textpointer = snprintf(text,TEXTSIZE,"\020\016%01.1f \140",temperature); // "\016\016%01.1f `" + C or F
+ − 3321 if(settingsGetPointer()->nonMetricalSystem == 0)
+ − 3322 text[textpointer++] = 'C';
+ − 3323 else
+ − 3324 text[textpointer++] = 'F';
+ − 3325 text[textpointer++] = 0;
+ − 3326 tinyHeaderFont = 0;
+ − 3327 break;
+ − 3328
+ − 3329 /* Average Depth */
442
+ − 3330 case LLC_AverageDepth:
38
+ − 3331 headerText[2] = TXT_AvgDepth;
710
+ − 3332 if(pSettings->nonMetricalSystem)
38
+ − 3333 snprintf(text,TEXTSIZE,"\020%01.0f",unit_depth_float(fAverageDepthAbsolute));
+ − 3334 else
+ − 3335 snprintf(text,TEXTSIZE,"\020%01.1f",fAverageDepthAbsolute);
+ − 3336 break;
+ − 3337
+ − 3338 /* ppO2 */
442
+ − 3339 case LLC_ppO2:
38
+ − 3340 headerText[2] = TXT_ppO2;
+ − 3341 snprintf(text,TEXTSIZE,"\020%01.2f",stateUsed->lifeData.ppO2);
+ − 3342 break;
+ − 3343
+ − 3344 /* Stop Uhr */
442
+ − 3345 case LLC_Stopwatch:
38
+ − 3346 headerText[2] = TXT_Stopwatch;
710
+ − 3347 if(pSettings->nonMetricalSystem)
38
+ − 3348 snprintf(text,TEXTSIZE,"\020\016\016%u:%02u\n\r%01.0f",Stopwatch.Minutes, Stopwatch.Seconds,unit_depth_float(fAverageDepth));
+ − 3349 else
+ − 3350 snprintf(text,TEXTSIZE,"\020\016\016%u:%02u\n\r%01.1f",Stopwatch.Minutes, Stopwatch.Seconds,fAverageDepth);
+ − 3351 tinyHeaderFont = 1;
+ − 3352 line = 1;
+ − 3353 break;
+ − 3354
+ − 3355 /* Ceiling */
442
+ − 3356 case LLC_Ceiling:
38
+ − 3357 headerText[2] = TXT_Ceiling;
710
+ − 3358 if((pDecoinfoStandard->output_ceiling_meter > 99.9f) || (pSettings->nonMetricalSystem))
38
+ − 3359 snprintf(text,TEXTSIZE,"\020%01.0f",unit_depth_float(pDecoinfoStandard->output_ceiling_meter));
+ − 3360 else
+ − 3361 snprintf(text,TEXTSIZE,"\020%01.1f",pDecoinfoStandard->output_ceiling_meter);
+ − 3362 break;
+ − 3363
+ − 3364 /* Future TTS */
442
+ − 3365 case LLC_FutureTTS:
38
+ − 3366 headerText[2] = TXT_FutureTTS;
214
+ − 3367 if (pDecoinfoFuture->output_time_to_surface_seconds < 1000 * 60)
710
+ − 3368 snprintf(text,TEXTSIZE,"\020\016\016@+%u'\n\r" "%i' TTS",pSettings->future_TTS, (pDecoinfoFuture->output_time_to_surface_seconds + 59) / 60);
214
+ − 3369 else
710
+ − 3370 snprintf(text,TEXTSIZE,"\020\016\016@+%u'\n\r" "%ih TTS",pSettings->future_TTS, (pDecoinfoFuture->output_time_to_surface_seconds + 59) / 3600);
38
+ − 3371 tinyHeaderFont = 1;
+ − 3372 line = 1;
+ − 3373 break;
+ − 3374
+ − 3375 /* CNS */
442
+ − 3376 case LLC_CNS:
38
+ − 3377 headerText[2] = TXT_CNS;
+ − 3378 fCNS = stateUsed->lifeData .cns;
+ − 3379 if(fCNS > 999)
+ − 3380 fCNS = 999;
+ − 3381 snprintf(text,TEXTSIZE,"\020%.0f\016\016%%\017",fCNS);
+ − 3382 break;
+ − 3383
+ − 3384 /* actual GF */
442
+ − 3385 case LLC_GF:
38
+ − 3386 headerText[2] = TXT_ActualGradient;
247
+ − 3387 snprintf(text,TEXTSIZE,"\020%.0f\016\016%%\017",100 * pDecoinfoStandard->super_saturation);
38
+ − 3388 break;
656
+ − 3389
+ − 3390 case LLC_ScrubberTime:
+ − 3391 tinyHeaderFont = 1;
+ − 3392 headerText[2] = TXT_ScrubTime;
758
b6d8a6fbf4fd
- Colours for scrubber display when time remaining falls below a threshold value
heinrichsweikamp
diff
changeset
+ − 3393
b6d8a6fbf4fd
- Colours for scrubber display when time remaining falls below a threshold value
heinrichsweikamp
diff
changeset
+ − 3394 printScrubberText(text, TEXTSIZE, pSettings);
b6d8a6fbf4fd
- Colours for scrubber display when time remaining falls below a threshold value
heinrichsweikamp
diff
changeset
+ − 3395
656
+ − 3396 break;
662
+ − 3397 #ifdef ENABLE_PSCR_MODE
+ − 3398 case LCC_SimPpo2:
+ − 3399 headerText[2] = TXT_SimPpo2;
+ − 3400 snprintf(text,TEXTSIZE,"\020%.2f\016\016Bar\017",stateUsed->lifeData.ppo2Simulated_bar);
+ − 3401 break;
+ − 3402 #endif
656
+ − 3403
446
+ − 3404 #ifdef ENABLE_BOTTLE_SENSOR
442
+ − 3405 case LCC_BottleBar:
+ − 3406 headerText[2] = TXT_AtemGasVorrat;
+ − 3407 tinyHeaderFont = 1;
448
+ − 3408 snprintf(text,TEXTSIZE,"%d\016\016\017", stateUsed->lifeData.bottle_bar[stateUsed->lifeData.actualGas.GasIdInSettings]);
442
+ − 3409 break;
446
+ − 3410 #endif
749
+ − 3411 #ifdef ENABLE_CO2_SUPPORT
+ − 3412 case LCC_CO2:
+ − 3413 headerText[2] = TXT_CO2Sensor;
+ − 3414 if(stateUsed->lifeData.CO2_data.CO2_ppm < CO2_WARNING_LEVEL_PPM)
+ − 3415 {
+ − 3416 text[textpointer++] = '\020';
+ − 3417 }
+ − 3418 else if(stateUsed->lifeData.CO2_data.CO2_ppm < CO2_ALARM_LEVEL_PPM)
+ − 3419 {
+ − 3420 text[textpointer++] = '\024'; /* yellow */
+ − 3421 }
+ − 3422 else
+ − 3423 {
+ − 3424 text[textpointer++] = '\025'; /* red */
+ − 3425 }
+ − 3426 snprintf(&text[textpointer],TEXTSIZE,"\%5ldppm", stateUsed->lifeData.CO2_data.CO2_ppm);
799
+ − 3427 break;
749
+ − 3428 #endif
737
+ − 3429 case LLC_Compass:
+ − 3430 headerText[2] = TXT_2BYTE;
+ − 3431 headerText[3] = TXT2BYTE_Compass;
+ − 3432 tinyHeaderFont = 1;
+ − 3433
+ − 3434 uint16_t heading;
+ − 3435 if(settingsGetPointer()->compassInertia) {
+ − 3436 heading = (uint16_t)compass_getCompensated();
+ − 3437 } else {
+ − 3438 heading = (uint16_t)stateUsed->lifeData.compass_heading;
+ − 3439 }
+ − 3440
+ − 3441 uint16_t userSetHeading = stateUsed->diveSettings.compassHeading;
+ − 3442 if (!userSetHeading) {
+ − 3443 snprintf(text, TEXTSIZE, "\020\002\034%u ", heading);
+ − 3444 } else {
+ − 3445 snprintf(text, TEXTSIZE, "\020\002\034\016\016%u ", heading);
+ − 3446
+ − 3447 int16_t declinationFromForwardMark = ((userSetHeading - heading + 180 + 360) % 360) - 180;
+ − 3448 int16_t declinationFromNearestMark = ((declinationFromForwardMark + 90 + 180) % 180) - 90;
+ − 3449
+ − 3450 uint16_t colour;
+ − 3451 if (abs(declinationFromForwardMark) <= 90) {
+ − 3452 colour = CLUT_CompassUserHeadingTick;
+ − 3453 } else {
+ − 3454 colour = CLUT_CompassUserBackHeadingTick;
+ − 3455 }
+ − 3456
+ − 3457 char direction[] = "\001 \004 \004 ";
+ − 3458 if (abs(declinationFromNearestMark) <= 10) {
+ − 3459 direction[2] = '>';
+ − 3460 direction[6] = '<';
+ − 3461
+ − 3462 if (abs(declinationFromForwardMark) <= 10) {
+ − 3463 direction[4] = 'X';
+ − 3464 } else {
+ − 3465 direction[4] = 'O';
+ − 3466 }
+ − 3467
+ − 3468 if (abs(declinationFromNearestMark) <= 3) {
+ − 3469 direction[3] = '\a';
+ − 3470 direction[5] = '\a';
+ − 3471 }
+ − 3472 } else {
+ − 3473 if (declinationFromForwardMark < -90) {
+ − 3474 direction[7] = 'O';
+ − 3475 } else if (declinationFromForwardMark < 0) {
+ − 3476 direction[1] = 'X';
+ − 3477 } else if (declinationFromForwardMark <= 90) {
+ − 3478 direction[7] = 'X';
+ − 3479 } else {
+ − 3480 direction[1] = 'O';
+ − 3481 }
+ − 3482
+ − 3483 if (declinationFromNearestMark >= 0) {
+ − 3484 direction[6] = '>';
+ − 3485 }
+ − 3486 if (declinationFromNearestMark > 30) {
+ − 3487 direction[4] = '>';
+ − 3488 }
+ − 3489 if (declinationFromNearestMark > 60 || declinationFromForwardMark == 90) {
+ − 3490 direction[2] = '>';
+ − 3491 }
+ − 3492 if (declinationFromNearestMark < 0) {
+ − 3493 direction[2] = '<';
+ − 3494 }
+ − 3495 if (declinationFromNearestMark < -30) {
+ − 3496 direction[4] = '<';
+ − 3497 }
+ − 3498 if (declinationFromNearestMark < -60 || declinationFromForwardMark == -90) {
+ − 3499 direction[6] = '<';
+ − 3500 }
+ − 3501 }
+ − 3502
+ − 3503 GFX_write_string_color(&FontT48, &t7l3, direction, 1, colour);
+ − 3504 }
+ − 3505
+ − 3506 break;
38
+ − 3507 }
737
+ − 3508
+ − 3509 if (headerText[2] != TXT_2BYTE) {
+ − 3510 headerText[3] = 0;
+ − 3511 } else {
+ − 3512 headerText[4] = 0;
+ − 3513 }
38
+ − 3514
+ − 3515 if(tinyHeaderFont)
+ − 3516 GFX_write_string(&FontT24,&t7l3,headerText,0);
+ − 3517 else
+ − 3518 GFX_write_string(&FontT42,&t7l3,headerText,0);
+ − 3519
868
+ − 3520 Gfx_colorsscheme_mod(text, 0);
446
+ − 3521 #ifndef ENABLE_BOTTLE_SENSOR
748
+ − 3522 #ifdef ENABLE_CO2_SUPPORT
+ − 3523 if(selection_custom_field != LCC_CO2)
+ − 3524 {
+ − 3525 GFX_write_string(&FontT105,&t7l3,text,line);
+ − 3526 }
+ − 3527 else
+ − 3528 {
+ − 3529 GFX_write_string(&FontT48,&t7l3,text,line);
+ − 3530 }
+ − 3531 #else
+ − 3532 GFX_write_string(&FontT105,&t7l3,text,line);
+ − 3533 #endif
446
+ − 3534 #else
+ − 3535 if(selection_custom_field != LCC_BottleBar) /* a changing color set is used for bar display */
442
+ − 3536 {
+ − 3537 GFX_write_string(&FontT105,&t7l3,text,line);
+ − 3538 }
+ − 3539 else
+ − 3540 {
448
+ − 3541 agedColor = stateUsed->lifeData.bottle_bar_age_MilliSeconds[stateUsed->lifeData.actualGas.GasIdInSettings];
442
+ − 3542 if(agedColor > 1200)
+ − 3543 {
448
+ − 3544 agedColor = CLUT_WarningRed;
442
+ − 3545 }
+ − 3546 else
+ − 3547 if(agedColor > 600)
448
+ − 3548 {
+ − 3549 agedColor = CLUT_MenuLineUnselected;
+ − 3550 }
+ − 3551 else
+ − 3552 if(agedColor > 20)
442
+ − 3553 {
448
+ − 3554 agedColor = CLUT_Font031;
442
+ − 3555 }
+ − 3556 else
+ − 3557 {
448
+ − 3558 agedColor = CLUT_Font020;
442
+ − 3559 }
+ − 3560
+ − 3561 GFX_write_string_color(&FontT105,&t7l3,text,line,agedColor);
+ − 3562 }
446
+ − 3563 #endif
38
+ − 3564 }
+ − 3565
+ − 3566 /* Private functions ---------------------------------------------------------*/
+ − 3567
+ − 3568 uint8_t t7_customtextPrepare(char * text)
+ − 3569 {
+ − 3570 uint8_t i, j, textptr, lineCount;
+ − 3571 char nextChar;
539
+ − 3572 uint8_t alignmentChanged = 0;
38
+ − 3573
+ − 3574 textptr = 0;
+ − 3575 lineCount = 0;
+ − 3576
+ − 3577 text[textptr++] = TXT_MINIMAL;
+ − 3578
+ − 3579 j = 0;
+ − 3580 i = 0;
+ − 3581 do
+ − 3582 {
+ − 3583 j += i;
+ − 3584 i = 0;
+ − 3585 do
+ − 3586 {
+ − 3587 nextChar = settingsGetPointer()->customtext[i+j];
539
+ − 3588 if((nextChar == '^') && (alignmentChanged == 0)) /* center */
537
+ − 3589 {
+ − 3590 text[textptr++] = '\001';
539
+ − 3591 alignmentChanged = 1;
537
+ − 3592 i++;
+ − 3593 }else
539
+ − 3594 if((nextChar == 180) && (alignmentChanged == 0)) /* '�' => Right */
537
+ − 3595 {
+ − 3596 text[textptr++] = '\002';
539
+ − 3597 alignmentChanged = 1;
537
+ − 3598 i++;
+ − 3599 }else
+ − 3600 {
+ − 3601 i++;
+ − 3602 if((!nextChar) || (nextChar =='\n') || (nextChar =='\r'))
+ − 3603 {
+ − 3604 break;
+ − 3605 }
+ − 3606 text[textptr++] = nextChar;
+ − 3607 }
38
+ − 3608 } while (i < 12);
+ − 3609
537
+ − 3610 if(i == 12) /* exit by limit => check for blanks at the end of the string */
+ − 3611 {
+ − 3612 while((textptr - 1 > 0) && (text[textptr - 1] == 32))
+ − 3613 {
+ − 3614 textptr--;
+ − 3615 }
+ − 3616 }
+ − 3617
38
+ − 3618 if(!nextChar)
+ − 3619 break;
+ − 3620
+ − 3621 if(lineCount < 3)
+ − 3622 {
+ − 3623 text[textptr++] = '\n';
+ − 3624 text[textptr++] = '\r';
+ − 3625 }
539
+ − 3626 alignmentChanged = 0;
38
+ − 3627 lineCount++;
+ − 3628 for(uint8_t k=0;k<2;k++)
+ − 3629 {
+ − 3630 nextChar = settingsGetPointer()->customtext[i+j+k];
+ − 3631 if((nextChar =='\n') || (nextChar =='\r'))
+ − 3632 i++;
+ − 3633 else
+ − 3634 break;
+ − 3635 }
+ − 3636
+ − 3637 } while (lineCount < 4);
+ − 3638
+ − 3639 text[textptr] = 0;
+ − 3640 return lineCount;
+ − 3641 }
+ − 3642
+ − 3643 void draw_frame(_Bool PluginBoxHeader, _Bool LinesOnTheSides, uint8_t colorBox, uint8_t colorLinesOnTheSide)
+ − 3644 {
+ − 3645 point_t LeftLow, WidthHeight;
+ − 3646 point_t start, stop;
+ − 3647
110
+ − 3648 SSettings* pSettings;
+ − 3649 pSettings = settingsGetPointer();
+ − 3650
38
+ − 3651 // plugin box
+ − 3652 LeftLow.x = CUSTOMBOX_LINE_LEFT;
+ − 3653 WidthHeight.x = CUSTOMBOX_LINE_RIGHT - CUSTOMBOX_LINE_LEFT;
+ − 3654 LeftLow.y = 60;
+ − 3655 WidthHeight.y = 440 - LeftLow.y;
642
+ − 3656 if((viewInFocus() && (!viewDetectionSuspended())))
553
+ − 3657 {
+ − 3658 GFX_draw_box(&t7screen, LeftLow, WidthHeight, 1, CLUT_Font023);
+ − 3659 }
+ − 3660 else
+ − 3661 {
+ − 3662 GFX_draw_box(&t7screen, LeftLow, WidthHeight, 1, colorBox);
+ − 3663 }
38
+ − 3664
+ − 3665 if(PluginBoxHeader)
+ − 3666 {
+ − 3667 // plugin box - header
+ − 3668 start.x = CUSTOMBOX_LINE_LEFT;
+ − 3669 stop.x = CUSTOMBOX_LINE_RIGHT;
+ − 3670 stop.y = start.y = 440 - 60;
+ − 3671 GFX_draw_line(&t7screen, start, stop, colorBox);
+ − 3672 }
+ − 3673
+ − 3674 if(LinesOnTheSides)
+ − 3675 {
+ − 3676 // aufteilung links
+ − 3677 start.x = 0;
+ − 3678 stop.x = CUSTOMBOX_LINE_LEFT;
110
+ − 3679 if(!pSettings->FlipDisplay)
+ − 3680 {
+ − 3681 stop.y = start.y = t7l1.WindowY0 - 1;
+ − 3682 }
+ − 3683 else
+ − 3684 {
+ − 3685 stop.y = start.y = 480 - t7l1.WindowY1 - 1;
+ − 3686 }
+ − 3687
38
+ − 3688 GFX_draw_line(&t7screen, start, stop, colorLinesOnTheSide);
110
+ − 3689 if(!pSettings->FlipDisplay)
+ − 3690 {
+ − 3691 stop.y = start.y = t7l2.WindowY0 -1;
+ − 3692 }
+ − 3693 else
+ − 3694 {
+ − 3695 stop.y = start.y = 480 - t7l2.WindowY1 -1;
+ − 3696 }
38
+ − 3697 GFX_draw_line(&t7screen, start, stop, colorLinesOnTheSide);
+ − 3698
+ − 3699 // aufteilung rechts
+ − 3700 start.x = CUSTOMBOX_LINE_RIGHT;
+ − 3701 stop.x = 799;
110
+ − 3702 if(!pSettings->FlipDisplay)
+ − 3703 {
+ − 3704 stop.y = start.y = t7l1.WindowY0 - 1;
+ − 3705 }
+ − 3706 else
+ − 3707 {
+ − 3708 stop.y = start.y = 480 - t7l1.WindowY1 - 1;
+ − 3709 }
+ − 3710
38
+ − 3711 GFX_draw_line(&t7screen, start, stop, colorLinesOnTheSide);
110
+ − 3712 if(!pSettings->FlipDisplay)
+ − 3713 {
+ − 3714 stop.y = start.y = t7l2.WindowY0 - 1;
+ − 3715 }
+ − 3716 else
+ − 3717 {
+ − 3718 stop.y = start.y = 480 - t7l2.WindowY1 - 1;
+ − 3719 }
38
+ − 3720 GFX_draw_line(&t7screen, start, stop, colorLinesOnTheSide);
+ − 3721 }
+ − 3722 }
+ − 3723
+ − 3724
+ − 3725 /* Compass like TCOS shellfish
+ − 3726 * input is 0 to 359
+ − 3727 * 2 px / 1 degree
+ − 3728 * Range is 148 degree with CUSTOMBOX_SPACE_INSIDE = 296
+ − 3729 * one side is 74 degree (less than 90 degree)
+ − 3730 * internal 360 + 180 degree of freedom
+ − 3731 * use positive values only, shift by 360 below 90 mid position
+ − 3732 */
+ − 3733
+ − 3734
+ − 3735 point_t t7_compass_circle(uint8_t id, uint16_t degree)
+ − 3736 {
+ − 3737 float fCos, fSin;
+ − 3738 const float piMult = ((2 * 3.14159) / 360);
+ − 3739 // const int radius[4] = {95,105,115,60};
+ − 3740 const int radius[4] = {95,105,115,100};
+ − 3741 const point_t offset = {.x = 400, .y = 250};
+ − 3742
+ − 3743 static point_t r[4][360] = { 0 };
+ − 3744
110
+ − 3745 if(r[0][0].y == 0) /* calc table at first call only */
38
+ − 3746 {
+ − 3747 for(int i=0;i<360;i++)
+ − 3748 {
+ − 3749 fCos = cos(i * piMult);
+ − 3750 fSin = sin(i * piMult);
+ − 3751 for(int j=0;j<4;j++)
+ − 3752 {
+ − 3753 r[j][i].x = offset.x + (int)(fSin * radius[j]);
+ − 3754 r[j][i].y = offset.y + (int)(fCos * radius[j]);
+ − 3755 }
+ − 3756 }
+ − 3757 }
+ − 3758 if(id > 3) id = 0;
+ − 3759 if(degree > 359) degree = 0;
+ − 3760 return r[id][degree];
+ − 3761 }
+ − 3762
+ − 3763 /* range should be 0 to 30 bar if 300 meter with 100% of nitrogen or helium
+ − 3764 * T24 is 28 high
+ − 3765 */
+ − 3766 void t7_tissues(const SDiveState * pState)
+ − 3767 {
+ − 3768 point_t start, change, stop;
+ − 3769 float value;
+ − 3770 uint16_t front, cns100pixel;
+ − 3771 char text[256];
+ − 3772 uint8_t textpointer = 0;
+ − 3773 uint8_t color;
+ − 3774
+ − 3775 float percent_N2;
+ − 3776 float percent_He;
+ − 3777 float partial_pressure_N2;
+ − 3778 float partial_pressure_He;
+ − 3779
110
+ − 3780 SSettings* pSettings;
+ − 3781 pSettings = settingsGetPointer();
+ − 3782
38
+ − 3783
+ − 3784 /* N2 */
+ − 3785 t7cY0free.WindowLineSpacing = 28 + 48 + 14;
110
+ − 3786 if(!pSettings->FlipDisplay)
+ − 3787 {
+ − 3788 t7cY0free.WindowY0 = t7cH.WindowY0 - 5 - 2 * t7cY0free.WindowLineSpacing;
+ − 3789 }
+ − 3790 else
+ − 3791 {
+ − 3792 t7cY0free.WindowY0 = t7cH.WindowY0 + 15;
+ − 3793 t7cY0free.WindowY1 = t7cY0free.WindowY0 + 250;
+ − 3794 }
38
+ − 3795 t7cY0free.WindowNumberOfTextLines = 3;
+ − 3796
+ − 3797 text[textpointer++] = '\030';
+ − 3798 text[textpointer++] = TXT_2BYTE;
+ − 3799 text[textpointer++] = TXT2BYTE_Nitrogen;
+ − 3800 text[textpointer++] = '\n';
+ − 3801 text[textpointer++] = '\r';
+ − 3802 text[textpointer++] = TXT_2BYTE;
+ − 3803 text[textpointer++] = TXT2BYTE_Helium;
+ − 3804 text[textpointer++] = '\n';
+ − 3805 text[textpointer++] = '\r';
+ − 3806 text[textpointer++] = TXT_2BYTE;
+ − 3807 text[textpointer++] = TXT2BYTE_CNS;
+ − 3808 text[textpointer++] = 0;
+ − 3809
+ − 3810 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 3811
110
+ − 3812 if(!pSettings->FlipDisplay)
+ − 3813 {
+ − 3814 start.y = t7cH.WindowY0 - 5;
+ − 3815 }
+ − 3816 else
+ − 3817 {
+ − 3818 start.y = t7cH.WindowY1 - 5;
+ − 3819 }
38
+ − 3820 start.x = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 3821 stop.x = start.x + CUSTOMBOX_SPACE_INSIDE;
+ − 3822
+ − 3823 for(int i=0;i<16;i++)
+ − 3824 {
+ − 3825 stop.y = start.y;
+ − 3826 change.y = start.y;
+ − 3827
+ − 3828 value = pState->lifeData.tissue_nitrogen_bar[i] - 0.7512f;
222
+ − 3829 value *= 80;
38
+ − 3830
+ − 3831 if(value < 0)
+ − 3832 front = 0;
+ − 3833 else
+ − 3834 if(value > CUSTOMBOX_SPACE_INSIDE)
+ − 3835 front = CUSTOMBOX_SPACE_INSIDE;
+ − 3836 else
+ − 3837 front = (uint16_t)value;
+ − 3838
+ − 3839 change.x = start.x + front;
+ − 3840 if(change.x != start.x)
+ − 3841 GFX_draw_thick_line(1,&t7screen, start, change, CLUT_Font030);
+ − 3842 if(change.x != stop.x)
+ − 3843 GFX_draw_thick_line(1,&t7screen, change, stop, CLUT_Font031);
+ − 3844
+ − 3845 start.y -= 3;
+ − 3846 }
+ − 3847
+ − 3848 /* He */
+ − 3849 start.y -= 28 + 14;
+ − 3850 for(int i=0;i<16;i++)
+ − 3851 {
+ − 3852 stop.y = start.y;
+ − 3853 change.y = start.y;
+ − 3854
+ − 3855 value = pState->lifeData.tissue_helium_bar[i];
+ − 3856 value *= 80;//20
+ − 3857
+ − 3858 if(value < 0)
+ − 3859 front = 0;
+ − 3860 else if(value > CUSTOMBOX_SPACE_INSIDE)
+ − 3861 front = CUSTOMBOX_SPACE_INSIDE;
+ − 3862 else
+ − 3863 front = (uint16_t)value;
+ − 3864
+ − 3865 change.x = start.x + front;
+ − 3866 if(change.x != start.x)
+ − 3867 GFX_draw_thick_line(1,&t7screen, start, change, CLUT_Font030);
+ − 3868 if(change.x != stop.x)
+ − 3869 GFX_draw_thick_line(1,&t7screen, change, stop, CLUT_Font031);
+ − 3870
+ − 3871 start.y -= 3;
+ − 3872 }
+ − 3873
+ − 3874 /* CNS == Oxygen */
+ − 3875 start.y -= 28 + 14;
+ − 3876
+ − 3877 cns100pixel = (8 * CUSTOMBOX_SPACE_INSIDE) / 10;
+ − 3878 value = pState->lifeData.cns;
+ − 3879 value *= cns100pixel;
+ − 3880 value /= 100;
+ − 3881
+ − 3882 if(value < 0)
+ − 3883 front = 0;
+ − 3884 else if(value > CUSTOMBOX_SPACE_INSIDE)
+ − 3885 front = CUSTOMBOX_SPACE_INSIDE;
+ − 3886 else
+ − 3887 front = (uint16_t)value;
+ − 3888
+ − 3889 if(pState->lifeData.cns < 95)
+ − 3890 color = CLUT_Font030;
+ − 3891 else if(pState->lifeData.cns < 100)
+ − 3892 color = CLUT_WarningYellow;
+ − 3893 else
+ − 3894 color = CLUT_WarningRed;
+ − 3895
+ − 3896 for(int i=0;i<16;i++)
+ − 3897 {
+ − 3898 stop.y = start.y;
+ − 3899 change.y = start.y;
+ − 3900
+ − 3901 change.x = start.x + front;
+ − 3902 if(change.x != start.x)
+ − 3903 GFX_draw_thick_line(1,&t7screen, start, change, color);
+ − 3904 if(change.x != stop.x)
+ − 3905 GFX_draw_thick_line(1,&t7screen, change, stop, CLUT_Font031);
+ − 3906
+ − 3907 start.y -= 3;
+ − 3908 }
+ − 3909
+ − 3910 /* where is the onload/offload limit for N2 and He */
+ − 3911 decom_get_inert_gases(pState->lifeData.pressure_ambient_bar, &pState->lifeData.actualGas, &percent_N2, &percent_He);
+ − 3912 partial_pressure_N2 = (pState->lifeData.pressure_ambient_bar - WATER_VAPOUR_PRESSURE) * percent_N2;
+ − 3913 partial_pressure_He = (pState->lifeData.pressure_ambient_bar - WATER_VAPOUR_PRESSURE) * percent_He;
+ − 3914
+ − 3915 // Nitrogen vertical bar
110
+ − 3916 if(!pSettings->FlipDisplay)
+ − 3917 {
+ − 3918 start.y = t7cH.WindowY0 + 1 - 5;
+ − 3919 }
+ − 3920 else
+ − 3921 {
+ − 3922 start.y = t7cH.WindowY1 - 5;
+ − 3923 }
+ − 3924
38
+ − 3925 stop.y = start.y - (3 * 15) - 1;
222
+ − 3926 if((percent_N2 > 0) && (partial_pressure_N2 > 0.7512f))
38
+ − 3927 {
222
+ − 3928 value = partial_pressure_N2 - 0.7512f;
+ − 3929 value *= 80;
38
+ − 3930
+ − 3931 if(value < 0)
+ − 3932 front = 3;
+ − 3933 else if(value + 5 > CUSTOMBOX_SPACE_INSIDE)
+ − 3934 front = CUSTOMBOX_SPACE_INSIDE - 3;
+ − 3935 else
+ − 3936 front = (uint16_t)value;
+ − 3937 }
+ − 3938 else
+ − 3939 {
+ − 3940 front = 1;
+ − 3941 }
+ − 3942 start.x = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + front;
+ − 3943 stop.x = start.x;
+ − 3944 GFX_draw_thick_line(2,&t7screen, start, stop, CLUT_EverythingOkayGreen);
+ − 3945
+ − 3946
+ − 3947 // Helium vertical bar
110
+ − 3948 if(!pSettings->FlipDisplay)
+ − 3949 {
+ − 3950 start.y = t7cH.WindowY0 + 1 - 5 - 3*16 - 28 - 14;
+ − 3951 }
+ − 3952 else
+ − 3953 {
+ − 3954 start.y = t7cH.WindowY1 - 5 - 3*16 - 28 - 14;
+ − 3955 }
+ − 3956
38
+ − 3957 stop.y = start.y - (3 * 15) - 1;
+ − 3958 if((percent_He > 0) && (partial_pressure_He > 0.01f)) // 0.5f
+ − 3959 {
+ − 3960
+ − 3961 value = partial_pressure_He;
222
+ − 3962 value *= 80;
38
+ − 3963
+ − 3964 if(value < 0)
+ − 3965 front = 3;
+ − 3966 else if(value + 5 > CUSTOMBOX_SPACE_INSIDE)
+ − 3967 front = CUSTOMBOX_SPACE_INSIDE - 3;
+ − 3968 else
+ − 3969 front = (uint16_t)value;
+ − 3970 }
+ − 3971 else
+ − 3972 {
+ − 3973 front = 1;
+ − 3974 }
+ − 3975
+ − 3976 start.x = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + front;
+ − 3977 stop.x = start.x;
+ − 3978 GFX_draw_thick_line(2,&t7screen, start, stop, CLUT_EverythingOkayGreen);
+ − 3979
+ − 3980 // Oxygen vertical bar
110
+ − 3981 if(!pSettings->FlipDisplay)
+ − 3982 {
+ − 3983 start.y = t7cH.WindowY0 + 1 - 5 - 6*16 - 2*28 - 2*14;
+ − 3984 }
+ − 3985 else
+ − 3986 {
+ − 3987 start.y = t7cH.WindowY1 - 5 - 6*16 - 2*28 - 2*14;
+ − 3988 }
+ − 3989
38
+ − 3990 stop.y = start.y - (3 * 15) - 1;
+ − 3991
+ − 3992 start.x = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + cns100pixel;
+ − 3993 stop.x = start.x;
+ − 3994 GFX_draw_thick_line(2, &t7screen, start, stop, CLUT_WarningRed);
110
+ − 3995
38
+ − 3996 }
+ − 3997
+ − 3998
+ − 3999 void t7_debug(void)
+ − 4000 {
+ − 4001 char text[256+50];
+ − 4002 uint8_t textpointer = 0;
+ − 4003
+ − 4004 t7cY0free.WindowLineSpacing = 28 + 48 + 14;
+ − 4005 t7cY0free.WindowY0 = t7cH.WindowY0 - 5 - 2 * t7cY0free.WindowLineSpacing;
+ − 4006 t7cY0free.WindowNumberOfTextLines = 3;
+ − 4007
896
+ − 4008 #ifdef T7_DEBUG_RUNTIME
+ − 4009 textpointer += snprintf(&text[textpointer],50,"Main loop %ld\n\r",getMainLoopTime());
+ − 4010 textpointer += snprintf(&text[textpointer],50,"Grafic loop %ld\n\r",getGfxLoopTime());
+ − 4011 textpointer += snprintf(&text[textpointer],50,"Decoloop %ld\n\r",getDecoLoopTime());
+ − 4012 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4013 #else
38
+ − 4014 textpointer += snprintf(&text[textpointer],50,"Ambient [bar]\n\r");
+ − 4015 textpointer += snprintf(&text[textpointer],50,"Surface [bar] + salt\n\r");
+ − 4016 // textpointer += snprintf(&text[textpointer],50,"Difference [mbar]\n\r");
+ − 4017 textpointer += snprintf(&text[textpointer],50,"ShallowCounter [s]\n\r");
+ − 4018 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4019
+ − 4020 t7cY0free.WindowY0 -= 52;
+ − 4021 // snprintf(text,60,"%0.2f\n\r%0.2f %u%%\n\r%0.0f",stateUsed->lifeData.pressure_ambient_bar, stateUsed->lifeData.pressure_surface_bar, settingsGetPointer()->salinity, 1000 * (stateUsed->lifeData.pressure_ambient_bar-stateUsed->lifeData.pressure_surface_bar));
+ − 4022 snprintf(text,60,
+ − 4023 "%0.2f\n\r"
+ − 4024 "%0.2f %u%%\n\r"
+ − 4025 "%u"
+ − 4026 ,stateUsed->lifeData.pressure_ambient_bar
+ − 4027 ,stateUsed->lifeData.pressure_surface_bar
+ − 4028 ,settingsGetPointer()->salinity
+ − 4029 ,stateUsed->lifeData.counterSecondsShallowDepth);
+ − 4030 GFX_write_string(&FontT42, &t7cY0free, text, 1);
896
+ − 4031 #endif
38
+ − 4032 }
+ − 4033
899
+ − 4034 void t7_showPosition(void)
+ − 4035 {
+ − 4036 char text[256+50];
+ − 4037 uint8_t textpointer = 0;
+ − 4038
+ − 4039 t7cY0free.WindowLineSpacing = 28 + 48 + 14;
+ − 4040 t7cY0free.WindowY0 = t7cH.WindowY0 - 5 - 2 * t7cY0free.WindowLineSpacing;
+ − 4041 t7cY0free.WindowNumberOfTextLines = 3;
+ − 4042
+ − 4043 textpointer += snprintf(&text[textpointer],50,"\001Longitude\n\r");
+ − 4044 textpointer += snprintf(&text[textpointer],50,"\001Latitude\n\r");
+ − 4045 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4046
+ − 4047 t7cY0free.WindowY0 -= 52;
+ − 4048 snprintf(text,60,
+ − 4049 "\001%0.5f\n\r"
+ − 4050 "\001%0.5f\n\r"
+ − 4051 ,stateUsed->lifeData.gnssPosition.Longitude
+ − 4052 ,stateUsed->lifeData.gnssPosition.Latitude );
+ − 4053
+ − 4054 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 4055 }
38
+ − 4056 void t7_SummaryOfLeftCorner(void)
+ − 4057 {
+ − 4058 char text[256+60];
+ − 4059 uint8_t textpointer = 0;
656
+ − 4060 SSettings* pSettings = settingsGetPointer();
38
+ − 4061
+ − 4062 const SDecoinfo * pDecoinfoStandard;
+ − 4063 const SDecoinfo * pDecoinfoFuture;
+ − 4064 float fCNS;
+ − 4065
+ − 4066 if(stateUsed->diveSettings.deco_type.ub.standard == GF_MODE)
+ − 4067 {
+ − 4068 pDecoinfoStandard = &stateUsed->decolistBuehlmann;
+ − 4069 pDecoinfoFuture = &stateUsed->decolistFutureBuehlmann;
+ − 4070 }
+ − 4071 else
+ − 4072 {
+ − 4073 pDecoinfoStandard = &stateUsed->decolistVPM;
+ − 4074 pDecoinfoFuture = &stateUsed->decolistFutureVPM;
+ − 4075 }
+ − 4076
+ − 4077 fCNS = stateUsed->lifeData .cns;
+ − 4078 if(fCNS > 999)
+ − 4079 fCNS = 999;
+ − 4080
+ − 4081 t7cY0free.WindowY0 = t7cC.WindowY0 - 10;
656
+ − 4082 if(pSettings->FlipDisplay)
315
+ − 4083 {
+ − 4084 t7cY0free.WindowY1 = 400;
+ − 4085 }
+ − 4086
38
+ − 4087 t7cY0free.WindowLineSpacing = 48;
+ − 4088 t7cY0free.WindowNumberOfTextLines = 6;
+ − 4089 t7cY0free.WindowTab = 420;
+ − 4090
+ − 4091 // header
+ − 4092 textpointer = 0;
+ − 4093 text[textpointer++] = '\032';
+ − 4094 text[textpointer++] = '\016';
+ − 4095 text[textpointer++] = '\016';
+ − 4096 text[textpointer++] = TXT_ppO2;
+ − 4097 text[textpointer++] = '\n';
+ − 4098 text[textpointer++] = '\r';
+ − 4099 text[textpointer++] = TXT_Ceiling;
+ − 4100 text[textpointer++] = '\n';
+ − 4101 text[textpointer++] = '\r';
+ − 4102 text[textpointer++] = TXT_ActualGradient;
+ − 4103 text[textpointer++] = '\n';
+ − 4104 text[textpointer++] = '\r';
+ − 4105 text[textpointer++] = TXT_CNS;
+ − 4106 text[textpointer++] = '\n';
+ − 4107 text[textpointer++] = '\r';
+ − 4108 text[textpointer++] = TXT_FutureTTS;
656
+ − 4109 text[textpointer++] = '\n';
+ − 4110 text[textpointer++] = '\r';
662
+ − 4111 if((pSettings->scrubTimerMode != SCRUB_TIMER_OFF) && (isLoopMode(pSettings->dive_mode)))
656
+ − 4112 {
+ − 4113 text[textpointer++] = TXT_ScrubTime;
+ − 4114
+ − 4115 }
38
+ − 4116 text[textpointer++] = '\017';
656
+ − 4117 text[textpointer++] = 0;
+ − 4118 if(!pSettings->FlipDisplay)
315
+ − 4119 {
+ − 4120 t7cY0free.WindowX0 += 10;
+ − 4121 t7cY0free.WindowY0 += 10;
+ − 4122 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4123 t7cY0free.WindowX0 -= 10;
+ − 4124 t7cY0free.WindowY0 -= 10;
+ − 4125 }
+ − 4126 else
+ − 4127 {
+ − 4128 t7cY0free.WindowY1 -= 10;
+ − 4129 t7cY0free.WindowX1 -= 10;
+ − 4130 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4131 t7cY0free.WindowY1 += 10;
+ − 4132 t7cY0free.WindowX1 += 10;
+ − 4133 }
38
+ − 4134 textpointer = 0;
+ − 4135 text[textpointer++] = '\t';
+ − 4136 textpointer += snprintf(&text[textpointer],10,"\020%01.2f", stateUsed->lifeData.ppO2);
+ − 4137 text[textpointer++] = '\n';
+ − 4138 text[textpointer++] = '\r';
+ − 4139 text[textpointer++] = '\t';
+ − 4140 if((pDecoinfoStandard->output_ceiling_meter > 99.9f) || (settingsGetPointer()->nonMetricalSystem))
215
+ − 4141 textpointer += snprintf(&text[textpointer],10,"\020%01.0f",unit_depth_float(pDecoinfoStandard->output_ceiling_meter));
38
+ − 4142 else
215
+ − 4143 textpointer += snprintf(&text[textpointer],10,"\020%01.1f",pDecoinfoStandard->output_ceiling_meter);
38
+ − 4144 text[textpointer++] = '\n';
+ − 4145 text[textpointer++] = '\r';
+ − 4146 text[textpointer++] = '\t';
247
+ − 4147 textpointer += snprintf(&text[textpointer],10,"\020%.0f\016\016%%\017", 100 * pDecoinfoStandard->super_saturation);
38
+ − 4148 text[textpointer++] = '\n';
+ − 4149 text[textpointer++] = '\r';
+ − 4150 text[textpointer++] = '\t';
+ − 4151 textpointer += snprintf(&text[textpointer],10,"\020%.0f\016\016%%\017",fCNS);
+ − 4152 text[textpointer++] = '\n';
+ − 4153 text[textpointer++] = '\r';
+ − 4154 text[textpointer++] = '\t';
214
+ − 4155 if (pDecoinfoFuture->output_time_to_surface_seconds < 1000 * 60)
+ − 4156 textpointer += snprintf(&text[textpointer],10,"\020%i'", (pDecoinfoFuture->output_time_to_surface_seconds + 59) / 60);
+ − 4157 else
+ − 4158 textpointer += snprintf(&text[textpointer],10,"\020%ih", (pDecoinfoFuture->output_time_to_surface_seconds + 59) / 3600);
656
+ − 4159
662
+ − 4160 if((pSettings->scrubTimerMode != SCRUB_TIMER_OFF) && (isLoopMode(pSettings->dive_mode)))
656
+ − 4161 {
+ − 4162 text[textpointer++] = '\n';
+ − 4163 text[textpointer++] = '\r';
+ − 4164 text[textpointer++] = '\t';
758
b6d8a6fbf4fd
- Colours for scrubber display when time remaining falls below a threshold value
heinrichsweikamp
diff
changeset
+ − 4165
b6d8a6fbf4fd
- Colours for scrubber display when time remaining falls below a threshold value
heinrichsweikamp
diff
changeset
+ − 4166 textpointer += printScrubberText(&text[textpointer], 10, pSettings);
656
+ − 4167 }
38
+ − 4168 text[textpointer++] = 0;
868
+ − 4169 Gfx_colorsscheme_mod(text, 0);
38
+ − 4170 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 4171 }
+ − 4172
+ − 4173 void t7_compass(uint16_t ActualHeading, uint16_t UserSetHeading)
+ − 4174 {
110
+ − 4175 uint16_t ActualHeadingRose;
38
+ − 4176 uint16_t LeftBorderHeading, LineHeading;
+ − 4177 uint32_t offsetPicture;
+ − 4178 point_t start, stop, center;
+ − 4179 static int32_t LastHeading = 0;
+ − 4180 int32_t newHeading = 0;
+ − 4181 int32_t diff = 0;
+ − 4182 int32_t diff2 = 0;
+ − 4183
+ − 4184 int32_t diffAbs = 0;
+ − 4185 int32_t diffAbs2 = 0;
+ − 4186
110
+ − 4187 SSettings* pSettings;
+ − 4188 pSettings = settingsGetPointer();
+ − 4189
38
+ − 4190 newHeading = ActualHeading;
+ − 4191
+ − 4192 diff = newHeading - LastHeading;
+ − 4193
+ − 4194 if(newHeading < LastHeading)
+ − 4195 diff2 = newHeading + 360 - LastHeading;
+ − 4196 else
+ − 4197 diff2 = newHeading - 360 - LastHeading;
+ − 4198
+ − 4199 diffAbs = diff;
+ − 4200 if(diffAbs < 0)
+ − 4201 diffAbs *= -1;
+ − 4202
+ − 4203 diffAbs2 = diff2;
+ − 4204 if(diffAbs2 < 0)
+ − 4205 diffAbs2 *= -1;
+ − 4206
+ − 4207
+ − 4208 if(diffAbs <= diffAbs2)
+ − 4209 newHeading = LastHeading + (diff / 2);
+ − 4210 else
+ − 4211 newHeading = LastHeading + (diff2 / 2);
+ − 4212
+ − 4213 if(newHeading < 0)
+ − 4214 newHeading += 360;
+ − 4215 else
+ − 4216 if(newHeading >= 360)
+ − 4217 newHeading -= 360;
+ − 4218
+ − 4219 LastHeading = newHeading;
+ − 4220 ActualHeading = newHeading;
110
+ − 4221 ActualHeadingRose = ActualHeading;
225
+ − 4222
110
+ − 4223 if(pSettings->FlipDisplay)
+ − 4224 {
+ − 4225 ActualHeadingRose = 360 - ActualHeadingRose;
+ − 4226 if (ActualHeadingRose < 170) ActualHeadingRose += 360;
+ − 4227 }
+ − 4228 else
+ − 4229 {
+ − 4230 if (ActualHeadingRose < 90) ActualHeadingRose += 360;
+ − 4231 ActualHeading = ActualHeadingRose;
+ − 4232 }
38
+ − 4233
+ − 4234 // new hw 160822
+ − 4235 // if (ActualHeading >= 360 + 90)
+ − 4236 // ActualHeading = 360;
+ − 4237
110
+ − 4238 LeftBorderHeading = 2 * (ActualHeadingRose - (CUSTOMBOX_SPACE_INSIDE/4));
+ − 4239
+ − 4240 if(pSettings->FlipDisplay) /* add offset caused by mirrowed drawing */
+ − 4241 {
+ − 4242 LeftBorderHeading += 2 * 80;
+ − 4243 }
38
+ − 4244
+ − 4245 offsetPicture = LeftBorderHeading * t7screenCompass.ImageHeight * 2;
+ − 4246
110
+ − 4247 /* the background is used to draw the rotating compass rose */
38
+ − 4248 background.pointer = t7screenCompass.FBStartAdress+offsetPicture;
+ − 4249 background.x0 = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
110
+ − 4250 if(!pSettings->FlipDisplay)
+ − 4251 {
+ − 4252 background.y0 = 65;
+ − 4253 }
+ − 4254 else
+ − 4255 {
+ − 4256 background.y0 = 480 - t7screenCompass.ImageHeight - 65;
+ − 4257 }
+ − 4258
38
+ − 4259 background.width = CUSTOMBOX_SPACE_INSIDE;
+ − 4260 background.height = t7screenCompass.ImageHeight;
+ − 4261
+ − 4262
+ − 4263 start.x = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + (CUSTOMBOX_SPACE_INSIDE/2);
+ − 4264 stop.x = start.x;
+ − 4265 start.y = 65;
+ − 4266 stop.y = start.y + 55;
+ − 4267 GFX_draw_line(&t7screen, start, stop, CLUT_Font030);
+ − 4268
+ − 4269
+ − 4270 center.x = start.x;
+ − 4271 center.y = 300;
+ − 4272
+ − 4273 stop.x = center.x + 44;
+ − 4274 stop.y = center.y + 24;
+ − 4275
+ − 4276
+ − 4277 while(ActualHeading > 359) ActualHeading -= 360;
+ − 4278
+ − 4279 LineHeading = 360 - ActualHeading;
+ − 4280 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(0,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font030); // North
+ − 4281 LineHeading += 90;
+ − 4282 if(LineHeading > 359) LineHeading -= 360;
+ − 4283 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031); // Maintick
+ − 4284 LineHeading += 90;
+ − 4285 if(LineHeading > 359) LineHeading -= 360;
+ − 4286 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4287 LineHeading += 90;
+ − 4288 if(LineHeading > 359) LineHeading -= 360;
+ − 4289 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4290
+ − 4291 LineHeading = 360 - ActualHeading;
+ − 4292 LineHeading += 45;
+ − 4293 if(LineHeading > 359) LineHeading -= 360;
+ − 4294 GFX_draw_thick_line(5,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031); // Subtick
+ − 4295 LineHeading += 90;
+ − 4296 if(LineHeading > 359) LineHeading -= 360;
+ − 4297 GFX_draw_thick_line(5,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4298 LineHeading += 90;
+ − 4299 if(LineHeading > 359) LineHeading -= 360;
+ − 4300 GFX_draw_thick_line(5,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4301 LineHeading += 90;
+ − 4302 if(LineHeading > 359) LineHeading -= 360;
+ − 4303 GFX_draw_thick_line(5,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4304
+ − 4305 LineHeading = 360 - ActualHeading;
+ − 4306 LineHeading += 22;
+ − 4307 if(LineHeading > 359) LineHeading -= 360;
+ − 4308 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031); // Subtick
+ − 4309 LineHeading += 45;
+ − 4310 if(LineHeading > 359) LineHeading -= 360;
+ − 4311 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4312 LineHeading += 45;
+ − 4313 if(LineHeading > 359) LineHeading -= 360;
+ − 4314 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4315 LineHeading += 45;
+ − 4316 if(LineHeading > 359) LineHeading -= 360;
+ − 4317 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4318 LineHeading += 45;
+ − 4319 if(LineHeading > 359) LineHeading -= 360;
+ − 4320 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031); // Subtick
+ − 4321 LineHeading += 45;
+ − 4322 if(LineHeading > 359) LineHeading -= 360;
+ − 4323 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4324 LineHeading += 45;
+ − 4325 if(LineHeading > 359) LineHeading -= 360;
+ − 4326 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4327 LineHeading += 45;
+ − 4328 if(LineHeading > 359) LineHeading -= 360;
+ − 4329 GFX_draw_thick_line(3,&t7screen, t7_compass_circle(1,LineHeading), t7_compass_circle(2,LineHeading), CLUT_Font031);
+ − 4330
+ − 4331 if(UserSetHeading)
+ − 4332 {
+ − 4333 LineHeading = UserSetHeading + 360 - ActualHeading;
+ − 4334 if(LineHeading > 359) LineHeading -= 360;
+ − 4335 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(3,LineHeading), t7_compass_circle(2,LineHeading), CLUT_CompassUserHeadingTick);
+ − 4336
+ − 4337 // R�ckpeilung, User Back Heading
+ − 4338 LineHeading = UserSetHeading + 360 + 180 - ActualHeading;
+ − 4339 if(LineHeading > 359) LineHeading -= 360;
+ − 4340 if(LineHeading > 359) LineHeading -= 360;
+ − 4341 GFX_draw_thick_line(9,&t7screen, t7_compass_circle(3,LineHeading), t7_compass_circle(2,LineHeading), CLUT_CompassUserBackHeadingTick);
+ − 4342 }
+ − 4343
+ − 4344 center.x = start.x;
+ − 4345 center.y = 250;
+ − 4346 GFX_draw_circle(&t7screen, center, 116, CLUT_Font030);
+ − 4347 GFX_draw_circle(&t7screen, center, 118, CLUT_Font030);
+ − 4348 GFX_draw_circle(&t7screen, center, 117, CLUT_Font030);
+ − 4349
+ − 4350
+ − 4351 }
+ − 4352
+ − 4353
+ − 4354 /* Font_T42: N is 27 px, S is 20 px, W is 36 px, E is 23 px
+ − 4355 * max is NW with 63 px
+ − 4356 * Font_T24: N is 15 px, S is 12 px, W is 20 px, E is 13 px
+ − 4357 * max is NW with 35 px
+ − 4358 * NE is 28 px
+ − 4359 * SW is 32 px
+ − 4360 * SE is 25 px
+ − 4361 * space between each is 45 px * 2
+ − 4362 * FirstItem List
+ − 4363 * \177 \177 prepare for size
+ − 4364 */
+ − 4365 void init_t7_compass(void)
+ − 4366 {
+ − 4367 t7screenCompass.FBStartAdress = getFrame(21);
+ − 4368
+ − 4369 char text[256];
+ − 4370 uint8_t textpointer = 0;
+ − 4371
+ − 4372 text[textpointer++] = '\030';
+ − 4373 text[textpointer++] = '\177';
+ − 4374 text[textpointer++] = '\177';
+ − 4375 text[textpointer++] = 76; // 90 - 14
+ − 4376 text[textpointer++] = '\016';
+ − 4377 text[textpointer++] = '\016';
+ − 4378 text[textpointer++] = 'N';
+ − 4379 text[textpointer++] = 'E'; // 96 + 28 = 124 total
+ − 4380 text[textpointer++] = '\017';
+ − 4381 text[textpointer++] = '\177';
+ − 4382 text[textpointer++] = '\177';
+ − 4383 text[textpointer++] = 64; // 90 - 14 - 12
+ − 4384 text[textpointer++] = 'E'; // 124 + 74 + 23 = 221 total
+ − 4385 text[textpointer++] = '\177';
+ − 4386 text[textpointer++] = '\177';
+ − 4387 text[textpointer++] = 66; // 90 - 11 - 13
+ − 4388 text[textpointer++] = '\016';
+ − 4389 text[textpointer++] = '\016';
+ − 4390 text[textpointer++] = 'S';
+ − 4391 text[textpointer++] = 'E';
+ − 4392 text[textpointer++] = '\017';
+ − 4393 text[textpointer++] = '\177';
+ − 4394 text[textpointer++] = '\177';
+ − 4395 text[textpointer++] = 68; // 90 - 12 - 10
+ − 4396 text[textpointer++] = 'S';
+ − 4397 text[textpointer++] = '\177';
+ − 4398 text[textpointer++] = '\177';
+ − 4399 text[textpointer++] = 64; // 90 - 10 - 16
+ − 4400 text[textpointer++] = '\016';
+ − 4401 text[textpointer++] = '\016';
+ − 4402 text[textpointer++] = 'S';
+ − 4403 text[textpointer++] = 'W';
+ − 4404 text[textpointer++] = '\017';
+ − 4405 text[textpointer++] = '\177';
+ − 4406 text[textpointer++] = '\177';
+ − 4407 text[textpointer++] = 56; // 90 - 16 - 18
+ − 4408 text[textpointer++] = 'W';
+ − 4409 text[textpointer++] = '\177';
+ − 4410 text[textpointer++] = '\177';
+ − 4411 text[textpointer++] = 54; // 90 - 18 - 18
+ − 4412 text[textpointer++] = '\016';
+ − 4413 text[textpointer++] = '\016';
+ − 4414 text[textpointer++] = 'N';
+ − 4415 text[textpointer++] = 'W';
+ − 4416 text[textpointer++] = '\017';
+ − 4417 text[textpointer++] = '\177';
+ − 4418 text[textpointer++] = '\177';
+ − 4419 text[textpointer++] = 59; // 90 - 17 - 14
+ − 4420 text[textpointer++] = 'N';
+ − 4421 text[textpointer++] = '\177';
+ − 4422 text[textpointer++] = '\177';
+ − 4423 text[textpointer++] = 63; // 90 - 13 - 14
+ − 4424 text[textpointer++] = '\016';
+ − 4425 text[textpointer++] = '\016';
+ − 4426 text[textpointer++] = 'N';
+ − 4427 text[textpointer++] = 'E';
+ − 4428 text[textpointer++] = '\017';
+ − 4429 text[textpointer++] = '\177';
+ − 4430 text[textpointer++] = '\177';
+ − 4431 text[textpointer++] = 64; // 90 - 14 - 12
+ − 4432 text[textpointer++] = 'E';
+ − 4433 text[textpointer++] = '\177';
+ − 4434 text[textpointer++] = '\177';
+ − 4435 text[textpointer++] = 66; // 90 - 11 - 13
+ − 4436 text[textpointer++] = '\016';
+ − 4437 text[textpointer++] = '\016';
+ − 4438 text[textpointer++] = 'S';
+ − 4439 text[textpointer++] = 'E';
+ − 4440 text[textpointer++] = '\017';
+ − 4441 text[textpointer++] = '\177';
+ − 4442 text[textpointer++] = '\177';
+ − 4443 text[textpointer++] = 68; // 90 - 12 - 10
+ − 4444 text[textpointer++] = 'S';
+ − 4445 text[textpointer++] = '\177';
+ − 4446 text[textpointer++] = '\177';
+ − 4447 text[textpointer++] = 64; // 90 - 10 - 16
+ − 4448 text[textpointer++] = '\016';
+ − 4449 text[textpointer++] = '\016';
+ − 4450 text[textpointer++] = 'S';
+ − 4451 text[textpointer++] = 'W';
+ − 4452 text[textpointer++] = '\017';
+ − 4453 text[textpointer++] = 0; // end
+ − 4454
+ − 4455 GFX_write_string(&FontT42,&t7pCompass,text,1);
+ − 4456
+ − 4457 releaseAllFramesExcept(21,t7screenCompass.FBStartAdress);
+ − 4458 }
+ − 4459
+ − 4460
+ − 4461 void t7_miniLiveLogProfile(void)
+ − 4462 {
+ − 4463 SWindowGimpStyle wintemp;
110
+ − 4464 SSettings* pSettings;
+ − 4465 pSettings = settingsGetPointer();
+ − 4466
38
+ − 4467 wintemp.left = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET;
+ − 4468 wintemp.right = wintemp.left + CUSTOMBOX_SPACE_INSIDE;
110
+ − 4469 if(!pSettings->FlipDisplay)
+ − 4470 {
+ − 4471 wintemp.top = 480 - t7l1.WindowY0;
+ − 4472 wintemp.bottom = wintemp. top + 200;
+ − 4473 }
+ − 4474 else
+ − 4475 {
+ − 4476 wintemp.top = t7l1.WindowY1;
+ − 4477 wintemp.bottom = wintemp. top + 200;
+ − 4478 }
38
+ − 4479
+ − 4480 uint16_t max_depth = (uint16_t)(stateUsed->lifeData.max_depth_meter * 10);
+ − 4481
+ − 4482 GFX_graph_print(&t7screen, &wintemp, 0,1,0, max_depth, getMiniLiveLogbookPointerToData(), getMiniLiveLogbookActualDataLength(), CLUT_Font030, NULL);
+ − 4483 }
+ − 4484
+ − 4485 void t7_logo_OSTC(void)
+ − 4486 {
+ − 4487 SWindowGimpStyle windowGimp;
110
+ − 4488 SSettings* pSettings;
+ − 4489 pSettings = settingsGetPointer();
+ − 4490
38
+ − 4491 /* OSTC logo */
110
+ − 4492 if(!pSettings->FlipDisplay)
+ − 4493 {
+ − 4494 windowGimp.left = t7l1.WindowX1 + 32;
+ − 4495 }
+ − 4496 else
+ − 4497 {
+ − 4498 windowGimp.left = t7r1.WindowX1 + 32;
+ − 4499 }
+ − 4500
38
+ − 4501 windowGimp.top = 40 + 32;
+ − 4502 GFX_draw_image_monochrome(&t7screen, windowGimp, &ImgOSTC, 0);
+ − 4503 }
672
+ − 4504
+ − 4505 static uint16_t ChargerLog[60] = {10,10,10,10,10,10,10,10,10,10,
+ − 4506 10,10,10,10,10,10,10,10,10,10,
+ − 4507 10,10,10,10,10,10,10,10,10,10,
+ − 4508 10,10,10,10,10,10,10,10,10,10,
+ − 4509 10,10,10,10,10,10,10,10,10,10,
+ − 4510 10,10,10,10,10,10,10,10,10,10};
+ − 4511
+ − 4512 uint16_t LogDeltaCharge(float charge)
+ − 4513 {
+ − 4514 static uint8_t curIndex = 0;
+ − 4515 static float averageSpeed = 0.0;
+ − 4516 uint16_t level = 0;
+ − 4517 uint16_t completeSec = 0;
+ − 4518
+ − 4519 if(charge > 0.003)
+ − 4520 {
+ − 4521 level = 2;
+ − 4522 }
+ − 4523 else if(charge > 0.0025)
+ − 4524 {
+ − 4525 level = 3;
+ − 4526 }
+ − 4527 else if(charge > 0.002)
+ − 4528 {
+ − 4529 level = 4;
+ − 4530 }
+ − 4531 else if(charge > 0.0015)
+ − 4532 {
+ − 4533 level = 5;
+ − 4534 }
+ − 4535 else if(charge > 0.001)
+ − 4536 {
+ − 4537 level = 6;
+ − 4538 }
+ − 4539 else if(charge > 0.0005)
+ − 4540 {
+ − 4541 level = 7;
+ − 4542 }
+ − 4543 else if(charge > 0.00)
+ − 4544 {
+ − 4545 level = 8;
+ − 4546 }
+ − 4547 else
+ − 4548 {
+ − 4549 level = 10;
+ − 4550 }
859
+ − 4551 if(curIndex > 1)
+ − 4552 {
+ − 4553 level = (level + ChargerLog[curIndex - 1]) / 2; /* smooth small jumps */
+ − 4554 }
672
+ − 4555 if(curIndex < 59)
+ − 4556 {
+ − 4557 ChargerLog[curIndex++] = level;
+ − 4558 }
+ − 4559 else
+ − 4560 {
+ − 4561 memcpy (&ChargerLog[0],&ChargerLog[1],sizeof(ChargerLog) - 1);
+ − 4562 ChargerLog[curIndex] = level;
+ − 4563 }
859
+ − 4564 if(curIndex > 1) /* estimate time til charging is complete */
672
+ − 4565 {
+ − 4566 averageSpeed = ((averageSpeed * (curIndex-1)) + charge) / curIndex;
+ − 4567 completeSec = (100.0 - stateUsed->lifeData.battery_charge) / averageSpeed;
+ − 4568 }
+ − 4569 else
+ − 4570 {
+ − 4571 completeSec = 0xffff;
+ − 4572 }
+ − 4573 return completeSec;
+ − 4574 }
+ − 4575
+ − 4576 uint16_t* getChargeLog()
+ − 4577 {
+ − 4578 return ChargerLog;
+ − 4579 }
+ − 4580
+ − 4581 void t7_ChargerView(void)
+ − 4582 {
+ − 4583 static float lastCharge = 0.0;
+ − 4584 float localCharge = 0.0;
+ − 4585 static uint32_t lastTick = 0;
+ − 4586 uint32_t curTick = 0;
+ − 4587 static float speed = 0.0;
+ − 4588 float deltatime = 0.0;
+ − 4589
+ − 4590 char text[256+50];
+ − 4591 uint8_t textpointer = 0;
+ − 4592 static uint16_t remainingSec = 0;
+ − 4593 uint16_t hoursto100 = 0;
+ − 4594 char indicator = '~';
+ − 4595
+ − 4596 point_t start, stop;
+ − 4597
675
+ − 4598 SWindowGimpStyle wintemp;
+ − 4599 SSettings* pSettings;
+ − 4600 pSettings = settingsGetPointer();
+ − 4601
672
+ − 4602 t7cY0free.WindowLineSpacing = 28 + 48 + 14;
+ − 4603 t7cY0free.WindowY0 = t7cH.WindowY0 - 5 - 2 * t7cY0free.WindowLineSpacing;
+ − 4604 t7cY0free.WindowNumberOfTextLines = 3;
+ − 4605
675
+ − 4606
+ − 4607 if(pSettings->FlipDisplay)
+ − 4608 {
+ − 4609 t7cY0free.WindowY0 = t7cH.WindowY0 + 15;
+ − 4610 t7cY0free.WindowY1 = t7cY0free.WindowY0 + 250;
+ − 4611 }
+ − 4612
672
+ − 4613 localCharge = stateUsed->lifeData.battery_charge;
+ − 4614 if(localCharge < 0.0)
+ − 4615 {
+ − 4616 localCharge *= -1.0;
+ − 4617 }
+ − 4618
+ − 4619 if(stateUsed->chargeStatus != CHARGER_off)
+ − 4620 {
859
+ − 4621 curTick = HAL_GetTick();
+ − 4622 deltatime = (curTick - lastTick);
+ − 4623
+ − 4624 if((deltatime > 3000) || (lastCharge != localCharge)) /* Charge value update is expected every 2 second. */
+ − 4625 { /* Added timeout to keep graph moving in case charger is temporary idle */
+ − 4626 if(lastCharge != localCharge)
672
+ − 4627 {
859
+ − 4628 if(lastCharge < localCharge)
+ − 4629 {
+ − 4630 speed = (localCharge - lastCharge) * 1000.0 / deltatime;
+ − 4631 }
+ − 4632
+ − 4633 if(localCharge > 100.0)
+ − 4634 {
+ − 4635 localCharge = 100.0;
+ − 4636 }
+ − 4637 lastCharge = localCharge;
672
+ − 4638 }
+ − 4639 deltatime = 0;
+ − 4640 remainingSec = LogDeltaCharge(speed);
+ − 4641 speed = 0;
859
+ − 4642 lastTick = curTick;
672
+ − 4643 }
+ − 4644 }
+ − 4645 textpointer += snprintf(&text[textpointer],50,"\n\r");
+ − 4646 textpointer += snprintf(&text[textpointer],50,"\001%c\n\r",TXT_ChargeHour);
+ − 4647
+ − 4648 GFX_write_string(&FontT24, &t7cY0free, text, 1);
+ − 4649
+ − 4650 hoursto100 = remainingSec / 3600; /* reduce to hours */
+ − 4651 if(hoursto100 < 1)
+ − 4652 {
+ − 4653 indicator = '<';
+ − 4654 hoursto100 = 1;
+ − 4655 }
675
+ − 4656
+ − 4657 if(!pSettings->FlipDisplay)
+ − 4658 {
+ − 4659 t7cY0free.WindowY0 -= 52;
+ − 4660 }
+ − 4661 else
+ − 4662 {
+ − 4663 t7cY0free.WindowY1 += 52;
+ − 4664 }
672
+ − 4665
+ − 4666 if((stateUsed->lifeData.battery_charge > 0) && (stateUsed->chargeStatus != CHARGER_off))
+ − 4667 {
+ − 4668 snprintf(text,60,
693
+ − 4669 "\001%0.2f\016\016%%\017\n\r"
672
+ − 4670 "\001%c%d\n\r"
+ − 4671 ,stateUsed->lifeData.battery_charge
+ − 4672 ,indicator
+ − 4673 ,hoursto100);
+ − 4674 }
+ − 4675 else
+ − 4676 {
+ − 4677 snprintf(text,60,
+ − 4678 "\001---\n\r"
+ − 4679 "\001---\n\r");
+ − 4680 }
+ − 4681 GFX_write_string(&FontT42, &t7cY0free, text, 1);
+ − 4682
+ − 4683 wintemp.left = CUSTOMBOX_LINE_LEFT + CUSTOMBOX_INSIDE_OFFSET + 50;
+ − 4684 wintemp.right = wintemp.left + CUSTOMBOX_SPACE_INSIDE - 100;
+ − 4685
+ − 4686
+ − 4687 if(!pSettings->FlipDisplay)
+ − 4688 {
+ − 4689 wintemp.top = 480 - t7l1.WindowY0 + 115;
+ − 4690 wintemp.bottom = wintemp.top + 100;
+ − 4691 }
+ − 4692 else
+ − 4693 {
675
+ − 4694 wintemp.top = t7l1.WindowY1 + 102;
+ − 4695 wintemp.bottom = wintemp.top + 100;
672
+ − 4696 }
+ − 4697
+ − 4698 start.x = wintemp.left-5;
+ − 4699 start.y = 90;
+ − 4700
+ − 4701 stop.x = wintemp.right + 5 - start.x;
+ − 4702 stop.y = 100;
+ − 4703 GFX_draw_box(&t7screen, start, stop,1, CLUT_Font020);
+ − 4704
+ − 4705 if(stateUsed->chargeStatus != CHARGER_off)
+ − 4706 {
+ − 4707 GFX_graph_print(&t7screen, &wintemp, 1,1,0, 10, getChargeLog(), 60, CLUT_Font030, NULL);
+ − 4708 }
+ − 4709 else
+ − 4710 {
+ − 4711 GFX_graph_print(&t7screen, &wintemp, 1,1,0, 10, getChargeLog(), 60, CLUT_Font031, NULL);
+ − 4712 }
+ − 4713
+ − 4714 }
777
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 4715
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4716
777
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 4717 bool t7_isCompassShowing(void)
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 4718 {
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 4719 return selection_customview == CVIEW_Compass || selection_custom_field == LLC_Compass;
6a8cf91e5b22
This is only showing if one of the compass views is visible. It should make it possible to verify that a correct heading is set as the user can see the compass readout when pushing the button. (mikeller)
heinrichsweikamp
diff
changeset
+ − 4720 }
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4721
882
+ − 4722 void t7_drawAcentGraph(uint8_t color)
+ − 4723 {
+ − 4724 point_t start, stop;
+ − 4725
+ − 4726 SSettings* pSettings;
+ − 4727 pSettings = settingsGetPointer();
+ − 4728
+ − 4729
+ − 4730 if(!pSettings->FlipDisplay)
+ − 4731 {
+ − 4732 start.y = t7l1.WindowY0 - 1;
+ − 4733 }
+ − 4734 else
+ − 4735 {
+ − 4736 start.y = t7l3.WindowY0 - 25;
+ − 4737 }
+ − 4738
+ − 4739 for(int i = 0; i<4;i++)
+ − 4740 {
+ − 4741 start.y += 5*6;
+ − 4742 stop.y = start.y;
+ − 4743 start.x = CUSTOMBOX_LINE_LEFT - 1;
+ − 4744 stop.x = start.x - 17;
+ − 4745 GFX_draw_line(&t7screen, start, stop, 0);
+ − 4746 // start.x = CUSTOMBOX_LINE_RIGHT + 2; old right too
+ − 4747 // stop.x = start.x + 17;
+ − 4748 // GFX_draw_line(&t7screen, start, stop, 0);
+ − 4749 }
+ − 4750 // new thick bar design Sept. 2015
+ − 4751 start.x = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET - 3 - 5;
+ − 4752 stop.x = start.x;
+ − 4753 if(!pSettings->FlipDisplay)
+ − 4754 {
+ − 4755 start.y = t7l1.WindowY0 - 1;
+ − 4756 }
+ − 4757 else
+ − 4758 {
+ − 4759 start.y = t7l3.WindowY0 - 25;
+ − 4760 }
+ − 4761 stop.y = start.y + (uint16_t)(stateUsed->lifeData.ascent_rate_meter_per_min * 6);
+ − 4762 stop.y -= 3; // wegen der Liniendicke von 12 anstelle von 9
+ − 4763 if(stop.y >= 470)
+ − 4764 stop.y = 470;
+ − 4765 start.y += 7; // starte etwas weiter oben
+ − 4766 if(color == 0)
+ − 4767 {
+ − 4768 color = CLUT_EverythingOkayGreen; /* do not use white color for drawing graph */
+ − 4769 }
+ − 4770
+ − 4771 GFX_draw_thick_line(12,&t7screen, start, stop, color);
+ − 4772 }
+ − 4773
915
+ − 4774 #define ASCENT_GRAPH_YPIXEL 110
+ − 4775
882
+ − 4776
907
+ − 4777 uint8_t t7_drawSlowExitGraph() /* this function is only called if diver is below last last stop depth */
882
+ − 4778 {
+ − 4779 static SSlowExitState slowExitState = SE_END;
+ − 4780 static uint16_t countDownSec = 0;
+ − 4781 static uint8_t drawingMeterStep;
+ − 4782 static float exitDepthMeter = 0.0;
+ − 4783 static uint32_t exitSecTick = 0;
907
+ − 4784 static uint32_t lastSecTick = 0;
882
+ − 4785
+ − 4786 uint8_t index = 0;
+ − 4787 static uint8_t color = 0;
+ − 4788 point_t start, stop;
+ − 4789
+ − 4790 SSettings* pSettings;
+ − 4791 pSettings = settingsGetPointer();
+ − 4792
907
+ − 4793 if((stateUsed->lifeData.max_depth_meter < pSettings->last_stop_depth_meter) /* start of dive => reinit timer */
+ − 4794 || (slowExitState == SE_REINIT))
882
+ − 4795 {
+ − 4796 if(slowExitState != SE_INIT)
+ − 4797 {
+ − 4798 countDownSec = pSettings->slowExitTime * 60;
+ − 4799 drawingMeterStep = ASCENT_GRAPH_YPIXEL / pSettings->last_stop_depth_meter; /* based on 120 / 4 = 30 of standard ascent graph */
+ − 4800 slowExitState = SE_INIT;
+ − 4801 exitDepthMeter = pSettings->last_stop_depth_meter;
+ − 4802 color = 0;
+ − 4803 }
+ − 4804 }
+ − 4805 else
+ − 4806 {
+ − 4807 if(slowExitState != SE_END)
+ − 4808 {
892
+ − 4809 if((slowExitState == SE_INIT) && (stateUsed->lifeData.dive_time_seconds > 900)) /* min 15min divetime */
882
+ − 4810 {
+ − 4811 slowExitState = SE_ACTIVE;
+ − 4812 exitSecTick = HAL_GetTick();
907
+ − 4813 lastSecTick = exitSecTick;
882
+ − 4814 }
892
+ − 4815 else if(slowExitState == SE_ACTIVE)
882
+ − 4816 {
907
+ − 4817 if(time_elapsed_ms(lastSecTick, HAL_GetTick()) > 60000) /* restart timer if diver go below exit zone */
+ − 4818 {
+ − 4819 slowExitState = SE_REINIT;
+ − 4820 }
+ − 4821 else if(time_elapsed_ms(exitSecTick, HAL_GetTick()) > 1000)
882
+ − 4822 {
892
+ − 4823 exitSecTick = HAL_GetTick();
907
+ − 4824 lastSecTick = exitSecTick;
892
+ − 4825 /* select depth digit color */
+ − 4826 if(fabsf(stateUsed->lifeData.depth_meter - exitDepthMeter) < 0.5 )
+ − 4827 {
+ − 4828 color = CLUT_NiceGreen;
+ − 4829 }
+ − 4830 else if(fabsf(stateUsed->lifeData.depth_meter - exitDepthMeter) <= 1.5)
+ − 4831 {
+ − 4832 color = CLUT_WarningYellow;
+ − 4833 }
+ − 4834 else if(stateUsed->lifeData.depth_meter - exitDepthMeter < -1.5 )
+ − 4835 {
+ − 4836 color = CLUT_WarningRed;
+ − 4837 }
+ − 4838 else
+ − 4839 {
+ − 4840 color = 0;
+ − 4841 }
+ − 4842
+ − 4843 if((fabsf(stateUsed->lifeData.depth_meter - exitDepthMeter) <= 1.6 ) /* only decrease counter if diver is close to target depth */
+ − 4844 || (color == CLUT_WarningRed)) /* or if diver is far ahead */
+ − 4845 {
+ − 4846 countDownSec--;
+ − 4847 if(countDownSec == 0)
+ − 4848 {
+ − 4849 slowExitState = SE_END;
+ − 4850 color = 0;
907
+ − 4851 exitDepthMeter = 0;
892
+ − 4852 }
907
+ − 4853 else
+ − 4854 {
+ − 4855 exitDepthMeter -= (pSettings->last_stop_depth_meter / (float)(pSettings->slowExitTime * 60));
+ − 4856 }
892
+ − 4857 }
882
+ − 4858 }
892
+ − 4859 if(!pSettings->FlipDisplay)
882
+ − 4860 {
892
+ − 4861 start.y = t7l1.WindowY0 - 1;
882
+ − 4862 }
+ − 4863 else
+ − 4864 {
892
+ − 4865 start.y = t7l3.WindowY0 - 25;
882
+ − 4866 }
+ − 4867
892
+ − 4868 for(index = 0; index < pSettings->last_stop_depth_meter; index++) /* draw meter indicators */
882
+ − 4869 {
892
+ − 4870 start.y += drawingMeterStep;
+ − 4871 stop.y = start.y;
+ − 4872 start.x = CUSTOMBOX_LINE_LEFT - 1;
915
+ − 4873 stop.x = start.x - 38;
892
+ − 4874 GFX_draw_line(&t7screen, start, stop, 0);
882
+ − 4875 }
892
+ − 4876
+ − 4877 start.x = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET - 20;
+ − 4878 stop.x = start.x;
+ − 4879 if(!pSettings->FlipDisplay)
+ − 4880 {
915
+ − 4881 start.y = t7l1.WindowY0 + ASCENT_GRAPH_YPIXEL + 5;
892
+ − 4882 }
+ − 4883 else
+ − 4884 {
915
+ − 4885 start.y = t7l3.WindowY0 - 25 + ASCENT_GRAPH_YPIXEL + 5;
892
+ − 4886 }
+ − 4887 stop.y = start.y - countDownSec * (ASCENT_GRAPH_YPIXEL / (float)(pSettings->slowExitTime * 60.0));
+ − 4888 if(stop.y >= 470)
+ − 4889 stop.y = 470;
+ − 4890
915
+ − 4891 if(!pSettings->FlipDisplay)
+ − 4892 {
+ − 4893 stop.y += 5;
+ − 4894 }
892
+ − 4895 GFX_draw_thick_line(15,&t7screen, start, stop, 3);
+ − 4896 /* mark diver depth */
915
+ − 4897 start.x = CUSTOMBOX_LINE_LEFT - CUSTOMBOX_OUTSIDE_OFFSET - 30;
+ − 4898 stop.x = start.x + 24;
+ − 4899
+ − 4900 start.y = start.y - (stateUsed->lifeData.depth_meter * (ASCENT_GRAPH_YPIXEL) / pSettings->last_stop_depth_meter);
882
+ − 4901 stop.y = start.y;
892
+ − 4902 GFX_draw_thick_line(10,&t7screen, start, stop, 9);
882
+ − 4903 }
+ − 4904 }
+ − 4905 }
+ − 4906 return color;
+ − 4907 }
805
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4908 void t7_tick(void)
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4909 {
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4910 SSettings *settings = settingsGetPointer();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4911
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4912 int nowS = current_second();
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4913 updateTimer(settings, nowS, false);
dd7ce655db26
Adds a simple countdown timer, available as a custom view in surface and dive mode.
heinrichsweikamp
diff
changeset
+ − 4914 }