mirror of
https://github.com/opentx/opentx.git
synced 2025-07-25 17:25:13 +03:00
Popups can now have an handler. It could perhaps avoid another EEPROM format @3djc ?
This commit is contained in:
parent
4de9e3f73b
commit
d4b14f614c
21 changed files with 104 additions and 61 deletions
|
@ -52,7 +52,7 @@ void onModelSelectMenu(const char * result)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else if (result == STR_DELETE_MODEL) {
|
else if (result == STR_DELETE_MODEL) {
|
||||||
POPUP_CONFIRMATION(STR_DELETEMODEL);
|
POPUP_CONFIRMATION(STR_DELETEMODEL, nullptr);
|
||||||
SET_WARNING_INFO(modelHeaders[sub].name, sizeof(g_model.header.name), ZCHAR);
|
SET_WARNING_INFO(modelHeaders[sub].name, sizeof(g_model.header.name), ZCHAR);
|
||||||
}
|
}
|
||||||
#if defined(SDCARD)
|
#if defined(SDCARD)
|
||||||
|
@ -104,7 +104,7 @@ void menuModelSelect(event_t event)
|
||||||
case EVT_KEY_LONG(KEY_EXIT):
|
case EVT_KEY_LONG(KEY_EXIT):
|
||||||
killEvents(event);
|
killEvents(event);
|
||||||
if (s_copyMode && s_copyTgtOfs == 0 && g_eeGeneral.currModel != sub && eeModelExists(sub)) {
|
if (s_copyMode && s_copyTgtOfs == 0 && g_eeGeneral.currModel != sub && eeModelExists(sub)) {
|
||||||
POPUP_CONFIRMATION(STR_DELETEMODEL);
|
POPUP_CONFIRMATION(STR_DELETEMODEL, nullptr);
|
||||||
SET_WARNING_INFO(modelHeaders[sub].name, sizeof(g_model.header.name), ZCHAR);
|
SET_WARNING_INFO(modelHeaders[sub].name, sizeof(g_model.header.name), ZCHAR);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -1608,7 +1608,7 @@ void menuModelSetup(event_t event)
|
||||||
{
|
{
|
||||||
uint8_t newAntennaSel = editChoice(MODEL_SETUP_2ND_COLUMN, y, STR_ANTENNASELECTION, STR_VANTENNATYPES, g_model.moduleData[INTERNAL_MODULE].pxx.external_antenna, 0, 1, attr, event);
|
uint8_t newAntennaSel = editChoice(MODEL_SETUP_2ND_COLUMN, y, STR_ANTENNASELECTION, STR_VANTENNATYPES, g_model.moduleData[INTERNAL_MODULE].pxx.external_antenna, 0, 1, attr, event);
|
||||||
if (newAntennaSel != g_model.moduleData[INTERNAL_MODULE].pxx.external_antenna && newAntennaSel == XJT_EXTERNAL_ANTENNA) {
|
if (newAntennaSel != g_model.moduleData[INTERNAL_MODULE].pxx.external_antenna && newAntennaSel == XJT_EXTERNAL_ANTENNA) {
|
||||||
POPUP_CONFIRMATION(STR_ANTENNACONFIRM1);
|
POPUP_CONFIRMATION(STR_ANTENNACONFIRM1, nullptr);
|
||||||
const char * w = STR_ANTENNACONFIRM2;
|
const char * w = STR_ANTENNACONFIRM2;
|
||||||
SET_WARNING_INFO(w, strlen(w), 0);
|
SET_WARNING_INFO(w, strlen(w), 0);
|
||||||
}
|
}
|
||||||
|
@ -1950,16 +1950,37 @@ enum MenuModelReceiverOptions {
|
||||||
|
|
||||||
#define RECEIVER_OPTIONS_2ND_COLUMN 80
|
#define RECEIVER_OPTIONS_2ND_COLUMN 80
|
||||||
|
|
||||||
|
void onRxOptionsUpdateConfirm(const char * result)
|
||||||
|
{
|
||||||
|
if (result == STR_OK) {
|
||||||
|
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_WRITE;
|
||||||
|
reusableBuffer.receiverSetup.dirty = 0;
|
||||||
|
reusableBuffer.receiverSetup.timeout = 0;
|
||||||
|
moduleSettings[g_moduleIdx].mode = MODULE_MODE_RECEIVER_SETTINGS;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
reusableBuffer.receiverSetup.dirty = 0;
|
||||||
|
popMenu();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void menuModelReceiverOptions(event_t event)
|
void menuModelReceiverOptions(event_t event)
|
||||||
{
|
{
|
||||||
const int lim = (g_model.extendedLimits ? (512 * LIMIT_EXT_PERCENT / 100) : 512) * 2;
|
const int lim = (g_model.extendedLimits ? (512 * LIMIT_EXT_PERCENT / 100) : 512) * 2;
|
||||||
uint8_t wbar = LCD_W / 2 - 20;
|
uint8_t wbar = LCD_W / 2 - 20;
|
||||||
|
uint8_t outputsCount = min<uint8_t>(16, reusableBuffer.receiverSetup.outputsCount);
|
||||||
|
|
||||||
SIMPLE_SUBMENU_NOTITLE(ITEM_RECEIVER_PINMAP_FIRST + sentModuleChannels(g_moduleIdx));
|
SIMPLE_SUBMENU_NOTITLE(ITEM_RECEIVER_PINMAP_FIRST + outputsCount);
|
||||||
|
|
||||||
if (menuEvent) {
|
if (menuEvent) {
|
||||||
moduleSettings[g_moduleIdx].mode = MODULE_MODE_NORMAL;
|
moduleSettings[g_moduleIdx].mode = MODULE_MODE_NORMAL;
|
||||||
return;
|
if (reusableBuffer.receiverSetup.dirty) {
|
||||||
|
pushMenu(menuModelReceiverOptions);
|
||||||
|
POPUP_CONFIRMATION("Update RX options?", onRxOptionsUpdateConfirm);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int8_t sub = menuVerticalPosition;
|
int8_t sub = menuVerticalPosition;
|
||||||
|
@ -1969,22 +1990,15 @@ void menuModelReceiverOptions(event_t event)
|
||||||
lcdInvertLine(0);
|
lcdInvertLine(0);
|
||||||
|
|
||||||
if (event == EVT_ENTRY) {
|
if (event == EVT_ENTRY) {
|
||||||
moduleSettings[g_moduleIdx].mode = MODULE_MODE_RECEIVER_SETTINGS;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!s_editMode && reusableBuffer.receiverSetup.dirty && reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_OK) {
|
|
||||||
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_WRITE;
|
|
||||||
reusableBuffer.receiverSetup.dirty = 0;
|
|
||||||
reusableBuffer.receiverSetup.timeout = 0;
|
|
||||||
reusableBuffer.receiverSetup.dirtyTimeout = get_tmr10ms() + 500/*5s*/;
|
|
||||||
moduleSettings[g_moduleIdx].mode = MODULE_MODE_RECEIVER_SETTINGS;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(SIMU)
|
#if defined(SIMU)
|
||||||
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_OK;
|
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_OK;
|
||||||
|
reusableBuffer.receiverSetup.outputsCount = 8;
|
||||||
|
#else
|
||||||
|
moduleSettings[g_moduleIdx].mode = MODULE_MODE_RECEIVER_SETTINGS;
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
if (reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_OK || get_tmr10ms() < reusableBuffer.receiverSetup.dirtyTimeout) {
|
if (reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_OK) {
|
||||||
for (uint8_t k=0; k<LCD_LINES-1; k++) {
|
for (uint8_t k=0; k<LCD_LINES-1; k++) {
|
||||||
coord_t y = MENU_HEADER_HEIGHT + 1 + k*FH;
|
coord_t y = MENU_HEADER_HEIGHT + 1 + k*FH;
|
||||||
uint8_t i = k + menuVerticalOffset;
|
uint8_t i = k + menuVerticalOffset;
|
||||||
|
@ -2009,7 +2023,7 @@ void menuModelReceiverOptions(event_t event)
|
||||||
// Pin
|
// Pin
|
||||||
{
|
{
|
||||||
uint8_t pin = i - ITEM_RECEIVER_PINMAP_FIRST;
|
uint8_t pin = i - ITEM_RECEIVER_PINMAP_FIRST;
|
||||||
uint8_t channel = reusableBuffer.receiverSetup.channelMapping[pin];
|
uint8_t channel = reusableBuffer.receiverSetup.outputsMapping[pin];
|
||||||
int32_t channelValue = channelOutputs[channel];
|
int32_t channelValue = channelOutputs[channel];
|
||||||
lcdDrawText(0, y, "Pin");
|
lcdDrawText(0, y, "Pin");
|
||||||
lcdDrawNumber(lcdLastRightPos + 1, y, pin + 1);
|
lcdDrawNumber(lcdLastRightPos + 1, y, pin + 1);
|
||||||
|
@ -2019,7 +2033,7 @@ void menuModelReceiverOptions(event_t event)
|
||||||
if (attr) {
|
if (attr) {
|
||||||
channel = checkIncDec(event, channel, 0, sentModuleChannels(g_moduleIdx) - 1);
|
channel = checkIncDec(event, channel, 0, sentModuleChannels(g_moduleIdx) - 1);
|
||||||
if (checkIncDec_Ret) {
|
if (checkIncDec_Ret) {
|
||||||
reusableBuffer.receiverSetup.channelMapping[pin] = channel;
|
reusableBuffer.receiverSetup.outputsMapping[pin] = channel;
|
||||||
reusableBuffer.receiverSetup.dirty = true;
|
reusableBuffer.receiverSetup.dirty = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -531,7 +531,7 @@ void menuModelTelemetryFrsky(event_t event)
|
||||||
s_editMode = 0;
|
s_editMode = 0;
|
||||||
if (event==EVT_KEY_LONG(KEY_ENTER)) {
|
if (event==EVT_KEY_LONG(KEY_ENTER)) {
|
||||||
killEvents(KEY_ENTER);
|
killEvents(KEY_ENTER);
|
||||||
POPUP_CONFIRMATION(STR_CONFIRMDELETE);
|
POPUP_CONFIRMATION(STR_CONFIRMDELETE, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -33,7 +33,7 @@ void menuModelTemplates(event_t event)
|
||||||
AUDIO_WARNING2();
|
AUDIO_WARNING2();
|
||||||
}
|
}
|
||||||
if (event==EVT_KEY_BREAK(KEY_ENTER)) {
|
if (event==EVT_KEY_BREAK(KEY_ENTER)) {
|
||||||
POPUP_CONFIRMATION(STR_VTEMPLATES+1 + (sub * LEN2_VTEMPLATES));
|
POPUP_CONFIRMATION(STR_VTEMPLATES+1 + (sub * LEN2_VTEMPLATES), nullptr);
|
||||||
s_editMode = 0;
|
s_editMode = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,20 +89,37 @@ void showAlertBox(const char * title, const char * text, const char * action , u
|
||||||
void runPopupWarning(event_t event)
|
void runPopupWarning(event_t event)
|
||||||
{
|
{
|
||||||
warningResult = false;
|
warningResult = false;
|
||||||
|
|
||||||
drawMessageBox();
|
drawMessageBox();
|
||||||
|
|
||||||
if (warningInfoText) {
|
if (warningInfoText) {
|
||||||
lcdDrawSizedText(WARNING_LINE_X, WARNING_LINE_Y+FH, warningInfoText, warningInfoLength, WARNING_INFO_FLAGS);
|
lcdDrawSizedText(WARNING_LINE_X, WARNING_LINE_Y+FH, warningInfoText, warningInfoLength, WARNING_INFO_FLAGS);
|
||||||
}
|
}
|
||||||
|
|
||||||
lcdDrawText(WARNING_LINE_X, WARNING_LINE_Y+2*FH, warningType == WARNING_TYPE_INFO ? STR_OK : (warningType == WARNING_TYPE_ASTERISK ? STR_EXIT : STR_POPUPS_ENTER_EXIT));
|
lcdDrawText(WARNING_LINE_X, WARNING_LINE_Y+2*FH, warningType == WARNING_TYPE_INFO ? STR_OK : (warningType == WARNING_TYPE_ASTERISK ? STR_EXIT : STR_POPUPS_ENTER_EXIT));
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case EVT_KEY_BREAK(KEY_ENTER):
|
case EVT_KEY_BREAK(KEY_ENTER):
|
||||||
if (warningType == WARNING_TYPE_ASTERISK)
|
if (warningType == WARNING_TYPE_ASTERISK)
|
||||||
|
// key ignored, the user has to press [EXIT]
|
||||||
break;
|
break;
|
||||||
if (warningType != WARNING_TYPE_INFO)
|
|
||||||
|
if (warningType == WARNING_TYPE_CONFIRM) {
|
||||||
|
warningType = WARNING_TYPE_ASTERISK;
|
||||||
|
warningText = nullptr;
|
||||||
warningResult = true;
|
warningResult = true;
|
||||||
|
if (popupMenuHandler)
|
||||||
|
popupMenuHandler(STR_OK);
|
||||||
|
break;
|
||||||
|
}
|
||||||
// no break
|
// no break
|
||||||
|
|
||||||
case EVT_KEY_BREAK(KEY_EXIT):
|
case EVT_KEY_BREAK(KEY_EXIT):
|
||||||
warningText = NULL;
|
if (warningType == WARNING_TYPE_CONFIRM) {
|
||||||
|
if (popupMenuHandler)
|
||||||
|
popupMenuHandler(STR_EXIT);
|
||||||
|
}
|
||||||
|
warningText = nullptr;
|
||||||
warningType = WARNING_TYPE_ASTERISK;
|
warningType = WARNING_TYPE_ASTERISK;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,9 +48,9 @@ extern uint8_t warningInfoFlags;
|
||||||
#define SET_WARNING_INFO(...)
|
#define SET_WARNING_INFO(...)
|
||||||
#else
|
#else
|
||||||
#define DISPLAY_WARNING (*popupFunc)
|
#define DISPLAY_WARNING (*popupFunc)
|
||||||
#define POPUP_INFORMATION(s) (warningText = s, warningType = WARNING_TYPE_INFO, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_INFORMATION(s) (warningText = s, warningType = WARNING_TYPE_INFO, warningInfoText = nullptr, popupFunc = runPopupWarning)
|
||||||
#define POPUP_WARNING(s) (warningText = s, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_WARNING(s) (warningText = s, warningInfoText = 0, popupFunc = runPopupWarning)
|
||||||
#define POPUP_CONFIRMATION(s) (warningText = s, warningType = WARNING_TYPE_CONFIRM, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_CONFIRMATION(s, func) (warningText = s, warningType = WARNING_TYPE_CONFIRM, warningInfoText = nullptr, popupFunc = runPopupWarning, popupMenuHandler = func)
|
||||||
#define POPUP_INPUT(s, func) (warningText = s, popupFunc = func)
|
#define POPUP_INPUT(s, func) (warningText = s, popupFunc = func)
|
||||||
#define WARNING_INFO_FLAGS warningInfoFlags
|
#define WARNING_INFO_FLAGS warningInfoFlags
|
||||||
#define SET_WARNING_INFO(info, len, flags) (warningInfoText = info, warningInfoLength = len, warningInfoFlags = flags)
|
#define SET_WARNING_INFO(info, len, flags) (warningInfoText = info, warningInfoLength = len, warningInfoFlags = flags)
|
||||||
|
@ -62,7 +62,6 @@ extern uint8_t warningInfoFlags;
|
||||||
#define POPUP_MENU_ADD_SD_ITEM(s)
|
#define POPUP_MENU_ADD_SD_ITEM(s)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define NAVIGATION_MENUS
|
|
||||||
#define POPUP_MENU_ADD_ITEM(s) do { popupMenuOffsetType = MENU_OFFSET_INTERNAL; if (popupMenuItemsCount < POPUP_MENU_MAX_LINES) popupMenuItems[popupMenuItemsCount++] = s; } while (0)
|
#define POPUP_MENU_ADD_ITEM(s) do { popupMenuOffsetType = MENU_OFFSET_INTERNAL; if (popupMenuItemsCount < POPUP_MENU_MAX_LINES) popupMenuItems[popupMenuItemsCount++] = s; } while (0)
|
||||||
#define POPUP_MENU_SELECT_ITEM(s) s_menu_item = (s > 0 ? (s < popupMenuItemsCount ? s : popupMenuItemsCount) : 0)
|
#define POPUP_MENU_SELECT_ITEM(s) s_menu_item = (s > 0 ? (s < popupMenuItemsCount ? s : popupMenuItemsCount) : 0)
|
||||||
#define POPUP_MENU_START(func) do { popupMenuHandler = (func); AUDIO_KEY_PRESS(); } while (0)
|
#define POPUP_MENU_START(func) do { popupMenuHandler = (func); AUDIO_KEY_PRESS(); } while (0)
|
||||||
|
@ -78,13 +77,11 @@ extern uint8_t warningInfoFlags;
|
||||||
extern uint8_t popupMenuOffsetType;
|
extern uint8_t popupMenuOffsetType;
|
||||||
extern uint8_t s_menu_item;
|
extern uint8_t s_menu_item;
|
||||||
|
|
||||||
#if defined(NAVIGATION_MENUS)
|
|
||||||
extern uint16_t popupMenuOffset;
|
extern uint16_t popupMenuOffset;
|
||||||
extern const char * popupMenuItems[POPUP_MENU_MAX_LINES];
|
extern const char * popupMenuItems[POPUP_MENU_MAX_LINES];
|
||||||
extern uint16_t popupMenuItemsCount;
|
extern uint16_t popupMenuItemsCount;
|
||||||
const char * runPopupMenu(event_t event);
|
const char * runPopupMenu(event_t event);
|
||||||
extern void (*popupMenuHandler)(const char * result);
|
extern void (*popupMenuHandler)(const char * result);
|
||||||
extern const char * popupMenuTitle;
|
extern const char * popupMenuTitle;
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // _POPUPS_H_
|
#endif // _POPUPS_H_
|
||||||
|
|
|
@ -553,7 +553,7 @@ void menuRadioSetup(event_t event)
|
||||||
if (g_eeGeneral.fai)
|
if (g_eeGeneral.fai)
|
||||||
POPUP_WARNING("FAI\001mode blocked!");
|
POPUP_WARNING("FAI\001mode blocked!");
|
||||||
else
|
else
|
||||||
POPUP_CONFIRMATION("FAI mode?");
|
POPUP_CONFIRMATION("FAI mode?", nullptr);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -196,7 +196,7 @@ void menuRadioVersion(event_t event)
|
||||||
// y += FH;
|
// y += FH;
|
||||||
if (menuVerticalPosition == ITEM_RADIO_FACTORY_RESET && event == EVT_KEY_BREAK(KEY_ENTER)) {
|
if (menuVerticalPosition == ITEM_RADIO_FACTORY_RESET && event == EVT_KEY_BREAK(KEY_ENTER)) {
|
||||||
s_editMode = EDIT_SELECT_FIELD;
|
s_editMode = EDIT_SELECT_FIELD;
|
||||||
POPUP_CONFIRMATION(STR_CONFIRMRESET);
|
POPUP_CONFIRMATION(STR_CONFIRMRESET, nullptr);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,7 +52,7 @@ void onModelSelectMenu(const char * result)
|
||||||
else if (result == STR_DELETE_MODEL) {
|
else if (result == STR_DELETE_MODEL) {
|
||||||
char * nametmp = reusableBuffer.modelsel.mainname;
|
char * nametmp = reusableBuffer.modelsel.mainname;
|
||||||
strcat_modelname (nametmp, sub);
|
strcat_modelname (nametmp, sub);
|
||||||
POPUP_CONFIRMATION(STR_DELETEMODEL);
|
POPUP_CONFIRMATION(STR_DELETEMODEL, nullptr);
|
||||||
SET_WARNING_INFO(nametmp, sizeof(g_model.header.name), 0);
|
SET_WARNING_INFO(nametmp, sizeof(g_model.header.name), 0);
|
||||||
}
|
}
|
||||||
else if (result) {
|
else if (result) {
|
||||||
|
@ -102,7 +102,7 @@ void menuModelSelect(event_t event)
|
||||||
if (s_copyMode && s_copyTgtOfs == 0 && g_eeGeneral.currModel != sub && eeModelExists(sub)) {
|
if (s_copyMode && s_copyTgtOfs == 0 && g_eeGeneral.currModel != sub && eeModelExists(sub)) {
|
||||||
char * nametmp = reusableBuffer.modelsel.mainname;
|
char * nametmp = reusableBuffer.modelsel.mainname;
|
||||||
strcat_modelname (nametmp, sub);
|
strcat_modelname (nametmp, sub);
|
||||||
POPUP_CONFIRMATION(STR_DELETEMODEL);
|
POPUP_CONFIRMATION(STR_DELETEMODEL, nullptr);
|
||||||
SET_WARNING_INFO(nametmp, sizeof(g_model.header.name), 0);
|
SET_WARNING_INFO(nametmp, sizeof(g_model.header.name), 0);
|
||||||
killEvents(event);
|
killEvents(event);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -506,7 +506,7 @@ void menuModelTelemetryFrsky(event_t event)
|
||||||
s_editMode = 0;
|
s_editMode = 0;
|
||||||
if (attr && event==EVT_KEY_LONG(KEY_ENTER)) {
|
if (attr && event==EVT_KEY_LONG(KEY_ENTER)) {
|
||||||
killEvents(KEY_ENTER);
|
killEvents(KEY_ENTER);
|
||||||
POPUP_CONFIRMATION(STR_CONFIRMDELETE);
|
POPUP_CONFIRMATION(STR_CONFIRMDELETE, nullptr);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -86,6 +86,8 @@ void showAlertBox(const char * title, const char * text, const char * action, ui
|
||||||
|
|
||||||
void runPopupWarning(event_t event)
|
void runPopupWarning(event_t event)
|
||||||
{
|
{
|
||||||
|
warningResult = false;
|
||||||
|
|
||||||
drawMessageBox(warningText);
|
drawMessageBox(warningText);
|
||||||
|
|
||||||
if (warningInfoText) {
|
if (warningInfoText) {
|
||||||
|
@ -99,12 +101,22 @@ void runPopupWarning(event_t event)
|
||||||
if (warningType == WARNING_TYPE_ASTERISK)
|
if (warningType == WARNING_TYPE_ASTERISK)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (warningType != WARNING_TYPE_INFO)
|
if (warningType == WARNING_TYPE_CONFIRM) {
|
||||||
popupMenuHandler(STR_OK);
|
warningType = WARNING_TYPE_ASTERISK;
|
||||||
|
warningText = nullptr;
|
||||||
|
warningResult = true;
|
||||||
|
if (popupMenuHandler)
|
||||||
|
popupMenuHandler(STR_OK);
|
||||||
|
break;
|
||||||
|
}
|
||||||
// no break
|
// no break
|
||||||
|
|
||||||
case EVT_KEY_BREAK(KEY_EXIT):
|
case EVT_KEY_BREAK(KEY_EXIT):
|
||||||
warningText = NULL;
|
if (warningType == WARNING_TYPE_CONFIRM) {
|
||||||
|
if (popupMenuHandler)
|
||||||
|
popupMenuHandler(STR_EXIT);
|
||||||
|
}
|
||||||
|
warningText = nullptr;
|
||||||
warningType = WARNING_TYPE_ASTERISK;
|
warningType = WARNING_TYPE_ASTERISK;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,7 +39,7 @@ extern uint8_t warningInfoFlags;
|
||||||
#define DISPLAY_WARNING (*popupFunc)
|
#define DISPLAY_WARNING (*popupFunc)
|
||||||
#define POPUP_INFORMATION(s) (warningText = s, warningType = WARNING_TYPE_INFO, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_INFORMATION(s) (warningText = s, warningType = WARNING_TYPE_INFO, warningInfoText = 0, popupFunc = runPopupWarning)
|
||||||
#define POPUP_WARNING(s) (warningText = s, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_WARNING(s) (warningText = s, warningInfoText = 0, popupFunc = runPopupWarning)
|
||||||
#define POPUP_CONFIRMATION(s) (warningText = s, warningType = WARNING_TYPE_CONFIRM, warningInfoText = 0, popupFunc = runPopupWarning)
|
#define POPUP_CONFIRMATION(s, func) (warningText = s, warningType = WARNING_TYPE_CONFIRM, warningInfoText = 0, popupFunc = runPopupWarning, popupMenuHandler = func)
|
||||||
#define POPUP_INPUT(s, func) (warningText = s, popupFunc = func)
|
#define POPUP_INPUT(s, func) (warningText = s, popupFunc = func)
|
||||||
#define WARNING_INFO_FLAGS warningInfoFlags
|
#define WARNING_INFO_FLAGS warningInfoFlags
|
||||||
#define SET_WARNING_INFO(info, len, flags) (warningInfoText = info, warningInfoLength = len, warningInfoFlags = flags)
|
#define SET_WARNING_INFO(info, len, flags) (warningInfoText = info, warningInfoLength = len, warningInfoFlags = flags)
|
||||||
|
|
|
@ -460,7 +460,7 @@ void menuRadioSetup(event_t event)
|
||||||
if (g_eeGeneral.fai)
|
if (g_eeGeneral.fai)
|
||||||
POPUP_WARNING("FAI\001mode blocked!");
|
POPUP_WARNING("FAI\001mode blocked!");
|
||||||
else
|
else
|
||||||
POPUP_CONFIRMATION("FAI mode?");
|
POPUP_CONFIRMATION("FAI mode?", nullptr);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -46,6 +46,6 @@ void menuRadioVersion(event_t event)
|
||||||
eepromBackup();
|
eepromBackup();
|
||||||
}
|
}
|
||||||
else if (event == EVT_KEY_LONG(KEY_MENU)) {
|
else if (event == EVT_KEY_LONG(KEY_MENU)) {
|
||||||
POPUP_CONFIRMATION(STR_CONFIRMRESET);
|
POPUP_CONFIRMATION(STR_CONFIRMRESET, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -149,7 +149,7 @@ void menuStatisticsDebug(event_t event)
|
||||||
#if defined(WATCHDOG_TEST)
|
#if defined(WATCHDOG_TEST)
|
||||||
case EVT_KEY_LONG(KEY_MENU):
|
case EVT_KEY_LONG(KEY_MENU):
|
||||||
{
|
{
|
||||||
POPUP_CONFIRMATION("Test the watchdog?");
|
POPUP_CONFIRMATION("Test the watchdog?", nullptr);
|
||||||
const char * w = "The radio will reset!";
|
const char * w = "The radio will reset!";
|
||||||
SET_WARNING_INFO(w, strlen(w), 0);
|
SET_WARNING_INFO(w, strlen(w), 0);
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,7 +82,7 @@ void onSdManagerMenu(const char * result)
|
||||||
pushMenu(menuRadioSdManagerInfo);
|
pushMenu(menuRadioSdManagerInfo);
|
||||||
}
|
}
|
||||||
else if (result == STR_SD_FORMAT) {
|
else if (result == STR_SD_FORMAT) {
|
||||||
POPUP_CONFIRMATION(STR_CONFIRM_FORMAT);
|
POPUP_CONFIRMATION(STR_CONFIRM_FORMAT, nullptr);
|
||||||
}
|
}
|
||||||
else if (result == STR_COPY_FILE) {
|
else if (result == STR_COPY_FILE) {
|
||||||
clipboard.type = CLIPBOARD_TYPE_SD_FILE;
|
clipboard.type = CLIPBOARD_TYPE_SD_FILE;
|
||||||
|
|
|
@ -2041,7 +2041,7 @@ uint32_t pwrCheck()
|
||||||
lcdRefreshWait();
|
lcdRefreshWait();
|
||||||
lcdClear();
|
lcdClear();
|
||||||
|
|
||||||
POPUP_CONFIRMATION(STR_MODEL_SHUTDOWN);
|
POPUP_CONFIRMATION(STR_MODEL_SHUTDOWN, nullptr);
|
||||||
SET_WARNING_INFO(STR_MODEL_STILL_POWERED, sizeof(TR_MODEL_STILL_POWERED), 0);
|
SET_WARNING_INFO(STR_MODEL_STILL_POWERED, sizeof(TR_MODEL_STILL_POWERED), 0);
|
||||||
event_t evt = getEvent(false);
|
event_t evt = getEvent(false);
|
||||||
DISPLAY_WARNING(evt);
|
DISPLAY_WARNING(evt);
|
||||||
|
|
|
@ -1144,10 +1144,10 @@ union ReusableBuffer
|
||||||
struct {
|
struct {
|
||||||
uint8_t state; // 0x00 = READ 0x40 = WRITE
|
uint8_t state; // 0x00 = READ 0x40 = WRITE
|
||||||
tmr10ms_t timeout;
|
tmr10ms_t timeout;
|
||||||
tmr10ms_t dirtyTimeout;
|
|
||||||
tmr10ms_t updateTime;
|
tmr10ms_t updateTime;
|
||||||
uint8_t receiverId;
|
uint8_t receiverId;
|
||||||
uint8_t channelMapping[24];
|
uint8_t outputsCount;
|
||||||
|
uint8_t outputsMapping[24];
|
||||||
uint8_t telemetryDisabled;
|
uint8_t telemetryDisabled;
|
||||||
uint8_t pwmRate;
|
uint8_t pwmRate;
|
||||||
uint8_t dirty;
|
uint8_t dirty;
|
||||||
|
|
|
@ -162,15 +162,17 @@ void Pxx2Pulses::setupReceiverSettingsFrame(uint8_t module)
|
||||||
if (reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_WRITE)
|
if (reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_WRITE)
|
||||||
flag0 |= PXX2_RX_SETTINGS_FLAG0_WRITE;
|
flag0 |= PXX2_RX_SETTINGS_FLAG0_WRITE;
|
||||||
Pxx2Transport::addByte(flag0);
|
Pxx2Transport::addByte(flag0);
|
||||||
uint8_t flag1 = 0;
|
if (reusableBuffer.receiverSetup.state == RECEIVER_SETTINGS_WRITE) {
|
||||||
if (reusableBuffer.receiverSetup.telemetryDisabled)
|
uint8_t flag1 = 0;
|
||||||
flag1 |= PXX2_RX_SETTINGS_FLAG1_TELEMETRY_DISABLED;
|
if (reusableBuffer.receiverSetup.telemetryDisabled)
|
||||||
if (reusableBuffer.receiverSetup.pwmRate)
|
flag1 |= PXX2_RX_SETTINGS_FLAG1_TELEMETRY_DISABLED;
|
||||||
flag1 |= PXX2_RX_SETTINGS_FLAG1_FASTPWM;
|
if (reusableBuffer.receiverSetup.pwmRate)
|
||||||
Pxx2Transport::addByte(flag1);
|
flag1 |= PXX2_RX_SETTINGS_FLAG1_FASTPWM;
|
||||||
uint8_t channelsCount = sentModuleChannels(module);
|
Pxx2Transport::addByte(flag1);
|
||||||
for (int i = 0; i < channelsCount; i++) {
|
uint8_t outputsCount = min<uint8_t>(16, reusableBuffer.receiverSetup.outputsCount);
|
||||||
Pxx2Transport::addByte(reusableBuffer.receiverSetup.channelMapping[i]);
|
for (int i = 0; i < outputsCount; i++) {
|
||||||
|
Pxx2Transport::addByte(reusableBuffer.receiverSetup.outputsMapping[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
reusableBuffer.receiverSetup.timeout = get_tmr10ms() + 200/*next try in 2s*/;
|
reusableBuffer.receiverSetup.timeout = get_tmr10ms() + 200/*next try in 2s*/;
|
||||||
}
|
}
|
||||||
|
|
|
@ -751,8 +751,8 @@
|
||||||
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_DMA2)
|
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_DMA2)
|
||||||
#define EXTMODULE_PWR_GPIO GPIOA
|
#define EXTMODULE_PWR_GPIO GPIOA
|
||||||
#define EXTMODULE_PWR_GPIO_PIN GPIO_Pin_8 // PA.08
|
#define EXTMODULE_PWR_GPIO_PIN GPIO_Pin_8 // PA.08
|
||||||
#define EXTERNAL_MODULE_ON() GPIO_ResetBits(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN)
|
#define EXTERNAL_MODULE_ON() GPIO_SetBits(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN)
|
||||||
#define EXTERNAL_MODULE_OFF() GPIO_SetBits(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN)
|
#define EXTERNAL_MODULE_OFF() GPIO_ResetBits(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN)
|
||||||
#define IS_EXTERNAL_MODULE_ON() (GPIO_ReadInputDataBit(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN) == Bit_RESET)
|
#define IS_EXTERNAL_MODULE_ON() (GPIO_ReadInputDataBit(EXTMODULE_PWR_GPIO, EXTMODULE_PWR_GPIO_PIN) == Bit_RESET)
|
||||||
#else
|
#else
|
||||||
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_DMA2)
|
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOC | RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_DMA2)
|
||||||
|
|
|
@ -66,17 +66,18 @@ void processReceiverSettingsFrame(uint8_t module, uint8_t * frame)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t channelsCount = sentModuleChannels(module);
|
|
||||||
for (uint8_t pin = 0; pin < channelsCount; pin++) {
|
|
||||||
reusableBuffer.receiverSetup.channelMapping[pin] = frame[5 + pin];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (frame[4] & PXX2_RX_SETTINGS_FLAG1_FASTPWM)
|
if (frame[4] & PXX2_RX_SETTINGS_FLAG1_FASTPWM)
|
||||||
reusableBuffer.receiverSetup.pwmRate = 1;
|
reusableBuffer.receiverSetup.pwmRate = 1;
|
||||||
|
|
||||||
if (frame[4] & PXX2_RX_SETTINGS_FLAG1_TELEMETRY_DISABLED)
|
if (frame[4] & PXX2_RX_SETTINGS_FLAG1_TELEMETRY_DISABLED)
|
||||||
reusableBuffer.receiverSetup.telemetryDisabled = 1;
|
reusableBuffer.receiverSetup.telemetryDisabled = 1;
|
||||||
|
|
||||||
|
uint8_t outputsCount = min<uint8_t>(16, frame[0] - 4);
|
||||||
|
reusableBuffer.receiverSetup.outputsCount = outputsCount;
|
||||||
|
for (uint8_t pin = 0; pin < outputsCount; pin++) {
|
||||||
|
reusableBuffer.receiverSetup.outputsMapping[pin] = frame[5 + pin];
|
||||||
|
}
|
||||||
|
|
||||||
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_OK;
|
reusableBuffer.receiverSetup.state = RECEIVER_SETTINGS_OK;
|
||||||
reusableBuffer.receiverSetup.timeout = 0;
|
reusableBuffer.receiverSetup.timeout = 0;
|
||||||
moduleSettings[module].mode = MODULE_MODE_NORMAL;
|
moduleSettings[module].mode = MODULE_MODE_NORMAL;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue