kopia lustrzana https://github.com/open-ham/OpenGD77
653 wiersze
22 KiB
C
653 wiersze
22 KiB
C
/*
|
|
* Copyright (C)2019 Roger Clark. VK3KYY / G4KYF
|
|
*
|
|
* 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 2 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, write to the Free Software
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
#include "functions/settings.h"
|
|
#include "user_interface/menuSystem.h"
|
|
#include "user_interface/uiLocalisation.h"
|
|
#include "user_interface/uiUtilities.h"
|
|
#include "interfaces/wdog.h"
|
|
#include "utils.h"
|
|
#include "functions/rxPowerSaving.h"
|
|
|
|
static void updateScreen(bool isFirstRun);
|
|
static void handleEvent(uiEvent_t *ev);
|
|
|
|
static menuStatus_t menuOptionsExitCode = MENU_STATUS_SUCCESS;
|
|
enum OPTIONS_MENU_LIST { OPTIONS_MENU_TX_FREQ_LIMITS = 0U,
|
|
OPTIONS_MENU_KEYPAD_TIMER_LONG, OPTIONS_MENU_KEYPAD_TIMER_REPEAT, OPTIONS_MENU_DMR_MONITOR_CAPTURE_TIMEOUT,
|
|
OPTIONS_MENU_SCAN_DELAY, OPTIONS_MENU_SCAN_STEP_TIME, OPTIONS_MENU_SCAN_MODE,
|
|
OPTIONS_MENU_SQUELCH_DEFAULT_VHF, OPTIONS_MENU_SQUELCH_DEFAULT_220MHz, OPTIONS_MENU_SQUELCH_DEFAULT_UHF,
|
|
OPTIONS_MENU_PTT_TOGGLE, OPTIONS_MENU_HOTSPOT_TYPE, OPTIONS_MENU_TALKER_ALIAS_TX,
|
|
OPTIONS_MENU_PRIVATE_CALLS,
|
|
OPTIONS_MENU_USER_POWER,
|
|
OPTIONS_MENU_TEMPERATURE_CALIBRATON,
|
|
OPTIONS_MENU_ECO_LEVEL,
|
|
NUM_OPTIONS_MENU_ITEMS};
|
|
|
|
menuStatus_t menuOptions(uiEvent_t *ev, bool isFirstRun)
|
|
{
|
|
if (isFirstRun)
|
|
{
|
|
menuDataGlobal.menuOptionsSetQuickkey = 0;
|
|
menuDataGlobal.menuOptionsTimeout = 0;
|
|
menuDataGlobal.newOptionSelected = true;
|
|
menuDataGlobal.endIndex = NUM_OPTIONS_MENU_ITEMS;
|
|
|
|
if (originalNonVolatileSettings.magicNumber == 0xDEADBEEF)
|
|
{
|
|
// Store original settings, used on cancel event.
|
|
memcpy(&originalNonVolatileSettings, &nonVolatileSettings, sizeof(settingsStruct_t));
|
|
}
|
|
|
|
voicePromptsInit();
|
|
voicePromptsAppendPrompt(PROMPT_SILENCE);
|
|
voicePromptsAppendPrompt(PROMPT_SILENCE);
|
|
voicePromptsAppendLanguageString(¤tLanguage->options);
|
|
voicePromptsAppendLanguageString(¤tLanguage->menu);
|
|
voicePromptsAppendPrompt(PROMPT_SILENCE);
|
|
voicePromptsAppendPrompt(PROMPT_SILENCE);
|
|
|
|
updateScreen(true);
|
|
return (MENU_STATUS_LIST_TYPE | MENU_STATUS_SUCCESS);
|
|
}
|
|
else
|
|
{
|
|
menuOptionsExitCode = MENU_STATUS_SUCCESS;
|
|
|
|
if (ev->hasEvent || (menuDataGlobal.menuOptionsTimeout > 0))
|
|
{
|
|
handleEvent(ev);
|
|
}
|
|
}
|
|
return menuOptionsExitCode;
|
|
}
|
|
|
|
static void updateScreen(bool isFirstRun)
|
|
{
|
|
int mNum = 0;
|
|
static const int bufferLen = 17;
|
|
char buf[bufferLen];
|
|
char buf2[bufferLen];
|
|
char * const *leftSide = NULL;// initialise to please the compiler
|
|
char * const *rightSideConst = NULL;// initialise to please the compiler
|
|
char rightSideVar[bufferLen];
|
|
voicePrompt_t rightSideUnitsPrompt;
|
|
const char * rightSideUnitsStr;
|
|
|
|
ucClearBuf();
|
|
bool settingOption = uiShowQuickKeysChoices(buf, bufferLen,currentLanguage->options);
|
|
|
|
// Can only display 3 of the options at a time menu at -1, 0 and +1
|
|
for(int i = -1; i <= 1; i++)
|
|
{
|
|
if ((settingOption == false) || (i == 0))
|
|
{
|
|
mNum = menuGetMenuOffset(NUM_OPTIONS_MENU_ITEMS, i);
|
|
buf[0] = 0;
|
|
buf[2] = 0;
|
|
leftSide = NULL;
|
|
rightSideConst = NULL;
|
|
rightSideVar[0] = 0;
|
|
rightSideUnitsPrompt = PROMPT_SILENCE;// use PROMPT_SILENCE as flag that the unit has not been set
|
|
rightSideUnitsStr = NULL;
|
|
|
|
switch(mNum)
|
|
{
|
|
case OPTIONS_MENU_TX_FREQ_LIMITS:// Tx Freq limits
|
|
leftSide = (char * const *)¤tLanguage->band_limits;
|
|
switch(nonVolatileSettings.txFreqLimited)
|
|
{
|
|
case BAND_LIMITS_NONE:
|
|
rightSideConst = (char * const *)(¤tLanguage->off);
|
|
break;
|
|
case BAND_LIMITS_ON_LEGACY_DEFAULT:
|
|
rightSideConst = (char * const *)(¤tLanguage->on);
|
|
break;
|
|
case BAND_LIMITS_FROM_CPS:
|
|
strcpy(rightSideVar,"CPS");
|
|
break;
|
|
}
|
|
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_LONG:// Timer longpress
|
|
leftSide = (char * const *)¤tLanguage->key_long;
|
|
snprintf(rightSideVar, bufferLen, "%1d.%1d", nonVolatileSettings.keypadTimerLong / 10, nonVolatileSettings.keypadTimerLong % 10);
|
|
rightSideUnitsPrompt = PROMPT_SECONDS;
|
|
rightSideUnitsStr = "s";
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_REPEAT:// Timer repeat
|
|
leftSide = (char * const *)¤tLanguage->key_repeat;
|
|
snprintf(rightSideVar, bufferLen, "%1d.%1d", nonVolatileSettings.keypadTimerRepeat/10, nonVolatileSettings.keypadTimerRepeat % 10);
|
|
rightSideUnitsPrompt = PROMPT_SECONDS;
|
|
rightSideUnitsStr = "s";
|
|
break;
|
|
case OPTIONS_MENU_DMR_MONITOR_CAPTURE_TIMEOUT:// DMR filtr timeout repeat
|
|
leftSide = (char * const *)¤tLanguage->dmr_filter_timeout;
|
|
snprintf(rightSideVar, bufferLen, "%d", nonVolatileSettings.dmrCaptureTimeout);
|
|
rightSideUnitsPrompt = PROMPT_SECONDS;
|
|
rightSideUnitsStr = "s";
|
|
break;
|
|
case OPTIONS_MENU_SCAN_DELAY:// Scan hold and pause time
|
|
leftSide = (char * const *)¤tLanguage->scan_delay;
|
|
snprintf(rightSideVar, bufferLen, "%d", nonVolatileSettings.scanDelay);
|
|
rightSideUnitsPrompt = PROMPT_SECONDS;
|
|
rightSideUnitsStr = "s";
|
|
break;
|
|
case OPTIONS_MENU_SCAN_STEP_TIME:// Scan step time
|
|
leftSide = (char * const *)¤tLanguage->scan_dwell_time;
|
|
snprintf(rightSideVar, bufferLen, "%d", settingsGetScanStepTimeMilliseconds());
|
|
rightSideUnitsPrompt = PROMPT_MILLISECONDS;
|
|
rightSideUnitsStr = "ms";
|
|
break;
|
|
|
|
case OPTIONS_MENU_SCAN_MODE:// scanning mode
|
|
leftSide = (char * const *)¤tLanguage->scan_mode;
|
|
{
|
|
const char * const *scanModes[] = { ¤tLanguage->hold, ¤tLanguage->pause, ¤tLanguage->stop };
|
|
rightSideConst = (char * const *)scanModes[nonVolatileSettings.scanModePause];
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_VHF:
|
|
leftSide = (char * const *)¤tLanguage->squelch_VHF;
|
|
snprintf(rightSideVar, bufferLen, "%d%%", (nonVolatileSettings.squelchDefaults[RADIO_BAND_VHF] - 1) * 5);// 5% steps
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_220MHz:
|
|
leftSide = (char * const *)¤tLanguage->squelch_220;
|
|
snprintf(rightSideVar, bufferLen, "%d%%", (nonVolatileSettings.squelchDefaults[RADIO_BAND_220MHz] - 1) * 5);// 5% steps
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_UHF:
|
|
leftSide = (char * const *)¤tLanguage->squelch_UHF;
|
|
snprintf(rightSideVar, bufferLen, "%d%%", (nonVolatileSettings.squelchDefaults[RADIO_BAND_UHF] - 1) * 5);// 5% steps
|
|
break;
|
|
case OPTIONS_MENU_PTT_TOGGLE:
|
|
leftSide = (char * const *)¤tLanguage->ptt_toggle;
|
|
rightSideConst = (char * const *)(settingsIsOptionBitSet(BIT_PTT_LATCH) ? ¤tLanguage->on : ¤tLanguage->off);
|
|
break;
|
|
case OPTIONS_MENU_HOTSPOT_TYPE:
|
|
leftSide = (char * const *)¤tLanguage->hotspot_mode;
|
|
#if defined(PLATFORM_RD5R)
|
|
rightSideConst = (char * const *)¤tLanguage->n_a;
|
|
#else
|
|
{
|
|
const char *hsTypes[] = {"MMDVM", "BlueDV" };
|
|
if (nonVolatileSettings.hotspotType == 0)
|
|
{
|
|
rightSideConst = (char * const *)¤tLanguage->off;
|
|
}
|
|
else
|
|
{
|
|
snprintf(rightSideVar, bufferLen, "%s", hsTypes[nonVolatileSettings.hotspotType - 1]);
|
|
}
|
|
}
|
|
#endif
|
|
break;
|
|
case OPTIONS_MENU_TALKER_ALIAS_TX:
|
|
leftSide = (char * const *)¤tLanguage->transmitTalkerAlias;
|
|
rightSideConst = (char * const *)(settingsIsOptionBitSet(BIT_TRANSMIT_TALKER_ALIAS) ? ¤tLanguage->on : ¤tLanguage->off);
|
|
break;
|
|
case OPTIONS_MENU_PRIVATE_CALLS:
|
|
leftSide = (char * const *)¤tLanguage->private_call_handling;
|
|
const char * const *allowPCOptions[] = { ¤tLanguage->off, ¤tLanguage->on, ¤tLanguage->ptt, ¤tLanguage->Auto};
|
|
rightSideConst = (char * const *)allowPCOptions[nonVolatileSettings.privateCalls];
|
|
break;
|
|
case OPTIONS_MENU_USER_POWER:
|
|
leftSide = (char * const *)¤tLanguage->user_power;
|
|
snprintf(rightSideVar, bufferLen, "%d", (nonVolatileSettings.userPower));
|
|
break;
|
|
case OPTIONS_MENU_TEMPERATURE_CALIBRATON:
|
|
{
|
|
int absValue = abs(nonVolatileSettings.temperatureCalibration);
|
|
leftSide = (char * const *)¤tLanguage->temperature_calibration;
|
|
snprintf(buf2, bufferLen, "%c%d.%d", (nonVolatileSettings.temperatureCalibration >= 0 ? '+' : '-'), ((absValue) / 2), ((absValue % 2) * 5));
|
|
snprintf(rightSideVar, bufferLen, "%s%s", buf2, currentLanguage->celcius);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_ECO_LEVEL:
|
|
leftSide = (char * const *)¤tLanguage->eco_level;
|
|
snprintf(rightSideVar, bufferLen, "%d", (nonVolatileSettings.ecoLevel));
|
|
break;
|
|
}
|
|
|
|
snprintf(buf, bufferLen, "%s:%s", *leftSide, (rightSideVar[0] ? rightSideVar : (rightSideConst ? *rightSideConst : "")));
|
|
|
|
if (i == 0)
|
|
{
|
|
bool wasPlaying = voicePromptsIsPlaying();
|
|
|
|
if (!isFirstRun && (menuDataGlobal.menuOptionsSetQuickkey == 0))
|
|
{
|
|
voicePromptsInit();
|
|
}
|
|
|
|
if (!wasPlaying || menuDataGlobal.newOptionSelected)
|
|
{
|
|
voicePromptsAppendLanguageString((const char * const *)leftSide);
|
|
}
|
|
|
|
if ((rightSideVar[0] != 0) || ((rightSideVar[0] == 0) && (rightSideConst == NULL)))
|
|
{
|
|
if (mNum == OPTIONS_MENU_TEMPERATURE_CALIBRATON)
|
|
{
|
|
voicePromptsAppendString(buf2);
|
|
voicePromptsAppendLanguageString(¤tLanguage->celcius);
|
|
}
|
|
else
|
|
{
|
|
voicePromptsAppendString(rightSideVar);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
voicePromptsAppendLanguageString((const char * const *)rightSideConst);
|
|
}
|
|
|
|
if (rightSideUnitsPrompt != PROMPT_SILENCE)
|
|
{
|
|
voicePromptsAppendPrompt(rightSideUnitsPrompt);
|
|
}
|
|
|
|
if (rightSideUnitsStr != NULL)
|
|
{
|
|
strncat(rightSideVar, rightSideUnitsStr, bufferLen);
|
|
}
|
|
|
|
if (menuDataGlobal.menuOptionsTimeout != -1)
|
|
{
|
|
promptsPlayNotAfterTx();
|
|
}
|
|
else
|
|
{
|
|
menuDataGlobal.menuOptionsTimeout = 0;// clear flag indicating that a QuickKey has just been set
|
|
}
|
|
}
|
|
|
|
// QuickKeys
|
|
if (menuDataGlobal.menuOptionsTimeout > 0)
|
|
{
|
|
menuDisplaySettingOption(*leftSide, (rightSideVar[0] ? rightSideVar : *rightSideConst));
|
|
}
|
|
else
|
|
{
|
|
if (rightSideUnitsStr != NULL)
|
|
{
|
|
strncat(buf, rightSideUnitsStr, bufferLen);
|
|
}
|
|
|
|
menuDisplayEntry(i, mNum, buf);
|
|
}
|
|
}
|
|
}
|
|
|
|
ucRender();
|
|
}
|
|
|
|
static void handleEvent(uiEvent_t *ev)
|
|
{
|
|
bool isDirty = false;
|
|
|
|
if (ev->events & BUTTON_EVENT)
|
|
{
|
|
if (repeatVoicePromptOnSK1(ev))
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
|
|
if ((menuDataGlobal.menuOptionsTimeout > 0) && (!BUTTONCHECK_DOWN(ev, BUTTON_SK2)))
|
|
{
|
|
menuDataGlobal.menuOptionsTimeout--;
|
|
if (menuDataGlobal.menuOptionsTimeout == 0)
|
|
{
|
|
resetOriginalSettingsData();
|
|
menuSystemPopPreviousMenu();
|
|
return;
|
|
}
|
|
}
|
|
if (ev->events & FUNCTION_EVENT)
|
|
{
|
|
isDirty = true;
|
|
if ((QUICKKEY_TYPE(ev->function) == QUICKKEY_MENU) && (QUICKKEY_ENTRYID(ev->function) < NUM_OPTIONS_MENU_ITEMS))
|
|
{
|
|
menuDataGlobal.currentItemIndex = QUICKKEY_ENTRYID(ev->function);
|
|
}
|
|
if ((QUICKKEY_FUNCTIONID(ev->function) != 0))
|
|
{
|
|
menuDataGlobal.menuOptionsTimeout = 1000;
|
|
}
|
|
}
|
|
|
|
if ((ev->events & KEY_EVENT) && (menuDataGlobal.menuOptionsSetQuickkey == 0) && (menuDataGlobal.menuOptionsTimeout == 0))
|
|
{
|
|
if (KEYCHECK_PRESS(ev->keys, KEY_DOWN) && (menuDataGlobal.endIndex != 0))
|
|
{
|
|
isDirty = true;
|
|
menuSystemMenuIncrement(&menuDataGlobal.currentItemIndex, NUM_OPTIONS_MENU_ITEMS);
|
|
menuDataGlobal.newOptionSelected = true;
|
|
menuOptionsExitCode |= MENU_STATUS_LIST_TYPE;
|
|
}
|
|
else if (KEYCHECK_PRESS(ev->keys, KEY_UP))
|
|
{
|
|
isDirty = true;
|
|
menuSystemMenuDecrement(&menuDataGlobal.currentItemIndex, NUM_OPTIONS_MENU_ITEMS);
|
|
menuDataGlobal.newOptionSelected = true;
|
|
menuOptionsExitCode |= MENU_STATUS_LIST_TYPE;
|
|
}
|
|
else if (KEYCHECK_SHORTUP(ev->keys, KEY_GREEN))
|
|
{
|
|
settingsSaveIfNeeded(true);
|
|
resetOriginalSettingsData();
|
|
rxPowerSavingSetLevel(nonVolatileSettings.ecoLevel);
|
|
menuSystemPopAllAndDisplayRootMenu();
|
|
return;
|
|
}
|
|
else if (KEYCHECK_SHORTUP(ev->keys, KEY_RED))
|
|
{
|
|
// Restore original settings.
|
|
memcpy(&nonVolatileSettings, &originalNonVolatileSettings, sizeof(settingsStruct_t));
|
|
settingsSaveIfNeeded(true);
|
|
trxUpdate_PA_DAC_Drive();
|
|
resetOriginalSettingsData();
|
|
menuSystemPopPreviousMenu();
|
|
return;
|
|
}
|
|
else if (KEYCHECK_SHORTUP_NUMBER(ev->keys) && BUTTONCHECK_DOWN(ev, BUTTON_SK2))
|
|
{
|
|
menuDataGlobal.menuOptionsSetQuickkey = ev->keys.key;
|
|
isDirty = true;
|
|
}
|
|
}
|
|
if ((ev->events & (KEY_EVENT | FUNCTION_EVENT)) && (menuDataGlobal.menuOptionsSetQuickkey == 0))
|
|
{
|
|
|
|
if (KEYCHECK_PRESS(ev->keys, KEY_RIGHT) || (QUICKKEY_FUNCTIONID(ev->function) == FUNC_RIGHT))
|
|
{
|
|
isDirty = true;
|
|
menuDataGlobal.newOptionSelected = false;
|
|
switch(menuDataGlobal.currentItemIndex)
|
|
{
|
|
case OPTIONS_MENU_TX_FREQ_LIMITS:
|
|
if (nonVolatileSettings.txFreqLimited < BAND_LIMITS_FROM_CPS)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.txFreqLimited, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_LONG:
|
|
if (nonVolatileSettings.keypadTimerLong < 90)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.keypadTimerLong, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_REPEAT:
|
|
if (nonVolatileSettings.keypadTimerRepeat < 90)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.keypadTimerRepeat, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_DMR_MONITOR_CAPTURE_TIMEOUT:
|
|
if (nonVolatileSettings.dmrCaptureTimeout < 90)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.dmrCaptureTimeout, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_DELAY:
|
|
if (nonVolatileSettings.scanDelay < 30)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.scanDelay, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_STEP_TIME:
|
|
if (nonVolatileSettings.scanStepTime < 15) // <30> + (15 * 30ms) MAX
|
|
{
|
|
settingsIncrement(nonVolatileSettings.scanStepTime, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_MODE:
|
|
if (nonVolatileSettings.scanModePause < SCAN_MODE_STOP)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.scanModePause, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_VHF:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_VHF] < CODEPLUG_MAX_VARIABLE_SQUELCH)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_VHF], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_220MHz:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_220MHz] < CODEPLUG_MAX_VARIABLE_SQUELCH)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_220MHz], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_UHF:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_UHF] < CODEPLUG_MAX_VARIABLE_SQUELCH)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_UHF], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_PTT_TOGGLE:
|
|
if (settingsIsOptionBitSet(BIT_PTT_LATCH) == false)
|
|
{
|
|
settingsSetOptionBit(BIT_PTT_LATCH, true);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_HOTSPOT_TYPE:
|
|
#if !defined(PLATFORM_RD5R)
|
|
if (nonVolatileSettings.hotspotType < HOTSPOT_TYPE_BLUEDV)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.hotspotType, 1);
|
|
}
|
|
#endif
|
|
break;
|
|
case OPTIONS_MENU_TALKER_ALIAS_TX:
|
|
if (settingsIsOptionBitSet(BIT_TRANSMIT_TALKER_ALIAS) == false)
|
|
{
|
|
settingsSetOptionBit(BIT_TRANSMIT_TALKER_ALIAS, true);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_PRIVATE_CALLS:
|
|
// Note. Currently the "AUTO" option is not available
|
|
if (nonVolatileSettings.privateCalls < ALLOW_PRIVATE_CALLS_PTT)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.privateCalls, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_USER_POWER:
|
|
{
|
|
int newVal = (int)nonVolatileSettings.userPower;
|
|
|
|
// Not the real max value of 4096, but trxUpdate_PA_DAC_Drive() will auto limit it to 4096
|
|
// and it makes the logic easier and there is no functional difference
|
|
newVal = SAFE_MIN((newVal + (BUTTONCHECK_DOWN(ev, BUTTON_SK2) ? 10 : 100)), 4100);
|
|
|
|
settingsSet(nonVolatileSettings.userPower, newVal);
|
|
trxUpdate_PA_DAC_Drive();
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_TEMPERATURE_CALIBRATON:
|
|
if (nonVolatileSettings.temperatureCalibration < 20)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.temperatureCalibration, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_ECO_LEVEL:
|
|
if (nonVolatileSettings.ecoLevel < ECO_LEVEL_MAX)
|
|
{
|
|
settingsIncrement(nonVolatileSettings.ecoLevel, 1);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
else if (KEYCHECK_PRESS(ev->keys, KEY_LEFT) || (QUICKKEY_FUNCTIONID(ev->function) == FUNC_LEFT))
|
|
{
|
|
isDirty = true;
|
|
menuDataGlobal.newOptionSelected = false;
|
|
switch(menuDataGlobal.currentItemIndex)
|
|
{
|
|
case OPTIONS_MENU_TX_FREQ_LIMITS:
|
|
if (nonVolatileSettings.txFreqLimited > BAND_LIMITS_NONE)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.txFreqLimited, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_LONG:
|
|
if (nonVolatileSettings.keypadTimerLong > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.keypadTimerLong, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_KEYPAD_TIMER_REPEAT:
|
|
if (nonVolatileSettings.keypadTimerRepeat > 1) // Don't set it to zero, otherwise watchdog may kicks in.
|
|
{
|
|
settingsDecrement(nonVolatileSettings.keypadTimerRepeat, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_DMR_MONITOR_CAPTURE_TIMEOUT:
|
|
if (nonVolatileSettings.dmrCaptureTimeout > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.dmrCaptureTimeout, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_DELAY:
|
|
if (nonVolatileSettings.scanDelay > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.scanDelay, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_STEP_TIME:
|
|
if (nonVolatileSettings.scanStepTime > 0)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.scanStepTime, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SCAN_MODE:
|
|
if (nonVolatileSettings.scanModePause > SCAN_MODE_HOLD)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.scanModePause, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_VHF:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_VHF] > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_VHF], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_220MHz:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_220MHz] > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_220MHz], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_SQUELCH_DEFAULT_UHF:
|
|
if (nonVolatileSettings.squelchDefaults[RADIO_BAND_UHF] > 1)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.squelchDefaults[RADIO_BAND_UHF], 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_PTT_TOGGLE:
|
|
if (settingsIsOptionBitSet(BIT_PTT_LATCH))
|
|
{
|
|
settingsSetOptionBit(BIT_PTT_LATCH, false);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_HOTSPOT_TYPE:
|
|
#if !defined(PLATFORM_RD5R)
|
|
if (nonVolatileSettings.hotspotType > HOTSPOT_TYPE_OFF)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.hotspotType, 1);
|
|
}
|
|
#endif
|
|
break;
|
|
case OPTIONS_MENU_TALKER_ALIAS_TX:
|
|
if (settingsIsOptionBitSet(BIT_TRANSMIT_TALKER_ALIAS))
|
|
{
|
|
settingsSetOptionBit(BIT_TRANSMIT_TALKER_ALIAS, false);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_PRIVATE_CALLS:
|
|
if (nonVolatileSettings.privateCalls > 0)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.privateCalls, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_USER_POWER:
|
|
{
|
|
int newVal = (int)nonVolatileSettings.userPower;
|
|
|
|
// Not the real max value of 4096, but trxUpdate_PA_DAC_Drive() will auto limit it to 4096
|
|
// and it makes the logic easier and there is no functional difference
|
|
newVal = SAFE_MAX((newVal - (BUTTONCHECK_DOWN(ev, BUTTON_SK2) ? 10 : 100)), 0);
|
|
|
|
settingsSet(nonVolatileSettings.userPower, newVal);
|
|
trxUpdate_PA_DAC_Drive();
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_TEMPERATURE_CALIBRATON:
|
|
if (nonVolatileSettings.temperatureCalibration > -20)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.temperatureCalibration, 1);
|
|
}
|
|
break;
|
|
case OPTIONS_MENU_ECO_LEVEL:
|
|
if (nonVolatileSettings.ecoLevel > 0)
|
|
{
|
|
settingsDecrement(nonVolatileSettings.ecoLevel, 1);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
else if ((ev->keys.event & KEY_MOD_PRESS) && (menuDataGlobal.menuOptionsTimeout > 0))
|
|
{
|
|
menuDataGlobal.menuOptionsTimeout = 0;
|
|
resetOriginalSettingsData();
|
|
menuSystemPopPreviousMenu();
|
|
return;
|
|
}
|
|
}
|
|
|
|
if ((ev->events & KEY_EVENT) && (menuDataGlobal.menuOptionsSetQuickkey != 0) && (menuDataGlobal.menuOptionsTimeout == 0))
|
|
{
|
|
if (KEYCHECK_SHORTUP(ev->keys, KEY_RED))
|
|
{
|
|
menuDataGlobal.menuOptionsSetQuickkey = 0;
|
|
menuDataGlobal.menuOptionsTimeout = 0;
|
|
menuOptionsExitCode |= MENU_STATUS_ERROR;
|
|
}
|
|
else if (KEYCHECK_SHORTUP(ev->keys, KEY_GREEN))
|
|
{
|
|
saveQuickkeyMenuIndex(menuDataGlobal.menuOptionsSetQuickkey, menuSystemGetCurrentMenuNumber(), menuDataGlobal.currentItemIndex, 0);
|
|
menuDataGlobal.menuOptionsSetQuickkey = 0;
|
|
}
|
|
else if (KEYCHECK_SHORTUP(ev->keys, KEY_LEFT))
|
|
{
|
|
saveQuickkeyMenuIndex(menuDataGlobal.menuOptionsSetQuickkey, menuSystemGetCurrentMenuNumber(), menuDataGlobal.currentItemIndex, FUNC_LEFT);
|
|
menuDataGlobal.menuOptionsSetQuickkey = 0;
|
|
}
|
|
else if (KEYCHECK_SHORTUP(ev->keys, KEY_RIGHT))
|
|
{
|
|
saveQuickkeyMenuIndex(menuDataGlobal.menuOptionsSetQuickkey, menuSystemGetCurrentMenuNumber(), menuDataGlobal.currentItemIndex, FUNC_RIGHT);
|
|
menuDataGlobal.menuOptionsSetQuickkey = 0;
|
|
}
|
|
isDirty = true;
|
|
}
|
|
|
|
if (isDirty)
|
|
{
|
|
updateScreen(false);
|
|
}
|
|
}
|