mirror of
https://github.com/opentx/opentx.git
synced 2025-07-23 16:25:16 +03:00
Makefile option for Timers count
This commit is contained in:
parent
be024051e7
commit
33dfcbe2f4
6 changed files with 131 additions and 84 deletions
|
@ -54,10 +54,12 @@
|
||||||
#define FAI_CHOICE
|
#define FAI_CHOICE
|
||||||
#define LUA
|
#define LUA
|
||||||
#define LUA_MODEL_SCRIPTS
|
#define LUA_MODEL_SCRIPTS
|
||||||
#define EEPROM_VARIANT 3
|
|
||||||
#define HAPTIC
|
#define HAPTIC
|
||||||
#define REVPLUS
|
#define REVPLUS
|
||||||
#define OVERRIDE_CHANNEL_FUNCTION
|
#define OVERRIDE_CHANNEL_FUNCTION
|
||||||
|
#define TIMERS 3
|
||||||
|
|
||||||
|
#define EEPROM_VARIANT 3
|
||||||
#define FLAVOUR "taranis-plus"
|
#define FLAVOUR "taranis-plus"
|
||||||
|
|
||||||
#undef min
|
#undef min
|
||||||
|
|
|
@ -54,11 +54,13 @@
|
||||||
#define FAI_CHOICE
|
#define FAI_CHOICE
|
||||||
#define LUA
|
#define LUA
|
||||||
#define LUA_MODEL_SCRIPTS
|
#define LUA_MODEL_SCRIPTS
|
||||||
#define EEPROM_VARIANT 3
|
|
||||||
#define HAPTIC
|
#define HAPTIC
|
||||||
#define REVPLUS
|
#define REVPLUS
|
||||||
#define REV9E
|
#define REV9E
|
||||||
#define OVERRIDE_CHANNEL_FUNCTION
|
#define OVERRIDE_CHANNEL_FUNCTION
|
||||||
|
#define TIMERS 3
|
||||||
|
|
||||||
|
#define EEPROM_VARIANT 3
|
||||||
#define FLAVOUR "taranis-x9e"
|
#define FLAVOUR "taranis-x9e"
|
||||||
|
|
||||||
#undef min
|
#undef min
|
||||||
|
|
|
@ -264,6 +264,10 @@ DEBUG = NO
|
||||||
# Values = YES, NO
|
# Values = YES, NO
|
||||||
SPORT_FILE_LOG = NO
|
SPORT_FILE_LOG = NO
|
||||||
|
|
||||||
|
# Timers Count
|
||||||
|
# Values = 1, 2, 3 (on ARM boards)
|
||||||
|
TIMERS = 2
|
||||||
|
|
||||||
# Flight Modes
|
# Flight Modes
|
||||||
# Values = YES, NO
|
# Values = YES, NO
|
||||||
FLIGHT_MODES = YES
|
FLIGHT_MODES = YES
|
||||||
|
@ -1064,6 +1068,8 @@ ifeq ($(THR_TRACE), YES)
|
||||||
CPPDEFS += -DTHRTRACE
|
CPPDEFS += -DTHRTRACE
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
CPPDEFS += -DTIMERS=$(TIMERS)
|
||||||
|
|
||||||
ifeq ($(FLIGHT_MODES), YES)
|
ifeq ($(FLIGHT_MODES), YES)
|
||||||
CPPDEFS += -DFLIGHT_MODES
|
CPPDEFS += -DFLIGHT_MODES
|
||||||
GUIMODELSRC += gui/$(GUIDIRECTORY)/menu_model_flightmodes.cpp
|
GUIMODELSRC += gui/$(GUIDIRECTORY)/menu_model_flightmodes.cpp
|
||||||
|
|
|
@ -46,16 +46,20 @@ enum menuModelSetupItems {
|
||||||
CASE_PERSISTENT_TIMERS(ITEM_MODEL_TIMER1_PERSISTENT)
|
CASE_PERSISTENT_TIMERS(ITEM_MODEL_TIMER1_PERSISTENT)
|
||||||
ITEM_MODEL_TIMER1_MINUTE_BEEP,
|
ITEM_MODEL_TIMER1_MINUTE_BEEP,
|
||||||
ITEM_MODEL_TIMER1_COUNTDOWN_BEEP,
|
ITEM_MODEL_TIMER1_COUNTDOWN_BEEP,
|
||||||
|
#if TIMERS > 1
|
||||||
ITEM_MODEL_TIMER2,
|
ITEM_MODEL_TIMER2,
|
||||||
ITEM_MODEL_TIMER2_NAME,
|
ITEM_MODEL_TIMER2_NAME,
|
||||||
CASE_PERSISTENT_TIMERS(ITEM_MODEL_TIMER2_PERSISTENT)
|
CASE_PERSISTENT_TIMERS(ITEM_MODEL_TIMER2_PERSISTENT)
|
||||||
ITEM_MODEL_TIMER2_MINUTE_BEEP,
|
ITEM_MODEL_TIMER2_MINUTE_BEEP,
|
||||||
ITEM_MODEL_TIMER2_COUNTDOWN_BEEP,
|
ITEM_MODEL_TIMER2_COUNTDOWN_BEEP,
|
||||||
|
#endif
|
||||||
|
#if TIMERS > 2
|
||||||
ITEM_MODEL_TIMER3,
|
ITEM_MODEL_TIMER3,
|
||||||
ITEM_MODEL_TIMER3_NAME,
|
ITEM_MODEL_TIMER3_NAME,
|
||||||
ITEM_MODEL_TIMER3_PERSISTENT,
|
ITEM_MODEL_TIMER3_PERSISTENT,
|
||||||
ITEM_MODEL_TIMER3_MINUTE_BEEP,
|
ITEM_MODEL_TIMER3_MINUTE_BEEP,
|
||||||
ITEM_MODEL_TIMER3_COUNTDOWN_BEEP,
|
ITEM_MODEL_TIMER3_COUNTDOWN_BEEP,
|
||||||
|
#endif
|
||||||
ITEM_MODEL_EXTENDED_LIMITS,
|
ITEM_MODEL_EXTENDED_LIMITS,
|
||||||
ITEM_MODEL_EXTENDED_TRIMS,
|
ITEM_MODEL_EXTENDED_TRIMS,
|
||||||
ITEM_MODEL_DISPLAY_TRIMS,
|
ITEM_MODEL_DISPLAY_TRIMS,
|
||||||
|
@ -120,84 +124,14 @@ void onModelSetupBitmapMenu(const char *result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CURRENT_MODULE_EDITED(k) (k>=ITEM_MODEL_TRAINER_LABEL ? TRAINER_MODULE : (k>=ITEM_MODEL_EXTERNAL_MODULE_LABEL ? EXTERNAL_MODULE : INTERNAL_MODULE))
|
void editTimerMode(int timerIdx, coord_t y, LcdFlags attr, uint8_t event)
|
||||||
|
|
||||||
void menuModelSetup(uint8_t event)
|
|
||||||
{
|
{
|
||||||
horzpos_t l_posHorz = m_posHorz;
|
|
||||||
#define IF_INTERNAL_MODULE_ON(x) (g_model.moduleData[INTERNAL_MODULE].rfProtocol == RF_PROTO_OFF ? HIDDEN_ROW : (uint8_t)(x))
|
|
||||||
#define IF_EXTERNAL_MODULE_ON(x) (g_model.externalModule == MODULE_TYPE_NONE ? HIDDEN_ROW : (uint8_t)(x))
|
|
||||||
#define IF_TRAINER_ON(x) (g_model.trainerMode == TRAINER_MODE_SLAVE ? (uint8_t)(x) : HIDDEN_ROW)
|
|
||||||
#define IF_EXTERNAL_MODULE_XJT(x) (IS_MODULE_XJT(EXTERNAL_MODULE) ? (uint8_t)x : HIDDEN_ROW)
|
|
||||||
#define IS_D8_RX(x) (g_model.moduleData[x].rfProtocol == RF_PROTO_D8)
|
|
||||||
#define INTERNAL_MODULE_CHANNELS_ROWS() IF_INTERNAL_MODULE_ON(1)
|
|
||||||
#define EXTERNAL_MODULE_CHANNELS_ROWS() IF_EXTERNAL_MODULE_ON(IS_MODULE_DSM2(EXTERNAL_MODULE) ? (uint8_t)0 : (uint8_t)1)
|
|
||||||
#define TRAINER_CHANNELS_ROWS() IF_TRAINER_ON(1)
|
|
||||||
#define PORT_CHANNELS_ROWS(x) (x==INTERNAL_MODULE ? INTERNAL_MODULE_CHANNELS_ROWS() : (x==EXTERNAL_MODULE ? EXTERNAL_MODULE_CHANNELS_ROWS() : TRAINER_CHANNELS_ROWS()))
|
|
||||||
#define FAILSAFE_ROWS(x) ((g_model.moduleData[x].rfProtocol==RF_PROTO_X16 || g_model.moduleData[x].rfProtocol==RF_PROTO_LR12) ? (g_model.moduleData[x].failsafeMode==FAILSAFE_CUSTOM ? (uint8_t)1 : (uint8_t)0) : HIDDEN_ROW)
|
|
||||||
#define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0)
|
|
||||||
#define TIMER_ROWS 2|NAVIGATION_LINE_BY_LINE, 0, CASE_PERSISTENT_TIMERS(0) 0, 0
|
|
||||||
bool CURSOR_ON_CELL = (m_posHorz >= 0);
|
|
||||||
MENU_TAB({ 0, 0, TIMER_ROWS, TIMER_ROWS, TIMER_ROWS, 0, 1, 0, 0, LABEL(Throttle), 0, 0, 0, LABEL(PreflightCheck), 0, 0, uint8_t(NAVIGATION_LINE_BY_LINE|getSwitchWarningsAllowed()), ONE_2x2POS_DEFINED() ? TITLE_ROW : HIDDEN_ROW, POT_WARN_ITEMS(), NAVIGATION_LINE_BY_LINE|(NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1), 0, LABEL(InternalModule), 0, IF_INTERNAL_MODULE_ON(1), IF_INTERNAL_MODULE_ON(IS_D8_RX(0) ? (uint8_t)1 : (uint8_t)2), IF_INTERNAL_MODULE_ON(FAILSAFE_ROWS(INTERNAL_MODULE)), LABEL(ExternalModule), (IS_MODULE_XJT(EXTERNAL_MODULE) || IS_MODULE_DSM2(EXTERNAL_MODULE)) ? (uint8_t)1 : (uint8_t)0, EXTERNAL_MODULE_CHANNELS_ROWS(), (IS_MODULE_XJT(EXTERNAL_MODULE) && IS_D8_RX(EXTERNAL_MODULE)) ? (uint8_t)1 : (IS_MODULE_PPM(EXTERNAL_MODULE) || IS_MODULE_XJT(EXTERNAL_MODULE) || IS_MODULE_DSM2(EXTERNAL_MODULE)) ? (uint8_t)2 : HIDDEN_ROW, IF_EXTERNAL_MODULE_XJT(FAILSAFE_ROWS(EXTERNAL_MODULE)), LABEL(Trainer), 0, TRAINER_CHANNELS_ROWS(), IF_TRAINER_ON(2)});
|
|
||||||
|
|
||||||
MENU_CHECK(STR_MENUSETUP, menuTabModel, e_ModelSetup, ITEM_MODEL_SETUP_MAX);
|
|
||||||
|
|
||||||
#if (defined(DSM2) || defined(PXX))
|
|
||||||
if (menuEvent) {
|
|
||||||
moduleFlag[0] = 0;
|
|
||||||
moduleFlag[1] = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint8_t sub = m_posVert;
|
|
||||||
int8_t editMode = s_editMode;
|
|
||||||
|
|
||||||
for (uint8_t i=0; i<NUM_BODY_LINES; ++i) {
|
|
||||||
coord_t y = MENU_TITLE_HEIGHT + 1 + i*FH;
|
|
||||||
uint8_t k = i+s_pgOfs;
|
|
||||||
for (int j=0; j<=k; j++) {
|
|
||||||
if (mstate_tab[j] == HIDDEN_ROW)
|
|
||||||
k++;
|
|
||||||
}
|
|
||||||
|
|
||||||
LcdFlags blink = ((editMode>0) ? BLINK|INVERS : INVERS);
|
|
||||||
LcdFlags attr = (sub == k ? blink : 0);
|
|
||||||
|
|
||||||
switch(k) {
|
|
||||||
case ITEM_MODEL_NAME:
|
|
||||||
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_MODELNAME, g_model.header.name, sizeof(g_model.header.name), event, attr);
|
|
||||||
memcpy(modelHeaders[g_eeGeneral.currModel].name, g_model.header.name, sizeof(g_model.header.name));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ITEM_MODEL_BITMAP:
|
|
||||||
lcd_putsLeft(y, STR_BITMAP);
|
|
||||||
if (ZEXIST(g_model.header.bitmap))
|
|
||||||
lcd_putsnAtt(MODEL_SETUP_2ND_COLUMN, y, g_model.header.bitmap, sizeof(g_model.header.bitmap), attr);
|
|
||||||
else
|
|
||||||
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN, y, STR_VCSWFUNC, 0, attr);
|
|
||||||
if (attr && event==EVT_KEY_BREAK(KEY_ENTER) && READ_ONLY_UNLOCKED()) {
|
|
||||||
s_editMode = 0;
|
|
||||||
if (listSdFiles(BITMAPS_PATH, BITMAPS_EXT, sizeof(g_model.header.bitmap), g_model.header.bitmap, LIST_NONE_SD_FILE)) {
|
|
||||||
menuHandler = onModelSetupBitmapMenu;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
POPUP_WARNING(STR_NO_BITMAPS_ON_SD);
|
|
||||||
s_menu_flags = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ITEM_MODEL_TIMER1:
|
|
||||||
case ITEM_MODEL_TIMER2:
|
|
||||||
case ITEM_MODEL_TIMER3:
|
|
||||||
{
|
|
||||||
unsigned int timerIdx = (k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0));
|
|
||||||
TimerData * timer = &g_model.timers[timerIdx];
|
TimerData * timer = &g_model.timers[timerIdx];
|
||||||
putsStrIdx(0*FW, y, STR_TIMER, timerIdx+1);
|
putsStrIdx(0*FW, y, STR_TIMER, timerIdx+1);
|
||||||
putsTimerMode(MODEL_SETUP_2ND_COLUMN, y, timer->mode, m_posHorz==0 ? attr : 0);
|
putsTimerMode(MODEL_SETUP_2ND_COLUMN, y, timer->mode, m_posHorz==0 ? attr : 0);
|
||||||
putsTimer(MODEL_SETUP_2ND_COLUMN+5*FW-2+5*FWNUM+1, y, timer->start, m_posHorz==1 ? attr : 0, m_posHorz==2 ? attr : 0);
|
putsTimer(MODEL_SETUP_2ND_COLUMN+5*FW-2+5*FWNUM+1, y, timer->start, m_posHorz==1 ? attr : 0, m_posHorz==2 ? attr : 0);
|
||||||
if (attr && m_posHorz < 0) drawFilledRect(MODEL_SETUP_2ND_COLUMN-1, y-1, LCD_W-MODEL_SETUP_2ND_COLUMN-MENUS_SCROLLBAR_WIDTH+1, FH+1);
|
if (attr && m_posHorz < 0) drawFilledRect(MODEL_SETUP_2ND_COLUMN-1, y-1, LCD_W-MODEL_SETUP_2ND_COLUMN-MENUS_SCROLLBAR_WIDTH+1, FH+1);
|
||||||
if (attr && editMode>0) {
|
if (attr && s_editMode>0) {
|
||||||
div_t qr = div(timer->start, 60);
|
div_t qr = div(timer->start, 60);
|
||||||
switch (m_posHorz) {
|
switch (m_posHorz) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -230,44 +164,144 @@ void menuModelSetup(uint8_t event)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define CURRENT_MODULE_EDITED(k) (k>=ITEM_MODEL_TRAINER_LABEL ? TRAINER_MODULE : (k>=ITEM_MODEL_EXTERNAL_MODULE_LABEL ? EXTERNAL_MODULE : INTERNAL_MODULE))
|
||||||
|
|
||||||
|
void menuModelSetup(uint8_t event)
|
||||||
|
{
|
||||||
|
horzpos_t l_posHorz = m_posHorz;
|
||||||
|
#define IF_INTERNAL_MODULE_ON(x) (g_model.moduleData[INTERNAL_MODULE].rfProtocol == RF_PROTO_OFF ? HIDDEN_ROW : (uint8_t)(x))
|
||||||
|
#define IF_EXTERNAL_MODULE_ON(x) (g_model.externalModule == MODULE_TYPE_NONE ? HIDDEN_ROW : (uint8_t)(x))
|
||||||
|
#define IF_TRAINER_ON(x) (g_model.trainerMode == TRAINER_MODE_SLAVE ? (uint8_t)(x) : HIDDEN_ROW)
|
||||||
|
#define IF_EXTERNAL_MODULE_XJT(x) (IS_MODULE_XJT(EXTERNAL_MODULE) ? (uint8_t)x : HIDDEN_ROW)
|
||||||
|
#define IS_D8_RX(x) (g_model.moduleData[x].rfProtocol == RF_PROTO_D8)
|
||||||
|
#define INTERNAL_MODULE_CHANNELS_ROWS() IF_INTERNAL_MODULE_ON(1)
|
||||||
|
#define EXTERNAL_MODULE_CHANNELS_ROWS() IF_EXTERNAL_MODULE_ON(IS_MODULE_DSM2(EXTERNAL_MODULE) ? (uint8_t)0 : (uint8_t)1)
|
||||||
|
#define TRAINER_CHANNELS_ROWS() IF_TRAINER_ON(1)
|
||||||
|
#define PORT_CHANNELS_ROWS(x) (x==INTERNAL_MODULE ? INTERNAL_MODULE_CHANNELS_ROWS() : (x==EXTERNAL_MODULE ? EXTERNAL_MODULE_CHANNELS_ROWS() : TRAINER_CHANNELS_ROWS()))
|
||||||
|
#define FAILSAFE_ROWS(x) ((g_model.moduleData[x].rfProtocol==RF_PROTO_X16 || g_model.moduleData[x].rfProtocol==RF_PROTO_LR12) ? (g_model.moduleData[x].failsafeMode==FAILSAFE_CUSTOM ? (uint8_t)1 : (uint8_t)0) : HIDDEN_ROW)
|
||||||
|
#define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0)
|
||||||
|
#define TIMER_ROWS 2|NAVIGATION_LINE_BY_LINE, 0, CASE_PERSISTENT_TIMERS(0) 0, 0
|
||||||
|
#if TIMERS == 1
|
||||||
|
#define TIMERS_ROWS TIMER_ROWS
|
||||||
|
#elif TIMERS == 2
|
||||||
|
#define TIMERS_ROWS TIMER_ROWS, TIMER_ROWS
|
||||||
|
#elif TIMERS == 3
|
||||||
|
#define TIMERS_ROWS TIMER_ROWS, TIMER_ROWS, TIMER_ROWS
|
||||||
|
#endif
|
||||||
|
bool CURSOR_ON_CELL = (m_posHorz >= 0);
|
||||||
|
MENU_TAB({ 0, 0, TIMERS_ROWS, 0, 1, 0, 0, LABEL(Throttle), 0, 0, 0, LABEL(PreflightCheck), 0, 0, uint8_t(NAVIGATION_LINE_BY_LINE|getSwitchWarningsAllowed()), ONE_2x2POS_DEFINED() ? TITLE_ROW : HIDDEN_ROW, POT_WARN_ITEMS(), NAVIGATION_LINE_BY_LINE|(NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1), 0, LABEL(InternalModule), 0, IF_INTERNAL_MODULE_ON(1), IF_INTERNAL_MODULE_ON(IS_D8_RX(0) ? (uint8_t)1 : (uint8_t)2), IF_INTERNAL_MODULE_ON(FAILSAFE_ROWS(INTERNAL_MODULE)), LABEL(ExternalModule), (IS_MODULE_XJT(EXTERNAL_MODULE) || IS_MODULE_DSM2(EXTERNAL_MODULE)) ? (uint8_t)1 : (uint8_t)0, EXTERNAL_MODULE_CHANNELS_ROWS(), (IS_MODULE_XJT(EXTERNAL_MODULE) && IS_D8_RX(EXTERNAL_MODULE)) ? (uint8_t)1 : (IS_MODULE_PPM(EXTERNAL_MODULE) || IS_MODULE_XJT(EXTERNAL_MODULE) || IS_MODULE_DSM2(EXTERNAL_MODULE)) ? (uint8_t)2 : HIDDEN_ROW, IF_EXTERNAL_MODULE_XJT(FAILSAFE_ROWS(EXTERNAL_MODULE)), LABEL(Trainer), 0, TRAINER_CHANNELS_ROWS(), IF_TRAINER_ON(2)});
|
||||||
|
|
||||||
|
MENU_CHECK(STR_MENUSETUP, menuTabModel, e_ModelSetup, ITEM_MODEL_SETUP_MAX);
|
||||||
|
|
||||||
|
#if (defined(DSM2) || defined(PXX))
|
||||||
|
if (menuEvent) {
|
||||||
|
moduleFlag[0] = 0;
|
||||||
|
moduleFlag[1] = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int sub = m_posVert;
|
||||||
|
|
||||||
|
for (uint8_t i=0; i<NUM_BODY_LINES; ++i) {
|
||||||
|
coord_t y = MENU_TITLE_HEIGHT + 1 + i*FH;
|
||||||
|
uint8_t k = i+s_pgOfs;
|
||||||
|
for (int j=0; j<=k; j++) {
|
||||||
|
if (mstate_tab[j] == HIDDEN_ROW)
|
||||||
|
k++;
|
||||||
|
}
|
||||||
|
|
||||||
|
LcdFlags blink = ((s_editMode>0) ? BLINK|INVERS : INVERS);
|
||||||
|
LcdFlags attr = (sub == k ? blink : 0);
|
||||||
|
|
||||||
|
switch(k) {
|
||||||
|
case ITEM_MODEL_NAME:
|
||||||
|
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_MODELNAME, g_model.header.name, sizeof(g_model.header.name), event, attr);
|
||||||
|
memcpy(modelHeaders[g_eeGeneral.currModel].name, g_model.header.name, sizeof(g_model.header.name));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_BITMAP:
|
||||||
|
lcd_putsLeft(y, STR_BITMAP);
|
||||||
|
if (ZEXIST(g_model.header.bitmap))
|
||||||
|
lcd_putsnAtt(MODEL_SETUP_2ND_COLUMN, y, g_model.header.bitmap, sizeof(g_model.header.bitmap), attr);
|
||||||
|
else
|
||||||
|
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN, y, STR_VCSWFUNC, 0, attr);
|
||||||
|
if (attr && event==EVT_KEY_BREAK(KEY_ENTER) && READ_ONLY_UNLOCKED()) {
|
||||||
|
s_editMode = 0;
|
||||||
|
if (listSdFiles(BITMAPS_PATH, BITMAPS_EXT, sizeof(g_model.header.bitmap), g_model.header.bitmap, LIST_NONE_SD_FILE)) {
|
||||||
|
menuHandler = onModelSetupBitmapMenu;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
POPUP_WARNING(STR_NO_BITMAPS_ON_SD);
|
||||||
|
s_menu_flags = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER1:
|
||||||
|
editTimerMode(0, y, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
case ITEM_MODEL_TIMER1_NAME:
|
case ITEM_MODEL_TIMER1_NAME:
|
||||||
case ITEM_MODEL_TIMER2_NAME:
|
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_TIMER_NAME, g_model.timers[0].name, LEN_TIMER_NAME, event, attr);
|
||||||
case ITEM_MODEL_TIMER3_NAME:
|
|
||||||
{
|
|
||||||
TimerData * timer = &g_model.timers[k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0)];
|
|
||||||
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_TIMER_NAME, timer->name, sizeof(timer->name), event, attr);
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case ITEM_MODEL_TIMER1_MINUTE_BEEP:
|
case ITEM_MODEL_TIMER1_MINUTE_BEEP:
|
||||||
case ITEM_MODEL_TIMER2_MINUTE_BEEP:
|
g_model.timers[0].minuteBeep = onoffMenuItem(g_model.timers[0].minuteBeep, MODEL_SETUP_2ND_COLUMN, y, STR_MINUTEBEEP, attr, event);
|
||||||
case ITEM_MODEL_TIMER3_MINUTE_BEEP:
|
|
||||||
{
|
|
||||||
TimerData * timer = &g_model.timers[k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0)];
|
|
||||||
timer->minuteBeep = onoffMenuItem(timer->minuteBeep, MODEL_SETUP_2ND_COLUMN, y, STR_MINUTEBEEP, attr, event);
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case ITEM_MODEL_TIMER1_COUNTDOWN_BEEP:
|
case ITEM_MODEL_TIMER1_COUNTDOWN_BEEP:
|
||||||
case ITEM_MODEL_TIMER2_COUNTDOWN_BEEP:
|
g_model.timers[0].countdownBeep = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_BEEPCOUNTDOWN, STR_VBEEPCOUNTDOWN, g_model.timers[0].countdownBeep, 0, 2, attr, event);
|
||||||
case ITEM_MODEL_TIMER3_COUNTDOWN_BEEP:
|
|
||||||
{
|
|
||||||
TimerData * timer = &g_model.timers[k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0)];
|
|
||||||
timer->countdownBeep = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_BEEPCOUNTDOWN, STR_VBEEPCOUNTDOWN, timer->countdownBeep, 0, 2, attr, event);
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case ITEM_MODEL_TIMER1_PERSISTENT:
|
case ITEM_MODEL_TIMER1_PERSISTENT:
|
||||||
case ITEM_MODEL_TIMER2_PERSISTENT:
|
g_model.timers[0].persistent = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_PERSISTENT, STR_VPERSISTENT, g_model.timers[0].persistent, 0, 2, attr, event);
|
||||||
case ITEM_MODEL_TIMER3_PERSISTENT:
|
|
||||||
{
|
|
||||||
TimerData * timer = &g_model.timers[k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0)];
|
|
||||||
timer->persistent = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_PERSISTENT, STR_VPERSISTENT, timer->persistent, 0, 2, attr, event);
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
#if TIMERS > 1
|
||||||
|
case ITEM_MODEL_TIMER2:
|
||||||
|
editTimerMode(1, y, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER2_NAME:
|
||||||
|
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_TIMER_NAME, g_model.timers[1].name, LEN_TIMER_NAME, event, attr);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER2_MINUTE_BEEP:
|
||||||
|
g_model.timers[1].minuteBeep = onoffMenuItem(g_model.timers[1].minuteBeep, MODEL_SETUP_2ND_COLUMN, y, STR_MINUTEBEEP, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER2_COUNTDOWN_BEEP:
|
||||||
|
g_model.timers[1].countdownBeep = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_BEEPCOUNTDOWN, STR_VBEEPCOUNTDOWN, g_model.timers[1].countdownBeep, 0, 2, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER2_PERSISTENT:
|
||||||
|
g_model.timers[1].persistent = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_PERSISTENT, STR_VPERSISTENT, g_model.timers[1].persistent, 0, 2, attr, event);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if TIMERS > 2
|
||||||
|
case ITEM_MODEL_TIMER3:
|
||||||
|
editTimerMode(2, y, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER3_NAME:
|
||||||
|
editSingleName(MODEL_SETUP_2ND_COLUMN, y, STR_TIMER_NAME, g_model.timers[2].name, LEN_TIMER_NAME, event, attr);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER3_MINUTE_BEEP:
|
||||||
|
g_model.timers[2].minuteBeep = onoffMenuItem(g_model.timers[2].minuteBeep, MODEL_SETUP_2ND_COLUMN, y, STR_MINUTEBEEP, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER3_COUNTDOWN_BEEP:
|
||||||
|
g_model.timers[2].countdownBeep = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_BEEPCOUNTDOWN, STR_VBEEPCOUNTDOWN, g_model.timers[2].countdownBeep, 0, 2, attr, event);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ITEM_MODEL_TIMER3_PERSISTENT:
|
||||||
|
g_model.timers[2].persistent = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_PERSISTENT, STR_VPERSISTENT, g_model.timers[2].persistent, 0, 2, attr, event);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
case ITEM_MODEL_EXTENDED_LIMITS:
|
case ITEM_MODEL_EXTENDED_LIMITS:
|
||||||
ON_OFF_MENU_ITEM(g_model.extendedLimits, MODEL_SETUP_2ND_COLUMN, y, STR_ELIMITS, attr, event);
|
ON_OFF_MENU_ITEM(g_model.extendedLimits, MODEL_SETUP_2ND_COLUMN, y, STR_ELIMITS, attr, event);
|
||||||
|
@ -506,7 +540,7 @@ void menuModelSetup(uint8_t event)
|
||||||
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN+5*FW, y, STR_XJT_PROTOCOLS, 1+g_model.moduleData[EXTERNAL_MODULE].rfProtocol, m_posHorz==1 ? attr : 0);
|
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN+5*FW, y, STR_XJT_PROTOCOLS, 1+g_model.moduleData[EXTERNAL_MODULE].rfProtocol, m_posHorz==1 ? attr : 0);
|
||||||
else if (IS_MODULE_DSM2(EXTERNAL_MODULE))
|
else if (IS_MODULE_DSM2(EXTERNAL_MODULE))
|
||||||
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN+5*FW, y, STR_DSM_PROTOCOLS, g_model.moduleData[EXTERNAL_MODULE].rfProtocol, m_posHorz==1 ? attr : 0);
|
lcd_putsiAtt(MODEL_SETUP_2ND_COLUMN+5*FW, y, STR_DSM_PROTOCOLS, g_model.moduleData[EXTERNAL_MODULE].rfProtocol, m_posHorz==1 ? attr : 0);
|
||||||
if (attr && editMode>0) {
|
if (attr && s_editMode>0) {
|
||||||
switch (m_posHorz) {
|
switch (m_posHorz) {
|
||||||
case 0:
|
case 0:
|
||||||
g_model.externalModule = checkIncDec(event, g_model.externalModule, MODULE_TYPE_NONE, MODULE_TYPE_COUNT-1, EE_MODEL, isModuleAvailable);
|
g_model.externalModule = checkIncDec(event, g_model.externalModule, MODULE_TYPE_NONE, MODULE_TYPE_COUNT-1, EE_MODEL, isModuleAvailable);
|
||||||
|
@ -548,7 +582,7 @@ void menuModelSetup(uint8_t event)
|
||||||
lcd_outdezAtt(lcdLastPos, y, moduleData.channelsStart+1, LEFT | (m_posHorz==0 ? attr : 0));
|
lcd_outdezAtt(lcdLastPos, y, moduleData.channelsStart+1, LEFT | (m_posHorz==0 ? attr : 0));
|
||||||
lcd_putc(lcdLastPos, y, '-');
|
lcd_putc(lcdLastPos, y, '-');
|
||||||
lcd_outdezAtt(lcdLastPos + FW+1, y, moduleData.channelsStart+NUM_CHANNELS(moduleIdx), LEFT | (m_posHorz==1 ? attr : 0));
|
lcd_outdezAtt(lcdLastPos + FW+1, y, moduleData.channelsStart+NUM_CHANNELS(moduleIdx), LEFT | (m_posHorz==1 ? attr : 0));
|
||||||
if (attr && editMode>0) {
|
if (attr && s_editMode>0) {
|
||||||
switch (m_posHorz) {
|
switch (m_posHorz) {
|
||||||
case 0:
|
case 0:
|
||||||
CHECK_INCDEC_MODELVAR_ZERO(event, moduleData.channelsStart, 32-8-moduleData.channelsCount);
|
CHECK_INCDEC_MODELVAR_ZERO(event, moduleData.channelsStart, 32-8-moduleData.channelsCount);
|
||||||
|
@ -579,7 +613,7 @@ void menuModelSetup(uint8_t event)
|
||||||
lcd_outdezAtt(MODEL_SETUP_2ND_COLUMN+8*FW+2, y, (moduleData.ppmDelay*50)+300, (CURSOR_ON_LINE() || m_posHorz==1) ? attr : 0);
|
lcd_outdezAtt(MODEL_SETUP_2ND_COLUMN+8*FW+2, y, (moduleData.ppmDelay*50)+300, (CURSOR_ON_LINE() || m_posHorz==1) ? attr : 0);
|
||||||
lcd_putcAtt(MODEL_SETUP_2ND_COLUMN+10*FW, y, moduleData.ppmPulsePol ? '+' : '-', (CURSOR_ON_LINE() || m_posHorz==2) ? attr : 0);
|
lcd_putcAtt(MODEL_SETUP_2ND_COLUMN+10*FW, y, moduleData.ppmPulsePol ? '+' : '-', (CURSOR_ON_LINE() || m_posHorz==2) ? attr : 0);
|
||||||
|
|
||||||
if (attr && editMode>0) {
|
if (attr && s_editMode>0) {
|
||||||
switch (m_posHorz) {
|
switch (m_posHorz) {
|
||||||
case 0:
|
case 0:
|
||||||
CHECK_INCDEC_MODELVAR(event, moduleData.ppmFrameLength, -20, 35);
|
CHECK_INCDEC_MODELVAR(event, moduleData.ppmFrameLength, -20, 35);
|
||||||
|
@ -607,13 +641,13 @@ void menuModelSetup(uint8_t event)
|
||||||
if (IS_MODULE_XJT(moduleIdx) || IS_MODULE_DSM2(moduleIdx)) {
|
if (IS_MODULE_XJT(moduleIdx) || IS_MODULE_DSM2(moduleIdx)) {
|
||||||
if (xOffsetBind) lcd_outdezNAtt(MODEL_SETUP_2ND_COLUMN, y, g_model.header.modelId, (l_posHorz==0 ? attr : 0) | LEADING0|LEFT, 2);
|
if (xOffsetBind) lcd_outdezNAtt(MODEL_SETUP_2ND_COLUMN, y, g_model.header.modelId, (l_posHorz==0 ? attr : 0) | LEADING0|LEFT, 2);
|
||||||
if (attr && l_posHorz==0) {
|
if (attr && l_posHorz==0) {
|
||||||
if (editMode>0) {
|
if (s_editMode>0) {
|
||||||
CHECK_INCDEC_MODELVAR_ZERO(event, g_model.header.modelId, IS_MODULE_DSM2(moduleIdx) ? 20 : 63);
|
CHECK_INCDEC_MODELVAR_ZERO(event, g_model.header.modelId, IS_MODULE_DSM2(moduleIdx) ? 20 : 63);
|
||||||
if (checkIncDec_Ret) {
|
if (checkIncDec_Ret) {
|
||||||
modelHeaders[g_eeGeneral.currModel].modelId = g_model.header.modelId;
|
modelHeaders[g_eeGeneral.currModel].modelId = g_model.header.modelId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (editMode==0 && event==EVT_KEY_BREAK(KEY_ENTER)) {
|
if (s_editMode==0 && event==EVT_KEY_BREAK(KEY_ENTER)) {
|
||||||
checkModelIdUnique(g_eeGeneral.currModel);
|
checkModelIdUnique(g_eeGeneral.currModel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -646,7 +680,7 @@ void menuModelSetup(uint8_t event)
|
||||||
if (moduleData.failsafeMode != FAILSAFE_CUSTOM)
|
if (moduleData.failsafeMode != FAILSAFE_CUSTOM)
|
||||||
m_posHorz = 0;
|
m_posHorz = 0;
|
||||||
if (m_posHorz==0) {
|
if (m_posHorz==0) {
|
||||||
if (editMode>0) {
|
if (s_editMode>0) {
|
||||||
CHECK_INCDEC_MODELVAR_ZERO(event, moduleData.failsafeMode, FAILSAFE_LAST);
|
CHECK_INCDEC_MODELVAR_ZERO(event, moduleData.failsafeMode, FAILSAFE_LAST);
|
||||||
if (checkIncDec_Ret) SEND_FAILSAFE_NOW(moduleIdx);
|
if (checkIncDec_Ret) SEND_FAILSAFE_NOW(moduleIdx);
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,8 +37,11 @@
|
||||||
#include "opentx.h"
|
#include "opentx.h"
|
||||||
#include "timers.h"
|
#include "timers.h"
|
||||||
|
|
||||||
TimerState timersStates[MAX_TIMERS] = { 0 };
|
#if TIMERS > MAX_TIMERS
|
||||||
|
#error "Timers cannot exceed " .. MAX_TIMERS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
TimerState timersStates[TIMERS] = { { 0 } };
|
||||||
|
|
||||||
void timerReset(uint8_t idx)
|
void timerReset(uint8_t idx)
|
||||||
{
|
{
|
||||||
|
@ -61,7 +64,7 @@ void timerSet(int idx, int16_t val)
|
||||||
#if defined(CPUARM) || defined(CPUM2560)
|
#if defined(CPUARM) || defined(CPUM2560)
|
||||||
void restoreTimers()
|
void restoreTimers()
|
||||||
{
|
{
|
||||||
for (uint8_t i=0; i<MAX_TIMERS; i++) {
|
for (uint8_t i=0; i<TIMERS; i++) {
|
||||||
if (g_model.timers[i].persistent) {
|
if (g_model.timers[i].persistent) {
|
||||||
timersStates[i].val = g_model.timers[i].value;
|
timersStates[i].val = g_model.timers[i].value;
|
||||||
}
|
}
|
||||||
|
@ -70,7 +73,7 @@ void restoreTimers()
|
||||||
|
|
||||||
void saveTimers()
|
void saveTimers()
|
||||||
{
|
{
|
||||||
for (uint8_t i=0; i<MAX_TIMERS; i++) {
|
for (uint8_t i=0; i<TIMERS; i++) {
|
||||||
if (g_model.timers[i].persistent) {
|
if (g_model.timers[i].persistent) {
|
||||||
TimerState *timerState = &timersStates[i];
|
TimerState *timerState = &timersStates[i];
|
||||||
if (g_model.timers[i].value != (uint16_t)timerState->val) {
|
if (g_model.timers[i].value != (uint16_t)timerState->val) {
|
||||||
|
@ -98,7 +101,7 @@ void saveTimers()
|
||||||
|
|
||||||
void evalTimers(int16_t throttle, uint8_t tick10ms)
|
void evalTimers(int16_t throttle, uint8_t tick10ms)
|
||||||
{
|
{
|
||||||
for (uint8_t i=0; i<MAX_TIMERS; i++) {
|
for (uint8_t i=0; i<TIMERS; i++) {
|
||||||
int8_t tm = g_model.timers[i].mode;
|
int8_t tm = g_model.timers[i].mode;
|
||||||
uint16_t tv = g_model.timers[i].start;
|
uint16_t tv = g_model.timers[i].start;
|
||||||
TimerState * timerState = &timersStates[i];
|
TimerState * timerState = &timersStates[i];
|
||||||
|
|
|
@ -53,7 +53,7 @@ struct TimerState {
|
||||||
uint8_t val_10ms;
|
uint8_t val_10ms;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern TimerState timersStates[MAX_TIMERS];
|
extern TimerState timersStates[TIMERS];
|
||||||
|
|
||||||
void timerReset(uint8_t idx);
|
void timerReset(uint8_t idx);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue