38
+ − 1 ///////////////////////////////////////////////////////////////////////////////
+ − 2 /// -*- coding: UTF-8 -*-
+ − 3 ///
+ − 4 /// \file Discovery/Src/show_logbook.c
+ − 5 /// \brief show_logbook_logbook_show_log_page1 /
+ − 6 /// \author Heinrichs Weikamp gmbh
+ − 7 /// \date 07-July-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 #include "base.h"
+ − 30 #include "logbook.h"
+ − 31 #include "gfx_colors.h"
+ − 32 #include "gfx_engine.h"
+ − 33 #include "gfx_fonts.h"
+ − 34 #include "show_logbook.h"
+ − 35 #include "unit.h"
454
+ − 36 #include "configuration.h"
596
+ − 37 #include "logbook_miniLive.h"
662
+ − 38 #include "text_multilanguage.h"
38
+ − 39
+ − 40 #include <stdint.h>
+ − 41 #include <stdio.h>
+ − 42 #include <stdlib.h> // for abs()
+ − 43
484
+ − 44 #define LOG_BORDER_OFFSET (50u) /* text offset from left / right display to text start/end */
+ − 45
38
+ − 46 /* Private variables ---------------------------------------------------------*/
+ − 47
186
+ − 48 static GFX_DrawCfgScreen tLOGscreen;
+ − 49 static GFX_DrawCfgScreen tLOGbackground;
38
+ − 50
+ − 51
186
+ − 52 static void print_gas_name(char* output,uint8_t lengh,uint8_t oxygen,uint8_t helium);
+ − 53 static int16_t get_colour(int16_t color);
38
+ − 54
596
+ − 55 static uint8_t active_log_page = 1;
+ − 56 static uint8_t active_log_offset = 0;
+ − 57
38
+ − 58 /* Overview */
186
+ − 59 static void show_logbook_logbook_show_log_page1(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards);
38
+ − 60 /* Temperature */
186
+ − 61 static void show_logbook_logbook_show_log_page2(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards);
38
+ − 62 /* Gas List */
186
+ − 63 static void show_logbook_logbook_show_log_page3(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards);
38
+ − 64 /* ppO2 */
186
+ − 65 static void show_logbook_logbook_show_log_page4(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards);
38
+ − 66
186
+ − 67 static inline uint32_t MaxU32LOG(uint32_t a, uint32_t b)
38
+ − 68 {
+ − 69 return((a>b)?a:b);
+ − 70 }
+ − 71
+ − 72 /**
+ − 73 ******************************************************************************
+ − 74 * @brief GFX write label. / print coordinate system & depth graph
763
+ − 75 * @author heinrichs weikamp gmbh
38
+ − 76 * @version V0.0.1
+ − 77 * @date 07-July-2014
+ − 78 ******************************************************************************
+ − 79 *
+ − 80 * @param hgfx:
+ − 81 * @param window: WindowGimpStyle
+ − 82 * @param mode: different modes depending witch page uses the function
+ − 83 * @param dataLength:
+ − 84 * @param depthdata:
+ − 85 * @param colordata: 1
+ − 86 * @retval None
+ − 87 */
186
+ − 88 static void show_logbook_draw_depth_graph(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards, SWindowGimpStyle* window, short mode, uint16_t dataLength, uint16_t* depthdata, uint8_t * colordata, uint16_t * decostopdata)
38
+ − 89 {
+ − 90 SLogbookHeader logbookHeader;
+ − 91 SWindowGimpStyle wintemp = *window;
+ − 92 SWindowGimpStyle winsmal;
+ − 93 logbook_getHeader(StepBackwards, &logbookHeader);
+ − 94 int divetime = logbookHeader.diveTimeMinutes;
+ − 95 int maxDepth = logbookHeader.maxDepth/100;
+ − 96
+ − 97 int16_t saveBottom = wintemp.bottom;
+ − 98 int16_t saveTop = 0 - wintemp.top;
+ − 99
+ − 100 //*** Horisontal (depth) ***************************************************
+ − 101
+ − 102 //--- calc depth lines and labels --
+ − 103 int vscale = 0;
+ − 104 int vstep = 0;
+ − 105
+ − 106 vstep = maxDepth / 5;
+ − 107 vscale = vstep * 5;
+ − 108 if(vscale < maxDepth)
+ − 109 {
+ − 110 vstep += 1;
+ − 111 vscale += 5;
+ − 112 }
+ − 113 /*
+ − 114 if(vscale <
+ − 115 for(int i=1; i <= 20; i++)
+ − 116 {
+ − 117 vscale = i * 25;
+ − 118 vstep = i * 5;
+ − 119 if( vscale > maxDepth)
+ − 120 break;
+ − 121 }
+ − 122 */
+ − 123 //--- print depth labels ---
+ − 124 winsmal.left = wintemp.left - 48;
+ − 125 winsmal.top = wintemp.top - 3;
+ − 126 winsmal.right = wintemp.left -1;
+ − 127 winsmal.bottom = winsmal.top + 16;
+ − 128
567
+ − 129 if(settingsGetPointer()->nonMetricalSystem)
+ − 130 {
+ − 131 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor1,"[ft]");
+ − 132 }
+ − 133 else
+ − 134 {
+ − 135 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor1,"[m]");
+ − 136 }
110
+ − 137
+ − 138 // winsmal.left = wintemp.left - 48;
632
+ − 139 char msg[10];
38
+ − 140 float deltaline = ((float)(wintemp.bottom - wintemp.top))/5;
+ − 141 for(int i = 1; i<=5; i++)
+ − 142 {
+ − 143 winsmal.top = wintemp.top + deltaline * i - 14;
+ − 144 winsmal.bottom = winsmal.top + 16;
110
+ − 145
+ − 146 // winsmal.right = wintemp.left - 2;
632
+ − 147 snprintf(msg,10,"%i",unit_depth_integer(i * vstep));
110
+ − 148 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor1,msg);
38
+ − 149 }
+ − 150
+ − 151 //vertical (Time) *******************************************************************
+ − 152 //--- calc time lines and labels --
+ − 153 int timestep = 0;
+ − 154 int lines = 0;
+ − 155 for(int i=1; i <= 60; i++)
+ − 156 {
+ − 157 timestep = i * 5;
+ − 158 lines = divetime/timestep;
+ − 159 if(lines < 7)
+ − 160 {
+ − 161 break;
+ − 162 }
+ − 163 }
+ − 164 //*** print coordinate system grit ***
+ − 165 int winwidth = wintemp.right - wintemp.left;
+ − 166 float vdeltaline = ((float)(winwidth * timestep))/divetime;
+ − 167 GFX_draw_Grid( &tLOGbackground,wintemp, 0, vdeltaline, 5,0, CLUT_LogbookGrid);
+ − 168
+ − 169
+ − 170 //--- print time labels ---
+ − 171 winsmal.left = wintemp.left;
+ − 172 winsmal.top = wintemp.top - 40;
+ − 173 winsmal.right = winsmal.left + 60;
+ − 174 winsmal.bottom = winsmal.top + 16;
+ − 175
110
+ − 176 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor1,"min");
38
+ − 177 for(int i = 1; i<=lines; i++)
+ − 178 {
+ − 179 winsmal.left= wintemp.left + vdeltaline * i - 15;
+ − 180 winsmal.right = winsmal.left + 30;
632
+ − 181 snprintf(msg,10,"%3i",i * timestep);
110
+ − 182 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor1,msg);
38
+ − 183 }
+ − 184 winsmal.left = wintemp.left;// - 9;
+ − 185 winsmal.top = wintemp.top - 40;
+ − 186 winsmal.right = winsmal.left + 60;
+ − 187
+ − 188 //--- print depth graph ---
+ − 189 //adapt window
+ − 190 int winhight = wintemp.bottom - wintemp.top;
+ − 191 int newhight = (winhight * maxDepth)/vscale;
+ − 192 wintemp.bottom = wintemp.top + newhight;
+ − 193 //wintemp.fontcolor = LOGBOOK_GRAPH_DEPTH;
+ − 194
+ − 195 int datamax = 0;
+ − 196 for(int i=0;i<dataLength;i++)
+ − 197 {
+ − 198 if(depthdata[i]>datamax)
+ − 199 datamax = depthdata[i];
+ − 200 }
+ − 201
+ − 202 if(decostopdata)
+ − 203 {
+ − 204 if(dataLength <= 1000)
+ − 205 {
+ − 206 uint8_t colortemp[1000];
+ − 207
+ − 208 for(int i = 0; i<dataLength; i++)
+ − 209 {
+ − 210 if(decostopdata[i] > depthdata[i])
+ − 211 {
+ − 212 colortemp[i] = CLUT_WarningRed;
+ − 213 }
+ − 214 else
+ − 215 {
+ − 216 colortemp[i] = CLUT_NiceGreen;
+ − 217 }
+ − 218 }
166
+ − 219 GFX_graph_print(hgfx,&wintemp,saveTop,1,0,datamax, decostopdata,dataLength, 0, colortemp);
38
+ − 220 }
+ − 221 else
+ − 222 GFX_graph_print(hgfx,&wintemp,saveTop,1,0,datamax, decostopdata,dataLength, CLUT_NiceGreen, NULL);
+ − 223 }
+ − 224
110
+ − 225 if(settingsGetPointer()->FlipDisplay)
+ − 226 {
+ − 227 winsmal.right = 800 - wintemp.left;
+ − 228 winsmal.left = 800 - wintemp.right;
+ − 229 winsmal.bottom = wintemp.bottom;
+ − 230 winsmal.top = wintemp.top;
+ − 231 }
+ − 232 else
+ − 233 {
+ − 234 winsmal.right = wintemp.right;
+ − 235 winsmal.left = wintemp.left;
+ − 236 winsmal.bottom = wintemp.bottom;
+ − 237 winsmal.top = wintemp.top;
+ − 238 }
+ − 239
38
+ − 240 switch(mode)
+ − 241 {
+ − 242 case 0:
110
+ − 243 GFX_graph_print(hgfx,&winsmal,0,1,0,datamax, depthdata,dataLength,CLUT_GasSensor1, NULL);
38
+ − 244 break;
+ − 245 case 1:
110
+ − 246 GFX_graph_print(hgfx,&winsmal,saveBottom,1,0,datamax, depthdata,dataLength,CLUT_GasSensor0,colordata);
38
+ − 247 break;
+ − 248 case 2:
+ − 249 if(*colordata)
110
+ − 250 GFX_graph_print(hgfx,&winsmal,0,1,0,datamax, depthdata,dataLength,CLUT_GasSensor0,colordata);
38
+ − 251 else
110
+ − 252 GFX_graph_print(hgfx,&winsmal,0,1,0,datamax, depthdata,dataLength,CLUT_GasSensor1, NULL);
38
+ − 253 }
+ − 254 }
+ − 255
+ − 256
+ − 257
+ − 258 /**
+ − 259 ******************************************************************************
+ − 260 * @brief scaleAdapt
+ − 261 * @author heinrichs weikamp gmbh
+ − 262 * @version V0.0.1
+ − 263 * @date 29-Nov-2016
+ − 264 ******************************************************************************
+ − 265 *
+ − 266 * @param ...
+ − 267 * @retval *OutputStepOfScale, *OutputMaxValueOnScale, *OutputTop, *OutputBottom
+ − 268
+ − 269 * fit to multiples of 1�C (data format is 1/10�C)
+ − 270 */
+ − 271
186
+ − 272 static void scaleAdapt( int InputTop, int InputBottom,
38
+ − 273 int16_t *OutputMinValue, int16_t *OutputMaxValue, int *OutputTop, int *OutputBottom,
+ − 274 uint16_t *OutputStepOfScale, int16_t *OutputMaxValueOnScale)
+ − 275 {
+ − 276 // uint16_t oldScale;
+ − 277 uint16_t newScale;
+ − 278 // uint16_t diff_newScale;
+ − 279
+ − 280 // int16_t oldMaxOnScale;
+ − 281 int16_t newMaxOnScale;
+ − 282 // int16_t diff_newMaxOnScale;
+ − 283 _Bool negativeMaxValue = 0;
+ − 284
+ − 285 // float oldRange;
+ − 286 float newRange;
+ − 287
+ − 288 float sizeOfScreen;
+ − 289 // float InputTopValue;
+ − 290 // float InputBottomValue;
+ − 291 float screenToRangeRatio;
+ − 292 float diffOutMaxToMaxOnScale;
+ − 293 float diffOutMinToMaxOnScale;
+ − 294 int positonOutputMaxValue;
+ − 295 int positonOutputMinValue;
+ − 296
+ − 297
+ − 298 // scale
+ − 299 // oldScale = *OutputStepOfScale;
+ − 300 newScale = *OutputStepOfScale + 9;
+ − 301 newScale /= 10;
+ − 302 newScale *= 10;
+ − 303 // diff_newScale = newScale - *OutputStepOfScale;
+ − 304 // oldRange = 5 * oldScale;
+ − 305 newRange = 5 * newScale;
+ − 306 *OutputStepOfScale = newScale;
+ − 307
+ − 308 // MaxValueOnScale
+ − 309 // oldMaxOnScale = *OutputMaxValueOnScale;
+ − 310 if(OutputMaxValueOnScale < 0)
+ − 311 {
+ − 312 negativeMaxValue = 1;
+ − 313 newMaxOnScale = 0 - *OutputMaxValueOnScale;
+ − 314 }
+ − 315 else
+ − 316 {
+ − 317 negativeMaxValue = 0;
+ − 318 newMaxOnScale = *OutputMaxValueOnScale;
+ − 319 }
+ − 320 newMaxOnScale += 9;
+ − 321 newMaxOnScale /= 10;
+ − 322 newMaxOnScale *= 10;
+ − 323 if(negativeMaxValue)
+ − 324 {
+ − 325 // diff_newMaxOnScale = newMaxOnScale + *OutputMaxValueOnScale;
+ − 326 *OutputMaxValueOnScale = 0 - newMaxOnScale;
+ − 327 }
+ − 328 else
+ − 329 {
+ − 330 // diff_newMaxOnScale = newMaxOnScale - *OutputMaxValueOnScale;
+ − 331 *OutputMaxValueOnScale = newMaxOnScale;
+ − 332 }
+ − 333
+ − 334
+ − 335 // new coordinates
+ − 336 sizeOfScreen = 1 + InputBottom - InputTop;
+ − 337 // InputTopValue = *OutputMaxValueOnScale;
+ − 338 // InputBottomValue = InputTopValue + (6 * *OutputStepOfScale);
+ − 339
+ − 340 screenToRangeRatio = sizeOfScreen / newRange;
+ − 341 diffOutMaxToMaxOnScale = abs(*OutputMaxValueOnScale) - abs(*OutputMaxValue);
+ − 342 // diffOutMinToMax = abs(*OutputMinValue - *OutputMaxValue);
+ − 343 diffOutMinToMaxOnScale = abs(*OutputMaxValueOnScale - *OutputMinValue);
+ − 344
+ − 345 positonOutputMaxValue = (int)(diffOutMaxToMaxOnScale * screenToRangeRatio);
+ − 346 positonOutputMaxValue += *OutputTop;
+ − 347 positonOutputMinValue = (int)(diffOutMinToMaxOnScale * screenToRangeRatio);
+ − 348 positonOutputMinValue += *OutputTop;
+ − 349 // positonOutputMinValue = (int)(diffOutMinToMax * screenToRangeRatio);
+ − 350 // positonOutputMinValue += positonOutputMaxValue;
+ − 351 *OutputTop = positonOutputMaxValue;
+ − 352 *OutputBottom = positonOutputMinValue;
+ − 353 }
+ − 354
+ − 355
+ − 356 /**
+ − 357 ******************************************************************************
+ − 358 * @brief scaleHelper
+ − 359 * @author heinrichs weikamp gmbh
+ − 360 * @version V0.0.1
+ − 361 * @date 13-Oct-2016
+ − 362 ******************************************************************************
+ − 363 *
+ − 364 * @param hgfx:
+ − 365 * @retval None
+ − 366
+ − 367 * pixel 50 oben
+ − 368 * pixel 439 unten
+ − 369 * pixel 390 gesamt h�he
+ − 370
+ − 371 * for temperature, input is �C * 10
+ − 372 */
+ − 373
186
+ − 374 static void scaleHelper( uint16_t InputDataLength, int16_t *InputDataArray, int InputTop, int InputBottom,
38
+ − 375 int16_t *OutputMinValue, int16_t *OutputMaxValue, int *OutputTop, int *OutputBottom,
+ − 376 uint16_t *OutputStepOfScale, int16_t *OutputMaxValueOnScale)
+ − 377 {
+ − 378 int32_t datamin = INT16_MAX; // 32 bit for delta calculation ( delta is unsigned -> value can be 2x INT16_MAX)
+ − 379 int32_t datamax = INT16_MIN;
+ − 380 uint16_t deltaMinMax = 1;
+ − 381 // uint16_t deltaMinMaxUsed = 1;
+ − 382 // uint16_t digits = 1;
+ − 383 // uint16_t scaler = 1;
+ − 384 uint32_t step = 1;
+ − 385 const int sizeOfScreen = InputBottom - InputTop;
+ − 386 float pixel2range = 1.0;
+ − 387
+ − 388 // min, max, deltaMinMax, OutputMinValue, OutputMaxValue
+ − 389 for(uint16_t i = 0; i < InputDataLength; i++)
+ − 390 {
+ − 391 if(InputDataArray[i] > datamax)
+ − 392 datamax = InputDataArray[i];
+ − 393
+ − 394 if(InputDataArray[i] < datamin)
+ − 395 datamin = InputDataArray[i];
+ − 396 }
+ − 397
+ − 398 deltaMinMax = (uint16_t)(datamax - datamin);
+ − 399
+ − 400 *OutputMinValue = (int16_t)datamin;
+ − 401 *OutputMaxValue = (int16_t)datamax;
+ − 402
+ − 403 // step
+ − 404 step = deltaMinMax / 5;
+ − 405 while(deltaMinMax > (step * 5))
+ − 406 {
+ − 407 step += 1;
+ − 408 }
+ − 409 pixel2range = ((float)sizeOfScreen) / (step * 5);
+ − 410
+ − 411 *OutputStepOfScale = (uint16_t)step;
+ − 412 *OutputMaxValueOnScale = *OutputMaxValue;
+ − 413 *OutputTop = InputTop;
+ − 414 *OutputBottom = ((int)(pixel2range * deltaMinMax)) + *OutputTop;
+ − 415 }
+ − 416
+ − 417 /**
+ − 418 ******************************************************************************
+ − 419 * @brief show_logbook_logbook_show_log_page1 /
763
+ − 420 * @author heinrichs weikamp gmbh
38
+ − 421 * @version V0.0.1
+ − 422 * @date 07-July-2014
+ − 423 ******************************************************************************
+ − 424 *
+ − 425 * @param hgfx:
+ − 426 * @retval None
+ − 427 */
186
+ − 428 static void show_logbook_logbook_show_log_page1(GFX_DrawCfgScreen *hgfx,uint8_t StepBackwards)
38
+ − 429 {
+ − 430 SWindowGimpStyle wintemp;
+ − 431 SWindowGimpStyle winsmal;
484
+ − 432 wintemp.left = LOG_BORDER_OFFSET;
38
+ − 433 wintemp.right = 799 - wintemp.left;
484
+ − 434 wintemp.top = LOG_BORDER_OFFSET;
38
+ − 435 wintemp.bottom = 479 - 40;
567
+ − 436 char timeSuffix;
+ − 437 uint8_t hoursToDisplay;
38
+ − 438
+ − 439 SLogbookHeader logbookHeader;
+ − 440 logbook_getHeader(StepBackwards ,&logbookHeader);
+ − 441
+ − 442 uint16_t depthdata[1000] = { 0 };
+ − 443 uint8_t gasdata[1000] = { 0 };
+ − 444 int16_t tempdata[1000] = { 0 };
454
+ − 445 uint16_t tankdata[1000] = { 0 };
+ − 446
941
+ − 447 SGnssCoord posCoord;
+ − 448 posCoord.fLat = 0.0;
+ − 449 posCoord.fLon = 0.0;
+ − 450
454
+ − 451 #ifdef ENABLE_BOTTLE_SENSOR
+ − 452 uint16_t bottlePressureStart = 0;
+ − 453 uint16_t bottlePressureEnd = 0;
+ − 454 uint16_t loop = 0;
+ − 455 #endif
38
+ − 456
+ − 457 uint16_t dataLength = 0;
941
+ − 458 dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, tempdata, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, tankdata, &posCoord, NULL);
38
+ − 459
+ − 460 //Print Date
+ − 461 uint8_t year = logbookHeader.dateYear;
+ − 462 uint8_t month = logbookHeader.dateMonth;
+ − 463 uint8_t day = logbookHeader.dateDay;
+ − 464 char text[40];
+ − 465 snprintf(text, 20, "20%02i-%02i-%02i", year, month, day);
110
+ − 466
+ − 467 Gfx_write_label_var(hgfx, 30, 250,10, &FontT42,CLUT_GasSensor1,text);
+ − 468
941
+ − 469 #if defined ENABLE_GNSS_SUPPORT || defined ENABLE_GPIO_V2
+ − 470 if((posCoord.fLat != 0.0) || (posCoord.fLon != 0.0))
+ − 471 {
+ − 472 snprintf(text, 20, "%2.4f - %2.4f", posCoord.fLat, posCoord.fLon );
+ − 473 Gfx_write_label_var(hgfx, 300, 500,10, &FontT42,CLUT_GasSensor1,text);
+ − 474 }
+ − 475 #endif
+ − 476
38
+ − 477
+ − 478 // Print logbook number with offset
+ − 479 if(settingsGetPointer()->logbookOffset)
+ − 480 {
+ − 481 int32_t logNumber;
+ − 482 logNumber = settingsGetPointer()->logbookOffset - StepBackwards;
+ − 483 if(logNumber < 0)
+ − 484 logNumber = 0;
+ − 485 else
+ − 486 if(logNumber > 9999)
+ − 487 logNumber = 9999;
+ − 488
457
+ − 489 snprintf(text,20,"#%ld",logNumber);
38
+ − 490 Gfx_write_label_var(hgfx, 300, 590,10, &FontT42,CLUT_GasSensor1,text);
+ − 491 }
+ − 492
+ − 493 //Print time
+ − 494 uint8_t minute = logbookHeader.timeMinute;
567
+ − 495
+ − 496 if (settingsGetPointer()->amPMTime)
+ − 497 {
+ − 498 if (logbookHeader.timeHour > 11)
+ − 499 {
+ − 500 timeSuffix = 'P';
+ − 501 }
+ − 502 else
+ − 503 {
+ − 504 timeSuffix = 'A';
+ − 505 }
+ − 506
+ − 507 if (logbookHeader.timeHour % 12 == 0)
+ − 508 {
+ − 509 hoursToDisplay = 12;
+ − 510 }
+ − 511 else
+ − 512 {
+ − 513 hoursToDisplay = (logbookHeader.timeHour % 12);
+ − 514 }
+ − 515
+ − 516 snprintf(text,20,"\002%02i:%02i %cM",hoursToDisplay,minute,timeSuffix);
+ − 517 }
+ − 518 else
+ − 519 {
+ − 520 hoursToDisplay = logbookHeader.timeHour;
+ − 521 snprintf(text,20,"\002%02i:%02i",hoursToDisplay,minute);
+ − 522 }
+ − 523
+ − 524
484
+ − 525 Gfx_write_label_var(hgfx, 600, wintemp.right,10, &FontT42,CLUT_GasSensor1,text);
38
+ − 526
+ − 527 //Print Dive Mode (OC/CCR/...)
+ − 528 switch(logbookHeader.diveMode)
+ − 529 {
+ − 530 case DIVEMODE_OC:
662
+ − 531 snprintf(text,20,"%c",TXT_OpenCircuit);
38
+ − 532 break;
+ − 533 case DIVEMODE_CCR:
662
+ − 534 snprintf(text,20,"%c",TXT_ClosedCircuit);
38
+ − 535 break;
+ − 536 case DIVEMODE_Gauge:
662
+ − 537 snprintf(text,20,"%c",TXT_Gauge);
38
+ − 538 break;
+ − 539 case DIVEMODE_Apnea:
662
+ − 540 snprintf(text,20,"%c",TXT_Apnoe);
+ − 541 break;
+ − 542 case DIVEMODE_PSCR:
+ − 543 snprintf(text,20,"%c",TXT_PSClosedCircuit);
38
+ − 544 break;
+ − 545 }
+ − 546 Gfx_write_label_var(hgfx, 30, 250,60, &FontT42,CLUT_GasSensor4,text);
+ − 547
+ − 548 // Decomodel
+ − 549 if(logbookHeader.diveMode <= DIVEMODE_CCR)
+ − 550 {
+ − 551 switch(logbookHeader.decoModel)
+ − 552 {
+ − 553 case GF_MODE:
+ − 554 snprintf(text,20,"\002GF%u/%u",logbookHeader.gfLow_or_Vpm_conservatism,logbookHeader.gfHigh);
484
+ − 555 break;
38
+ − 556 case VPM_MODE:
+ − 557 snprintf(text,20,"\002VPM +%u",logbookHeader.gfLow_or_Vpm_conservatism);
484
+ − 558 break;
+ − 559 default:
+ − 560 snprintf(text,20," "); /* no information to be displayed */
+ − 561 break;
38
+ − 562 }
484
+ − 563 Gfx_write_label_var(hgfx, 500, wintemp.right,60, &FontT42,CLUT_GasSensor1,text);
38
+ − 564 }
+ − 565
+ − 566 //Write Dive Time
+ − 567 int minutes = logbookHeader.diveTimeMinutes;
+ − 568 int seconds = logbookHeader.diveTimeSeconds;
+ − 569 int hours = minutes/60;
+ − 570 minutes -= hours * 60;
+ − 571 snprintf(text,20,"%02i:%02i:%02i",hours,minutes,seconds);
+ − 572 Gfx_write_label_var(hgfx, 30, 250,360, &FontT42,CLUT_GasSensor1,text);
+ − 573 Gfx_write_label_var(hgfx, 200, 250,360, &FontT42,CLUT_GasSensor4,"s");
+ − 574
+ − 575 // Max Depth
+ − 576 int maxdepth =logbookHeader.maxDepth/100;
+ − 577 int maxdepth_dcm = logbookHeader.maxDepth/10 - maxdepth * 10;
+ − 578 int top = 150;
+ − 579 if(settingsGetPointer()->nonMetricalSystem)
+ − 580 {
+ − 581 float maxDepthFeet = 0;
+ − 582 maxDepthFeet = unit_depth_float(((float)logbookHeader.maxDepth)/100);
+ − 583 snprintf(text,20,"%.0f",maxDepthFeet);
+ − 584 }
+ − 585 else
+ − 586 {
+ − 587 snprintf(text,20,"%i.%i",maxdepth,maxdepth_dcm);
+ − 588 }
+ − 589 Gfx_write_label_var(hgfx, 30, 250,top, &FontT42,CLUT_GasSensor1,text);
+ − 590 winsmal.left = 30;
+ − 591 winsmal.top = top -3;
+ − 592 winsmal.bottom = winsmal.top + FontT42.height;
110
+ − 593
38
+ − 594 if(maxdepth < 10)
+ − 595 {
+ − 596 winsmal.left = 137;
+ − 597 }
+ − 598 else if(maxdepth < 100)
+ − 599 {
+ − 600 winsmal.left = 151;
+ − 601 }
+ − 602 else
+ − 603 {
+ − 604 winsmal.left = 147;
+ − 605 }
110
+ − 606 winsmal.right = winsmal.left + 50;
+ − 607
+ − 608 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,top, &FontT24,CLUT_GasSensor4,"max");
38
+ − 609 snprintf(text,3,"%c%c"
+ − 610 , unit_depth_char1()
+ − 611 , unit_depth_char2()
+ − 612 );
+ − 613 Gfx_write_label_var(hgfx, winsmal.left - 37, 250,top, &FontT42,CLUT_GasSensor4,text);
+ − 614
+ − 615 // Average Depth
+ − 616 int avrdepth =logbookHeader.averageDepth_mbar/100;
+ − 617 int avrdepth_dcm = logbookHeader.averageDepth_mbar/10 - avrdepth * 10;
+ − 618 top = 200;
+ − 619 if(settingsGetPointer()->nonMetricalSystem)
+ − 620 {
+ − 621 float avgDepthFeet = 0;
+ − 622 avgDepthFeet = unit_depth_float(((float)logbookHeader.averageDepth_mbar)/100);
+ − 623 snprintf(text,20,"%.0f",avgDepthFeet);
+ − 624 }
+ − 625 else
+ − 626 {
+ − 627 snprintf(text,20,"%i.%i",avrdepth,avrdepth_dcm);
+ − 628 }
+ − 629 Gfx_write_label_var(hgfx, 30, 250,top, &FontT42,CLUT_GasSensor1,text);
110
+ − 630
38
+ − 631 winsmal.left = 30;
+ − 632 winsmal.top = top -3;
+ − 633 winsmal.bottom = winsmal.top + FontT42.height;
110
+ − 634
+ − 635 /* put avg behind previous string */
38
+ − 636 if(avrdepth < 10)
+ − 637 {
+ − 638 winsmal.left = 137 ;
+ − 639 }
+ − 640 else if(avrdepth < 100)
+ − 641 {
+ − 642 winsmal.left = 151;
+ − 643 }
+ − 644 else
+ − 645 {
+ − 646 winsmal.left = 147;
+ − 647 }
110
+ − 648 winsmal.right = winsmal.left + 50;
+ − 649
+ − 650 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_GasSensor4,"avg");
38
+ − 651 snprintf(text,3,"%c%c"
+ − 652 , unit_depth_char1()
+ − 653 , unit_depth_char2()
+ − 654 );
+ − 655 Gfx_write_label_var(hgfx, winsmal.left - 37, 250,top, &FontT42,CLUT_GasSensor4,text);
+ − 656 // Temperature
+ − 657 top+= 50;
+ − 658 float temp_Temperature;
+ − 659 uint16_t start;
+ − 660 temp_Temperature = ((float)logbookHeader.minTemp)/10;
+ − 661 snprintf(text,20,"%.1f",unit_temperature_float(temp_Temperature));
+ − 662 Gfx_write_label_var(hgfx, 30, 250,top, &FontT42,CLUT_GasSensor1,text);
+ − 663
+ − 664 if(settingsGetPointer()->nonMetricalSystem)
+ − 665 start = 121;
+ − 666 else if((logbookHeader.minTemp >= 0) && (logbookHeader.minTemp < 10))
+ − 667 start = 100;
+ − 668 else if((logbookHeader.minTemp >= -10) && (logbookHeader.minTemp < 100))
+ − 669 start = 114;
+ − 670 else
+ − 671 start = 121;
+ − 672
+ − 673 text[0] = '\140';
+ − 674 if(settingsGetPointer()->nonMetricalSystem)
+ − 675 text[1] = 'F';
+ − 676 else
+ − 677 text[1] = 'C';
+ − 678 text[2] = 0;
+ − 679
+ − 680 Gfx_write_label_var(hgfx, start, 300,top, &FontT42,CLUT_GasSensor4,text);
+ − 681
+ − 682 // CNS
+ − 683 snprintf(text,20,"CNS: %i %%",logbookHeader.maxCNS);
150
+ − 684 Gfx_write_label_var(hgfx, 30, 250,440, &FontT42,CLUT_GasSensor1,text);
38
+ − 685
+ − 686 // Surface Pressure
+ − 687 // snprintf(text,20,"\001%i\016\016 mbar",logbookHeader.surfacePressure_mbar);
+ − 688 // Gfx_write_label_var(hgfx,300,500,750, &FontT42,CLUT_GasSensor1,text);
+ − 689 // snprintf(text,40,"%i\016\016 mbar\017 (%i\016\016 m\017)",logbookHeader.surfacePressure_mbar, unit_SeaLevelRelation_integer(logbookHeader.surfacePressure_mbar));
102
+ − 690 snprintf(text,40,"%i\016\016 hPa\017",logbookHeader.surfacePressure_mbar);
150
+ − 691 Gfx_write_label_var(hgfx,320,600,440, &FontT42,CLUT_GasSensor1,text);
38
+ − 692
596
+ − 693
+ − 694 /* show symbol in case log entry is marked for usage in profile custom view */
+ − 695 snprintf(text,10,"\002>");
616
+ − 696 if(StepBackwards == getReplayOffset())
596
+ − 697 {
+ − 698 Gfx_write_label_var(hgfx,750,799,440, &FontT42,CLUT_GasSensor1,text);
+ − 699 }
+ − 700 else
+ − 701 {
+ − 702 Gfx_write_label_var(hgfx,750,799,440, &FontT42,CLUT_MenuTopBackground,text);
+ − 703 }
+ − 704
+ − 705
454
+ − 706 /* Show tank info */
+ − 707 #ifdef ENABLE_BOTTLE_SENSOR
+ − 708 for(loop = 0; loop < dataLength; loop++)
+ − 709 {
+ − 710 if((bottlePressureStart == 0) && (tankdata[loop] != 0)) /* find first pressure value */
+ − 711 {
+ − 712 bottlePressureStart = tankdata[loop];
+ − 713 }
+ − 714 if((tankdata[loop] != 0)) /* store last pressure value */
+ − 715 {
+ − 716 bottlePressureEnd = tankdata[loop];
+ − 717 }
+ − 718 }
+ − 719 if(bottlePressureStart != 0)
+ − 720 {
484
+ − 721 snprintf(text,40,"\002%i | %i\016\016 Bar\017",bottlePressureStart,bottlePressureEnd);
+ − 722 Gfx_write_label_var(hgfx,450,wintemp.right,440, &FontT42,CLUT_GasSensor1,text);
454
+ − 723 }
+ − 724 #endif
38
+ − 725 //--- print coordinate system & depth graph with gaschanges ---
+ − 726 wintemp.left = 330;
+ − 727 wintemp.top = 160;
+ − 728 wintemp.bottom -= 40;
110
+ − 729
38
+ − 730 show_logbook_draw_depth_graph(hgfx, StepBackwards, &wintemp, 1, dataLength, depthdata, gasdata, NULL);
+ − 731 }
+ − 732
+ − 733
186
+ − 734 static void show_logbook_logbook_show_log_page2(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards)
38
+ − 735 {
+ − 736 //*** Page2: Depth and Temperature ****
+ − 737
+ − 738 SWindowGimpStyle wintemp;
+ − 739 SWindowGimpStyle winsmal;
+ − 740 wintemp.left = 50;
+ − 741 wintemp.right = 799 - wintemp.left;
+ − 742 wintemp.top = 50;
+ − 743 wintemp.bottom = 479 - 40;
+ − 744
+ − 745 SLogbookHeader logbookHeader;
+ − 746
+ − 747 logbook_getHeader(StepBackwards,&logbookHeader);
+ − 748 uint16_t dataLength = 0;
+ − 749 uint16_t depthdata[1000];
+ − 750 uint8_t gasdata[1000];
+ − 751 int16_t tempdata[1000];
+ − 752 uint16_t decoDepthdata[1000];
+ − 753 uint16_t *pDecoDepthData = 0;
+ − 754
941
+ − 755 dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, tempdata, NULL, NULL, NULL, NULL, NULL, NULL, NULL, decoDepthdata, NULL, NULL, NULL);
38
+ − 756
+ − 757 for(int i = 0; i<dataLength; i++)
+ − 758 {
+ − 759 if(decoDepthdata[i] >= 300)
+ − 760 {
+ − 761 pDecoDepthData = decoDepthdata;
+ − 762 break;
+ − 763 }
+ − 764 }
+ − 765 //--- print coordinate system & depth graph ---
+ − 766 show_logbook_draw_depth_graph(hgfx, StepBackwards, &wintemp, 0, dataLength, depthdata, gasdata, pDecoDepthData);
+ − 767
+ − 768 //*** Temperature *************************************************
+ − 769
+ − 770 //--- print temperature labels ---
+ − 771 // input maxtmpline, tmpstep, deltaline
+ − 772
+ − 773 winsmal.left = wintemp.right +6;
+ − 774 winsmal.top = wintemp.top - 3;
+ − 775 winsmal.right = wintemp.right + 30;
+ − 776 winsmal.bottom = winsmal.top + 16;
+ − 777
567
+ − 778 if(settingsGetPointer()->nonMetricalSystem)
+ − 779 {
+ − 780 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_LogbookTemperature,"[F]");
+ − 781 }
+ − 782 else
+ − 783 {
+ − 784 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_LogbookTemperature,"[C]");
+ − 785 }
38
+ − 786
+ − 787 int16_t minVal = 0;
+ − 788 int16_t maxVal = 0;
+ − 789 int newTop = 0;
+ − 790 int newBottom = 0;
+ − 791 uint16_t step = 0;
+ − 792 int16_t maxValTop = 0;
653
+ − 793 int16_t tmp = 0;
38
+ − 794
+ − 795 scaleHelper(dataLength, tempdata, wintemp.top, wintemp.bottom,
+ − 796 &minVal, &maxVal, &newTop, &newBottom,
+ − 797 &step, &maxValTop); // newTop is wintemp.top
+ − 798
+ − 799 scaleAdapt( wintemp.top, wintemp.bottom,
+ − 800 &minVal, &maxVal, &newTop, &newBottom,
+ − 801 &step, &maxValTop);
+ − 802
+ − 803 // temperature in 1/10 �C
+ − 804 int deltaline = (1 + wintemp.bottom - wintemp.top)/5;
632
+ − 805 char msg[15];
653
+ − 806
+ − 807 /* temperature is provided in centi scaling => convert */
+ − 808 maxValTop /= 10;
+ − 809 step /= 10;
+ − 810
+ − 811 tmp = maxValTop;
38
+ − 812 for(int i = 1; i<=5; i++)
+ − 813 {
+ − 814 tmp -= step;
+ − 815 winsmal.top = wintemp.top + deltaline * i - 14;
+ − 816 winsmal.bottom = winsmal.top + 16;
653
+ − 817 snprintf(msg,15,"%2i",unit_temperature_integer(tmp));
110
+ − 818 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,CLUT_LogbookTemperature,msg);
38
+ − 819 }
+ − 820
+ − 821
+ − 822 //--- print temperature graph ---
+ − 823 // input tempdata[i], maxtmpline, mintmpline, maxTmp, minTmp, deltaline, wintemp.top, dataLength, datamax,
+ − 824
+ − 825 //adapt window
+ − 826 wintemp.bottom = newBottom;
+ − 827 wintemp.top = newTop;
+ − 828 GFX_graph_print(hgfx,&wintemp,0,1,maxVal,minVal, (uint16_t *)tempdata,dataLength,CLUT_LogbookTemperature, NULL);
+ − 829 }
+ − 830
+ − 831
186
+ − 832 static void build_logbook_test(uint8_t page, uint8_t StepBackwards)
38
+ − 833 {
+ − 834 uint32_t lastScreen,lastBackground;
+ − 835
+ − 836 lastScreen = tLOGscreen.FBStartAdress;
+ − 837 lastBackground = tLOGbackground.FBStartAdress;
+ − 838
+ − 839 tLOGscreen.FBStartAdress = getFrame(16);
+ − 840 tLOGscreen.ImageHeight = 480;
+ − 841 tLOGscreen.ImageWidth = 800;
+ − 842 tLOGscreen.LayerIndex = 1;
+ − 843
+ − 844 tLOGbackground.FBStartAdress = getFrame(17);
+ − 845 tLOGbackground.ImageHeight = 480;
+ − 846 tLOGbackground.ImageWidth = 800;
+ − 847 tLOGbackground.LayerIndex = 0;
+ − 848 switch(page)
+ − 849 {
+ − 850 case 1:
+ − 851 show_logbook_logbook_show_log_page1(&tLOGscreen,StepBackwards);
+ − 852 break;
+ − 853 case 2:
+ − 854 show_logbook_logbook_show_log_page2(&tLOGscreen,StepBackwards);
+ − 855 break;
+ − 856 case 3:
+ − 857 show_logbook_logbook_show_log_page3(&tLOGscreen,StepBackwards);
+ − 858 break;
+ − 859 case 4:
+ − 860 show_logbook_logbook_show_log_page4(&tLOGscreen,StepBackwards);
+ − 861 break;
+ − 862 }
+ − 863
+ − 864 releaseFrame(16,lastScreen);
+ − 865 releaseFrame(17,lastBackground);
+ − 866 }
+ − 867
+ − 868
+ − 869 void show_logbook_test(_Bool firstPage, uint8_t StepBackwards)
+ − 870 {
+ − 871 if(firstPage)
+ − 872 {
596
+ − 873 active_log_page = 1;
+ − 874 active_log_offset = StepBackwards;
38
+ − 875 }
+ − 876 else
+ − 877 {
596
+ − 878 active_log_page++;
+ − 879 if(active_log_page > 4)
+ − 880 {
+ − 881 active_log_page = 1;
+ − 882 }
38
+ − 883 }
+ − 884
596
+ − 885 build_logbook_test(active_log_page,StepBackwards);
38
+ − 886 // GFX_ResetLayer(TOP_LAYER);
+ − 887 // GFX_ResetLayer(BACKGRD_LAYER);
+ − 888
+ − 889 set_globalState(StILOGSHOW);
+ − 890 GFX_SetFramesTopBottom(tLOGscreen.FBStartAdress, tLOGbackground.FBStartAdress,480);
+ − 891 }
+ − 892
+ − 893
+ − 894 void show_logbook_exit(void)
+ − 895 {
+ − 896 releaseFrame(16,tLOGscreen.FBStartAdress);
+ − 897 releaseFrame(17,tLOGbackground.FBStartAdress);
+ − 898 }
+ − 899
+ − 900
186
+ − 901 static void show_logbook_logbook_show_log_page3(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards)
38
+ − 902 {
+ − 903 SWindowGimpStyle wintemp;
+ − 904 SWindowGimpStyle winsmal;
662
+ − 905 uint8_t gasWasUsed[NUM_GASES * 2];
+ − 906 int16_t index = 0;
+ − 907 uint8_t loopMode = 0;
+ − 908
38
+ − 909 wintemp.left = 50;
+ − 910 wintemp.right = 799 - wintemp.left;
+ − 911 wintemp.top = 50;
+ − 912 wintemp.bottom = 479 - 40;
+ − 913
+ − 914 SLogbookHeader logbookHeader;
+ − 915
+ − 916 logbook_getHeader(StepBackwards, &logbookHeader);
+ − 917 uint16_t dataLength = 0;
+ − 918 uint16_t depthdata[1000];
+ − 919 uint8_t gasdata[1000];
941
+ − 920 dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
38
+ − 921
662
+ − 922 char msg[15];
+ − 923 char gas_name[15];
+ − 924 int j = 0;
+ − 925
+ − 926 loopMode = isLoopMode(logbookHeader.diveMode);
+ − 927
+ − 928 /* check if gas was used, independent from its active state */
+ − 929 for(index = 0; index < NUM_GASES * 2; index++)
+ − 930 {
+ − 931 gasWasUsed[index] = 0;
+ − 932 }
+ − 933 for(index = 0; index < dataLength; index++)
+ − 934 {
+ − 935 if(loopMode)
+ − 936 {
+ − 937 if(gasdata[index] < NUM_GASES) /* the log entry starts with a ID in range 1..4 independend if diluent is used at start */
+ − 938 {
+ − 939 gasdata[index] += NUM_GASES;
+ − 940 }
+ − 941 else
+ − 942 {
+ − 943 loopMode = 0; /* after the first gas change, no matter if diluent or bailout, the correct ID will be stored */
+ − 944 }
+ − 945 }
+ − 946 if(gasdata[index] > 0)
+ − 947 {
+ − 948 gasWasUsed[gasdata[index]-1] = 1; /* The ID stored in the samples is starting with 1 (array[0] = gasID1) */
+ − 949 }
+ − 950 else
+ − 951 {
+ − 952 gasWasUsed[0] = 1;
+ − 953 }
+ − 954 }
+ − 955
38
+ − 956 //--- print coordinate system & depth graph with gaschanges ---
+ − 957 show_logbook_draw_depth_graph(hgfx, StepBackwards, &wintemp, 1, dataLength, depthdata, gasdata, NULL);
+ − 958
+ − 959 //--- print gas list ---
+ − 960 winsmal.left = wintemp.right - 190;
+ − 961 winsmal.right = winsmal.left + 150;
+ − 962
662
+ − 963 loopMode = isLoopMode(logbookHeader.diveMode);
+ − 964 for(index = (2 * NUM_GASES) -1; index >= 0; index--)
38
+ − 965 {
662
+ − 966 if(gasWasUsed[index])
38
+ − 967 {
+ − 968 j++;
662
+ − 969 if(j > 5) /* limit number of gases displayed to 5 */
+ − 970 {
+ − 971 break;
+ − 972 }
38
+ − 973 winsmal.top = wintemp.bottom - 5 - j * 26 ;
+ − 974 winsmal.bottom = winsmal.top + 21 ;
662
+ − 975 uint8_t color = get_colour(index);
38
+ − 976
662
+ − 977 if(loopMode)
+ − 978 {
+ − 979 if(index < NUM_GASES) /* Switch to Bailout is not covered by log gas list */
+ − 980 {
+ − 981 snprintf(gas_name,15,"Bailout");
+ − 982 snprintf(msg,15,"G%d: %s",index +1, gas_name);
+ − 983 }
+ − 984 else
+ − 985 {
+ − 986 print_gas_name(gas_name,15,logbookHeader.gasordil[index-NUM_GASES].oxygen_percentage,logbookHeader.gasordil[index-NUM_GASES].helium_percentage);
+ − 987 snprintf(msg,15,"D%d: %s",index +1 - NUM_GASES, gas_name);
+ − 988 }
+ − 989 }
+ − 990 else
+ − 991 {
+ − 992 print_gas_name(gas_name,15,logbookHeader.gasordil[index].oxygen_percentage,logbookHeader.gasordil[index].helium_percentage);
+ − 993 snprintf(msg,15,"G%d: %s",index +1, gas_name);
+ − 994 }
110
+ − 995 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,msg);
38
+ − 996 }
+ − 997 }
+ − 998
+ − 999 //--- define buttons ---
+ − 1000 /*if(*ghost_char_logfile_oxydata)
+ − 1001 button_start_single_action(surf1_menu_logbook_current_page, surf1_menu_logbook_show_log_page4, surf1_menu_logbook_show_log_next);
+ − 1002 else
+ − 1003 button_start_single_action(surf1_menu_logbook_current_page, surf1_menu_logbook_show_log_page1, surf1_menu_logbook_show_log_next);
+ − 1004 */
+ − 1005 }
+ − 1006
662
+ − 1007 static uint8_t check_data_array_empty(uint16_t* pdata)
+ − 1008 {
+ − 1009 uint8_t ret = 0;
+ − 1010 uint8_t index = 0;
+ − 1011 uint8_t emptyCnt = 0;
+ − 1012
+ − 1013 for (index=0; index < 10; index++) /* read the first 10 data points. If all are 0 then the array is rated as empty */
+ − 1014 {
+ − 1015 if(*(pdata+index) == 0)
+ − 1016 {
+ − 1017 emptyCnt++;
+ − 1018 }
+ − 1019 }
+ − 1020 if(emptyCnt == 10)
+ − 1021 {
+ − 1022 ret = 1;
+ − 1023 }
+ − 1024 return ret;
+ − 1025 }
+ − 1026
186
+ − 1027 static void show_logbook_logbook_show_log_page4(GFX_DrawCfgScreen *hgfx, uint8_t StepBackwards)
38
+ − 1028 { SWindowGimpStyle wintemp;
+ − 1029 SWindowGimpStyle winsmal;
+ − 1030 wintemp.left = 50;
+ − 1031 wintemp.right = 799 - wintemp.left;
+ − 1032 wintemp.top = 50;
+ − 1033 wintemp.bottom = 479 - 40;
+ − 1034 uint8_t color = 0;
+ − 1035 SLogbookHeader logbookHeader;
+ − 1036
+ − 1037 logbook_getHeader(StepBackwards, &logbookHeader);
+ − 1038 uint16_t dataLength = 0;
+ − 1039 uint16_t depthdata[1000];
+ − 1040 uint8_t gasdata[1000];
+ − 1041 uint16_t ppO2data[1000];
+ − 1042 uint16_t sensor2[1000];
+ − 1043 uint16_t sensor3[1000];
662
+ − 1044 uint16_t *setpoint = ppO2data;
+ − 1045 uint16_t *sensor1 = ppO2data;
+ − 1046 uint8_t sensorDataAvailable[] = {0,0,0};
38
+ − 1047
+ − 1048
662
+ − 1049 if(!isLoopMode(logbookHeader.diveMode))
941
+ − 1050 dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, ppO2data, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
38
+ − 1051 else
+ − 1052 {
662
+ − 1053 switch(logbookHeader.CCRmode)
+ − 1054 {
+ − 1055 case CCRMODE_FixedSetpoint:
941
+ − 1056 default: dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata, gasdata, NULL, NULL, setpoint, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1057 break;
941
+ − 1058 case CCRMODE_Sensors: dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata, gasdata, NULL, NULL, NULL, sensor1, sensor2, sensor3, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1059 if(!check_data_array_empty(sensor1))
+ − 1060 {
+ − 1061 sensorDataAvailable[0] = 1;
+ − 1062 }
+ − 1063 if(!check_data_array_empty(sensor2))
+ − 1064 {
+ − 1065 sensorDataAvailable[1] = 1;
+ − 1066 }
+ − 1067 if(!check_data_array_empty(sensor3))
+ − 1068 {
+ − 1069 sensorDataAvailable[2] = 1;
+ − 1070 }
+ − 1071 if((logbookHeader.diveMode == DIVEMODE_PSCR) && (sensorDataAvailable[0] + sensorDataAvailable[1] + sensorDataAvailable[2] != 3)) /*insert sim data if not all three sensors are in use*/
+ − 1072 {
+ − 1073 if(sensorDataAvailable[0] == 0)
+ − 1074 {
941
+ − 1075 logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, sensor1, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1076 sensorDataAvailable[0] = 1;
+ − 1077 }
+ − 1078 else if(sensorDataAvailable[1] == 0)
+ − 1079 {
941
+ − 1080 logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, sensor2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1081 sensorDataAvailable[1] = 1;
+ − 1082 }
+ − 1083 else if(sensorDataAvailable[2] == 0)
+ − 1084 {
941
+ − 1085 logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, sensor3, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1086 sensorDataAvailable[2] = 1;
+ − 1087 }
+ − 1088 }
+ − 1089 break;
941
+ − 1090 case CCRMODE_Simulation: dataLength = logbook_readSampleData(StepBackwards, 1000, depthdata,gasdata, NULL, ppO2data, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
662
+ − 1091 break;
+ − 1092 }
38
+ − 1093 }
+ − 1094
+ − 1095
+ − 1096 //--- print coordinate system & depth graph with bailout---
+ − 1097 show_logbook_draw_depth_graph(hgfx, StepBackwards, &wintemp, 0, dataLength, depthdata, gasdata, NULL);
+ − 1098
+ − 1099
+ − 1100
+ − 1101 //*** Desciption at bottom of page ***************************
+ − 1102 winsmal.top = wintemp.bottom +2 ;
+ − 1103 winsmal.bottom = winsmal.top + 16;
+ − 1104
+ − 1105
+ − 1106 /*if(strcmp( (char*)ghost_char_logfile_text_oc_ccr,"ccr/bailout") == 0)
+ − 1107 {
+ − 1108 winsmal.left = wintemp.left + 2;
+ − 1109 winsmal.right = winsmal.left + 55;
+ − 1110
+ − 1111 oled_write(OVERLAY, &winsmal,"CCR -",false,true);
+ − 1112
+ − 1113 winsmal.left = winsmal.right;
+ − 1114 winsmal.right = winsmal.left + 90;
+ − 1115 //winsmal.fontcolor = oled_get_colour(15);
+ − 1116 oled_write(OVERLAY, &winsmal,"bailout",false,true);
+ − 1117 }
+ − 1118 else*/
+ − 1119 {
+ − 1120 winsmal.left = wintemp.left + 2;
+ − 1121 winsmal.right = winsmal.left + 55;
+ − 1122 color = CLUT_GasSensor1;//LOGBOOK_GRAPH_DEPTH;
+ − 1123
110
+ − 1124 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"depth");
38
+ − 1125
+ − 1126 }
+ − 1127 winsmal.left = 799 - 67;//wintemp.right -67;
+ − 1128 winsmal.right = winsmal.left;// + 45;
+ − 1129
662
+ − 1130 color = CLUT_LogbookTemperature;
+ − 1131
+ − 1132 if(!isLoopMode(logbookHeader.diveMode))
+ − 1133 {
110
+ − 1134 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"\002PP O2");
662
+ − 1135 }
38
+ − 1136 else
662
+ − 1137 {
+ − 1138 switch(logbookHeader.CCRmode)
+ − 1139 {
+ − 1140 case CCRMODE_FixedSetpoint:
+ − 1141 default: Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"\002SETPOINT");
+ − 1142 break;
+ − 1143 case CCRMODE_Sensors: Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"\002SENSORS");
+ − 1144 break;
+ − 1145 case CCRMODE_Simulation: Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"\002SIM PPO2");
+ − 1146 break;
+ − 1147 }
+ − 1148 }
38
+ − 1149
+ − 1150 //*** PP O2 ****************************************************
+ − 1151 //calc lines and labels
+ − 1152 int datamax = 0;
+ − 1153 int datamin = 10000;
+ − 1154 for(int i=1;i<dataLength;i++)
+ − 1155 {
+ − 1156 if(ppO2data[i]>datamax)
+ − 1157 datamax = ppO2data[i];
+ − 1158 if(ppO2data[i]<datamin)
+ − 1159 datamin = ppO2data[i];
+ − 1160 }
662
+ − 1161 if(isLoopMode(logbookHeader.diveMode) && (logbookHeader.CCRmode == CCRMODE_Sensors))
38
+ − 1162 {
+ − 1163 for(int i=1;i<dataLength;i++)
+ − 1164 {
+ − 1165 if(sensor2[i]>datamax)
+ − 1166 datamax = sensor2[i];
+ − 1167 if(sensor2[i]<datamin)
+ − 1168 datamin = sensor2[i];
+ − 1169 if(sensor3[i]>datamax)
+ − 1170 datamax = sensor3[i];
+ − 1171 if(sensor3[i]<datamin)
+ − 1172 datamin = sensor3[i];
+ − 1173 }
+ − 1174 }
+ − 1175 float maxoxy = ((float)datamax)/100;
+ − 1176 float minoxy = ((float)datamin)/100;
+ − 1177 float oxystep = 0.5;
+ − 1178 float maxoxyline = 2.5;
+ − 1179
+ − 1180 //--- print PP O2 labels ----
+ − 1181 winsmal.left = wintemp.right + 2;
+ − 1182 winsmal.top = wintemp.top ;
+ − 1183 winsmal.right = wintemp.right + 30;
+ − 1184 winsmal.bottom = winsmal.top + 16;
+ − 1185 //winsmal.font = ft_tiny + ft_SLIM;
+ − 1186 color = CLUT_LogbookTemperature;// = LOGBOOK_GRAPH_TEMP;
+ − 1187
110
+ − 1188 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,"bar");
38
+ − 1189
+ − 1190 int deltaline = (wintemp.bottom - wintemp.top)/5;
+ − 1191 char msg[4];
+ − 1192 float oxy = maxoxyline;
+ − 1193 for(int i = 1; i<=5; i++)
+ − 1194 {
+ − 1195 oxy -= oxystep;
+ − 1196 if(oxy < 0)
+ − 1197 break;
+ − 1198 winsmal.top = wintemp.top + deltaline * i - 8;
+ − 1199 winsmal.bottom = winsmal.top + 16;
+ − 1200 snprintf(msg,4,"%1.1f",oxy);
110
+ − 1201 Gfx_write_label_var(hgfx, winsmal.left, winsmal.right,winsmal.top, &FontT24,color,msg);
38
+ − 1202 //oled_write(OVERLAY, &winsmal,msg,false,true);
+ − 1203 }
+ − 1204
+ − 1205 //--- print PP O2 graph ---
+ − 1206 //Adapt window
+ − 1207 float ftmp = ((maxoxyline - minoxy) * deltaline) /oxystep + wintemp.top;
+ − 1208 wintemp.bottom = ftmp;
+ − 1209 if((ftmp - (int)ftmp) >= 0.5f)
+ − 1210 wintemp.bottom++;
+ − 1211
+ − 1212 ftmp = wintemp.top + ((maxoxyline - maxoxy) * deltaline) /oxystep;
+ − 1213 wintemp.top = ftmp;
+ − 1214 if((ftmp - (int)ftmp) >= 0.5f)
+ − 1215 wintemp.top++;
+ − 1216 wintemp.top = MaxU32LOG(wintemp.top ,0);
+ − 1217 if(wintemp.top < wintemp.bottom)
+ − 1218 {
662
+ − 1219 if(isLoopMode(logbookHeader.diveMode) && (logbookHeader.CCRmode == CCRMODE_Sensors))
38
+ − 1220 {
662
+ − 1221 if(sensorDataAvailable[0])
+ − 1222 {
+ − 1223 GFX_graph_print(hgfx,&wintemp,0,1,datamax,datamin, ppO2data,dataLength,CLUT_GasSensor2, NULL);
+ − 1224 }
+ − 1225 if(sensorDataAvailable[1])
+ − 1226 {
+ − 1227 GFX_graph_print(hgfx,&wintemp,0,1,datamax,datamin, sensor2,dataLength,CLUT_GasSensor3, NULL);
+ − 1228 }
+ − 1229 if(sensorDataAvailable[2])
+ − 1230 {
+ − 1231 GFX_graph_print(hgfx,&wintemp,0,1,datamax,datamin, sensor3,dataLength,CLUT_GasSensor4, NULL);
+ − 1232 }
38
+ − 1233 }
+ − 1234 else
+ − 1235 GFX_graph_print(hgfx,&wintemp,0,1,datamax,datamin, ppO2data,dataLength,CLUT_LogbookTemperature, NULL);
+ − 1236 }
+ − 1237 else
+ − 1238 {
+ − 1239 point_t startPoint, stopPoint;
+ − 1240 startPoint.x = wintemp.left;
+ − 1241 stopPoint.x = wintemp.right;
+ − 1242 stopPoint.y = startPoint.y = 479 - wintemp.top;
+ − 1243 GFX_draw_colorline(hgfx, startPoint, stopPoint, CLUT_LogbookTemperature);
+ − 1244 }
+ − 1245
+ − 1246 //--- define buttons ---
+ − 1247 //button_start_single_action(surf1_menu_logbook_current_page, surf1_menu_logbook_show_log_page1, surf1_menu_logbook_show_log_next);
+ − 1248 }
+ − 1249
186
+ − 1250 static void print_gas_name(char* output,uint8_t length,uint8_t oxygen,uint8_t helium)
38
+ − 1251 {
+ − 1252 if(helium == 0)
+ − 1253 {
+ − 1254 if(oxygen == 21)
+ − 1255 snprintf(output, length, "Air");
+ − 1256 else if(oxygen == 100)
+ − 1257 snprintf(output, length, "Oxy");
+ − 1258 else
+ − 1259 snprintf(output, length, "NX%i",oxygen);
+ − 1260 }
+ − 1261 else
+ − 1262 {
+ − 1263 if((oxygen + helium) == 100)
+ − 1264 snprintf(output, length, "HX%i",oxygen);
+ − 1265 else
+ − 1266 snprintf(output, length, "TMX%i/%i", oxygen, helium);
+ − 1267 }
+ − 1268
+ − 1269 }
+ − 1270
186
+ − 1271 static int16_t get_colour(int16_t color)
38
+ − 1272 {
+ − 1273 return CLUT_GasSensor1 + color;
+ − 1274 }
596
+ − 1275
+ − 1276 uint8_t getActiveLogPage()
+ − 1277 {
+ − 1278 return active_log_page;
+ − 1279 }
+ − 1280
+ − 1281 void updateReplayIncdicator(GFX_DrawCfgScreen *hgfx)
+ − 1282 {
+ − 1283 build_logbook_test(1,active_log_offset);
+ − 1284 GFX_SetFramesTopBottom(tLOGscreen.FBStartAdress, tLOGbackground.FBStartAdress,480);
+ − 1285 }