Mercurial > public > ostc4
view Discovery/Src/tMenuCvOptionText.c @ 1075:ef99fff2d2de Icon_Integration tip
Unlock button lock if BT is connected:
In the previous version the button lock coluld only be disabled by following the correct button press order. In case a button does not work (e.g. low button sensitifity) the OSTC would be locked. To avoid such a scenario the button lock is now also removed if the OSTC is connected via Bluetooth
| author | ideenmodellierer |
|---|---|
| date | Sun, 22 Feb 2026 20:00:00 +0100 |
| parents | 734f84b72b30 |
| children |
line wrap: on
line source
/////////////////////////////////////////////////////////////////////////////// /// -*- coding: UTF-8 -*- /// /// \file Discovery/Src/tMenuCvOptionText.c /// \brief File providing functions for generation of text lines /// \author heinrichs weikamp gmbh /// \date 03-Feb-2026 /// /// \details /// /// $Id$ /////////////////////////////////////////////////////////////////////////////// /// \par Copyright (c) 2014-2025 Heinrichs Weikamp gmbh /// /// This program is free software: you can redistribute it and/or modify /// it under the terms of the GNU General Public License as published by /// the Free Software Foundation, either version 3 of the License, or /// (at your option) any later version. /// /// This program is distributed in the hope that it will be useful, /// but WITHOUT ANY WARRANTY; without even the implied warranty of /// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the /// GNU General Public License for more details. /// /// You should have received a copy of the GNU General Public License /// along with this program. If not, see <http://www.gnu.org/licenses/>. ////////////////////////////////////////////////////////////////////////////// /* Includes ------------------------------------------------------------------*/ #include "tMenuCvOptionText.h" #include "tMenuEditCvOption.h" #include "tMenu.h" #include "tHome.h" // for enum CUSTOMVIEWS and init_t7_compass() #include "t3.h" #include "t7.h" /* Private function prototypes -----------------------------------------------*/ /* Exported functions --------------------------------------------------------*/ static refreshFunc_t refreshFctPointerTable[MAXLINES]; /* function pointer for refresh */ static uint8_t activeLines = 0; /* number of active lines */ refreshFunc_t* tMCvOptText_GetTable() { return refreshFctPointerTable; } uint8_t tMCvOptText_GetTableItemCnt() { return activeLines; } uint8_t tMCvOptText_refreshCompass(char* pText) { uint8_t textPointer = 0; pText[textPointer++] = TXT_2BYTE; pText[textPointer++] = TXT2BYTE_Compass; pText[textPointer++] = '\t'; if(settingsGetPointer()->compassBearing != 0) { textPointer += snprintf(&pText[textPointer], 20, "(%03u`)", settingsGetPointer()->compassBearing % 360); } pText[textPointer] = 0; return strlen(pText); } uint8_t tMCvOptText_refreshTimer(char* pText) { SSettings *settings = settingsGetPointer(); snprintf(pText, 21, "%c%c\t%u:%02u \016\016[m:ss]\017", TXT_2BYTE, TXT2BYTE_Timer, settings->timerDurationS / 60, settings->timerDurationS % 60); return strlen(pText); } uint8_t tMCvOptText_refreshO2(char* pText) { char sensorStatusColor[3]; uint8_t textPointer = 0; SSettings *pSettings = settingsGetPointer(); pText[textPointer++] = TXT_2BYTE; pText[textPointer++] = TXT2BYTE_Sensor; textPointer += snprintf(&pText[textPointer],20,"O2 %c%c",TXT_2BYTE,TXT2BYTE_Sensor); if((stateUsed->lifeData.ppO2Sensor_bar[0] != 0) || (stateUsed->lifeData.ppO2Sensor_bar[1] != 0) || (stateUsed->lifeData.ppO2Sensor_bar[2] != 0)) { pText[textPointer++] = '\t'; sensorStatusColor[0] = '\020'; sensorStatusColor[1] = '\020'; sensorStatusColor[2] = '\020'; /* Warning */ if(stateUsed->warnings.sensorOutOfBounds) sensorStatusColor[0] = '\024'; if(stateUsed->warnings.sensorOutOfBounds) sensorStatusColor[1] = '\024'; if(stateUsed->warnings.sensorOutOfBounds) sensorStatusColor[2] = '\024'; /* Grey out */ if(stateUsed->diveSettings.ppo2sensors_deactivated & 1) sensorStatusColor[0] = '\031'; if(stateUsed->diveSettings.ppo2sensors_deactivated & 2) sensorStatusColor[1] = '\031'; if(stateUsed->diveSettings.ppo2sensors_deactivated & 4) sensorStatusColor[2] = '\031'; if((pSettings->ext_sensor_map[0] == SENSOR_ANALOG) || (pSettings->ext_sensor_map[0] == SENSOR_DIGO2M) || (pSettings->ext_sensor_map[0] == SENSOR_SENTINELM)) { textPointer += snprintf(&pText[textPointer],20,"%c%01.1f \020\007",sensorStatusColor[0], stateUsed->lifeData.ppO2Sensor_bar[0]); } if((pSettings->ext_sensor_map[1] == SENSOR_ANALOG) || (pSettings->ext_sensor_map[1] == SENSOR_DIGO2M) || (pSettings->ext_sensor_map[1] == SENSOR_SENTINELM)) { textPointer += snprintf(&pText[textPointer],20,"%c%01.1f \020\007",sensorStatusColor[1], stateUsed->lifeData.ppO2Sensor_bar[1]); } if((pSettings->ext_sensor_map[2] == SENSOR_ANALOG) || (pSettings->ext_sensor_map[2] == SENSOR_DIGO2M) || (pSettings->ext_sensor_map[2] == SENSOR_SENTINELM)) { textPointer += snprintf(&pText[textPointer],20,"%c%01.1f",sensorStatusColor[2], stateUsed->lifeData.ppO2Sensor_bar[2]); } } pText[textPointer++] = '\020'; pText[textPointer] = 0; return strlen(pText); } uint8_t tMCvOptText_refreshCO2(char* pText) { char sensorStatusColor; uint8_t textPointer = 0; SSettings *pSettings = settingsGetPointer(); pText[textPointer++] = TXT_2BYTE; pText[textPointer++] = TXT2BYTE_Sensor; textPointer += snprintf(&pText[textPointer],20,"CO2 %c%c",TXT_2BYTE,TXT2BYTE_Sensor); pText[textPointer++] = '\t'; sensorStatusColor = '\020'; /* Warning */ if(stateUsed->warnings.co2High) sensorStatusColor = '\024'; /* Grey out */ if(pSettings->co2_sensor_active == 0) sensorStatusColor = '\031'; textPointer += snprintf(&pText[textPointer],20,"%c%ld \020\007",sensorStatusColor, stateUsed->lifeData.CO2_data.CO2_ppm); pText[textPointer++] = '\020'; pText[textPointer] = 0; return strlen(pText); } uint8_t tMCvOptText_BuildDynamicContentList() { uint8_t cvOptIndex = 0; uint8_t CvOptAvailable = 0; uint8_t index = 0; uint8_t SensorActive[SENSOR_END]; SSettings *settings = settingsGetPointer(); memset(SensorActive, 0, sizeof(SensorActive)); activeLines = 0; for (index = 0; index < EXT_INTERFACE_SENSOR_CNT; index++) { switch(settings->ext_sensor_map[index]) { case SENSOR_ANALOG: SensorActive[SENSOR_ANALOG] = 1; break; case SENSOR_SENTINEL: case SENSOR_DIGO2M: SensorActive[SENSOR_DIGO2] = 1; break; case SENSOR_CO2: SensorActive[SENSOR_CO2] = 1; break; #if defined ENABLE_GNSS_INTERNAL || defined ENABLE_GNSS_EXTERN case SENSOR_GNSS: SensorActive[SENSOR_GNSS] = 1; break; #endif default: break; } } do { CvOptAvailable = 0; switch(cvOptIndex) { case CVOPT_Compass: if((!t3_customview_disabled(CVIEW_T3_Compass)) || (!t3_customview_disabled(CVIEW_T3_Navigation)) || (!t7_customview_disabled(CVIEW_Compass))) { refreshFctPointerTable[activeLines] = tMCvOptText_refreshCompass; CvOptAvailable = 1; } break; case CVOPT_Timer: if(!t7_customview_disabled(CVIEW_Timer)) { refreshFctPointerTable[activeLines] = tMCvOptText_refreshTimer; CvOptAvailable = 1; } break; case CVOPT_O2_Sensor: if((SensorActive[SENSOR_ANALOG]) || (SensorActive[SENSOR_DIGO2])) { refreshFctPointerTable[activeLines] = tMCvOptText_refreshO2; CvOptAvailable = 1; } break; case CVOPT_CO2_Sensor: if(SensorActive[SENSOR_CO2]) { refreshFctPointerTable[activeLines] = tMCvOptText_refreshCO2; CvOptAvailable = 1; } break; default: break; } if(CvOptAvailable) { tMCvOption_SetOpenFnct(cvOptIndex,activeLines); activeLines++; } cvOptIndex++; } while((activeLines < MAXLINES) && (cvOptIndex != CVOPT_END)); for(index = activeLines; index < MAXLINES; index++) /* delete pointers not in use */ { tMCvOption_SetOpenFnct(CVOPT_END, index); } return activeLines; } /* Private functions ---------------------------------------------------------*/
