1
0
Fork 0
mirror of https://github.com/opentx/opentx.git synced 2025-07-23 16:25:16 +03:00

Fixes #1092 - Chronos names

This commit is contained in:
bsongis 2014-08-18 13:00:10 +02:00
parent 2d43ecdd05
commit 1454eff428
23 changed files with 281 additions and 190 deletions

View file

@ -914,10 +914,13 @@ class MavlinkData {
void clear() { memset(this, 0, sizeof(MavlinkData)); } void clear() { memset(this, 0, sizeof(MavlinkData)); }
}; };
#define TIMER_NAME_LEN 8
class TimerData { class TimerData {
public: public:
TimerData() { clear(); } TimerData() { clear(); }
RawSwitch mode; RawSwitch mode;
char name[TIMER_NAME_LEN+1];
bool minuteBeep; bool minuteBeep;
unsigned int countdownBeep; unsigned int countdownBeep;
unsigned int val; unsigned int val;
@ -1063,6 +1066,7 @@ enum Capability {
Imperial, Imperial,
Mixes, Mixes,
Timers, Timers,
TimersName,
TimeDivisions, TimeDivisions,
CustomFunctions, CustomFunctions,
SafetyChannelCustomFunction, SafetyChannelCustomFunction,

View file

@ -2452,6 +2452,10 @@ OpenTxModelData::OpenTxModelData(ModelData & modelData, BoardEnum board, unsigne
internalField.Append(new SpareBitsField<3>()); internalField.Append(new SpareBitsField<3>());
internalField.Append(new UnsignedField<24>(modelData.timers[i].val)); internalField.Append(new UnsignedField<24>(modelData.timers[i].val));
internalField.Append(new SignedField<24>(modelData.timers[i].pvalue)); internalField.Append(new SignedField<24>(modelData.timers[i].pvalue));
if (IS_TARANIS(board))
internalField.Append(new ZCharField<8>(modelData.timers[i].name));
else
internalField.Append(new ZCharField<3>(modelData.timers[i].name));
} }
else if ((IS_ARM(board) || IS_2560(board)) && version >= 216) { else if ((IS_ARM(board) || IS_2560(board)) && version >= 216) {
internalField.Append(new UnsignedField<16>(modelData.timers[i].val)); internalField.Append(new UnsignedField<16>(modelData.timers[i].val));

View file

@ -561,6 +561,8 @@ int OpenTxFirmware::getCapability(const Capability capability)
return (IS_ARM(board) ? 500 : 245); return (IS_ARM(board) ? 500 : 245);
case Timers: case Timers:
return (IS_ARM(board) ? 3 : 2); return (IS_ARM(board) ? 3 : 2);
case TimersName:
return (IS_TARANIS(board) ? 8 : (IS_ARM(board) ? 3 : 0));
case PermTimers: case PermTimers:
if (board == BOARD_GRUVIN9X || IS_ARM(board)) if (board == BOARD_GRUVIN9X || IS_ARM(board))
return 1; return 1;

View file

@ -10,10 +10,22 @@ TimerPanel::TimerPanel(QWidget *parent, ModelData & model, TimerData & timer, Ge
timer(timer), timer(timer),
ui(new Ui::Timer) ui(new Ui::Timer)
{ {
BoardEnum board = firmware->getBoard();
ui->setupUi(this); ui->setupUi(this);
lock = true; lock = true;
// Name
int length = firmware->getCapability(TimersName);
if (length == 0) {
ui->name->hide();
}
else {
ui->name->setMaxLength(length);
ui->name->setText(timer.name);
}
// Mode // Mode
populateSwitchCB(ui->mode, timer.mode, generalSettings, TimersContext); populateSwitchCB(ui->mode, timer.mode, generalSettings, TimersContext);
@ -25,7 +37,7 @@ TimerPanel::TimerPanel(QWidget *parent, ModelData & model, TimerData & timer, Ge
ui->countdownBeep->setField(&timer.countdownBeep, this); ui->countdownBeep->setField(&timer.countdownBeep, this);
ui->countdownBeep->addItem(tr("Silent"), 0); ui->countdownBeep->addItem(tr("Silent"), 0);
ui->countdownBeep->addItem(tr("Beeps"), 1); ui->countdownBeep->addItem(tr("Beeps"), 1);
if (IS_ARM(GetEepromInterface()->getBoard()) || IS_2560(GetEepromInterface()->getBoard())) { if (IS_ARM(board) || IS_2560(board)) {
ui->countdownBeep->addItem(tr("Voice"), 2); ui->countdownBeep->addItem(tr("Voice"), 2);
} }
@ -87,6 +99,13 @@ void TimerPanel::on_minuteBeep_toggled(bool checked)
emit modified(); emit modified();
} }
void TimerPanel::on_name_editingFinished()
{
int length = ui->name->maxLength();
strncpy(timer.name, ui->name->text().toAscii(), length);
emit modified();
}
/******************************************************************************/ /******************************************************************************/
ModulePanel::ModulePanel(QWidget *parent, ModelData & model, ModuleData & module, GeneralSettings & generalSettings, FirmwareInterface * firmware, int moduleIdx): ModulePanel::ModulePanel(QWidget *parent, ModelData & model, ModuleData & module, GeneralSettings & generalSettings, FirmwareInterface * firmware, int moduleIdx):
@ -336,13 +355,15 @@ SetupPanel::SetupPanel(QWidget *parent, ModelData & model, GeneralSettings & gen
ModelPanel(parent, model, generalSettings, firmware), ModelPanel(parent, model, generalSettings, firmware),
ui(new Ui::Setup) ui(new Ui::Setup)
{ {
BoardEnum board = firmware->getBoard();
lock = true; lock = true;
memset(modules, 0, sizeof(modules)); memset(modules, 0, sizeof(modules));
ui->setupUi(this); ui->setupUi(this);
ui->name->setMaxLength(IS_TARANIS(firmware->getBoard()) ? 12 : 10); ui->name->setMaxLength(IS_TARANIS(board) ? 12 : 10);
for (int i=0; i<C9X_MAX_TIMERS; i++) { for (int i=0; i<C9X_MAX_TIMERS; i++) {
if (i<firmware->getCapability(Timers)) { if (i<firmware->getCapability(Timers)) {
@ -428,7 +449,7 @@ SetupPanel::SetupPanel(QWidget *parent, ModelData & model, GeneralSettings & gen
ui->centerBeepLayout->addWidget(checkbox, 0, i+1); ui->centerBeepLayout->addWidget(checkbox, 0, i+1);
connect(checkbox, SIGNAL(toggled(bool)), this, SLOT(onBeepCenterToggled(bool))); connect(checkbox, SIGNAL(toggled(bool)), this, SLOT(onBeepCenterToggled(bool)));
centerBeepCheckboxes << checkbox; centerBeepCheckboxes << checkbox;
if (!IS_TARANIS_PLUS(firmware->getBoard()) && i==6) { if (!IS_TARANIS_PLUS(board) && i==6) {
checkbox->hide(); checkbox->hide();
} }
} }
@ -448,7 +469,7 @@ SetupPanel::SetupPanel(QWidget *parent, ModelData & model, GeneralSettings & gen
slider->setTickInterval(1); slider->setTickInterval(1);
slider->setMinimumSize(QSize(30, 50)); slider->setMinimumSize(QSize(30, 50));
slider->setMaximumSize(QSize(50, 50)); slider->setMaximumSize(QSize(50, 50));
if (IS_TARANIS(GetEepromInterface()->getBoard())) { if (IS_TARANIS(board)) {
label->setText(switchesX9D[i]); label->setText(switchesX9D[i]);
slider->setMaximum(i==5 ? 1 : 2); slider->setMaximum(i==5 ? 1 : 2);
} }
@ -471,7 +492,7 @@ SetupPanel::SetupPanel(QWidget *parent, ModelData & model, GeneralSettings & gen
ui->switchesStartupLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Expanding, QSizePolicy::Minimum), 0, firmware->getCapability(Switches)); ui->switchesStartupLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Expanding, QSizePolicy::Minimum), 0, firmware->getCapability(Switches));
// Pot warnings // Pot warnings
if (IS_TARANIS(firmware->getBoard())) { if (IS_TARANIS(board)) {
for (int i=0; i<firmware->getCapability(Pots); i++) { for (int i=0; i<firmware->getCapability(Pots); i++) {
QCheckBox * cb = new QCheckBox(this); QCheckBox * cb = new QCheckBox(this);
cb->setProperty("index", i+1); cb->setProperty("index", i+1);
@ -479,7 +500,7 @@ SetupPanel::SetupPanel(QWidget *parent, ModelData & model, GeneralSettings & gen
ui->potWarningLayout->addWidget(cb, 0, i+1); ui->potWarningLayout->addWidget(cb, 0, i+1);
connect(cb, SIGNAL(toggled(bool)), this, SLOT(potWarningToggled(bool))); connect(cb, SIGNAL(toggled(bool)), this, SLOT(potWarningToggled(bool)));
potWarningCheckboxes << cb; potWarningCheckboxes << cb;
if (!IS_TARANIS_PLUS(firmware->getBoard()) && i==2) { if (!IS_TARANIS_PLUS(board) && i==2) {
cb->hide(); cb->hide();
} }
} }

View file

@ -29,6 +29,7 @@ class TimerPanel : public ModelPanel
void on_mode_currentIndexChanged(int index); void on_mode_currentIndexChanged(int index);
void on_value_editingFinished(); void on_value_editingFinished();
void on_minuteBeep_toggled(bool checked); void on_minuteBeep_toggled(bool checked);
void on_name_editingFinished();
private: private:
TimerData & timer; TimerData & timer;

View file

@ -2,21 +2,37 @@
<ui version="4.0"> <ui version="4.0">
<class>Timer</class> <class>Timer</class>
<widget class="QWidget" name="Timer"> <widget class="QWidget" name="Timer">
<property name="enabled">
<bool>true</bool>
</property>
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>586</width> <width>626</width>
<height>38</height> <height>33</height>
</rect> </rect>
</property> </property>
<property name="windowTitle"> <property name="windowTitle">
<string/> <string/>
</property> </property>
<layout class="QHBoxLayout" name="horizontalLayout_2"> <layout class="QHBoxLayout" name="horizontalLayout_2">
<property name="spacing">
<number>-1</number>
</property>
<property name="margin"> <property name="margin">
<number>0</number> <number>0</number>
</property> </property>
<item>
<widget class="QLineEdit" name="name">
<property name="minimumSize">
<size>
<width>80</width>
<height>0</height>
</size>
</property>
</widget>
</item>
<item> <item>
<widget class="QTimeEdit" name="value"> <widget class="QTimeEdit" name="value">
<property name="accelerated"> <property name="accelerated">

View file

@ -218,7 +218,7 @@ PACK(typedef struct {
PACK(typedef struct { PACK(typedef struct {
int16_t trim[4]; int16_t trim[4];
int8_t swtch; // swtch of phase[0] is not used int8_t swtch; // swtch of phase[0] is not used
char name[LEN_FP_NAME]; char name[LEN_FLIGHT_MODE_NAME];
uint8_t fadeIn; uint8_t fadeIn;
uint8_t fadeOut; uint8_t fadeOut;
ROTARY_ENCODER_ARRAY; ROTARY_ENCODER_ARRAY;

View file

@ -874,14 +874,17 @@ enum menuModelSetupItems {
ITEM_MODEL_NAME, ITEM_MODEL_NAME,
CASE_PCBTARANIS(ITEM_MODEL_BITMAP) CASE_PCBTARANIS(ITEM_MODEL_BITMAP)
ITEM_MODEL_TIMER1, ITEM_MODEL_TIMER1,
CASE_CPUARM(ITEM_MODEL_TIMER1_NAME)
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,
ITEM_MODEL_TIMER2, ITEM_MODEL_TIMER2,
CASE_CPUARM(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,
CASE_CPUARM(ITEM_MODEL_TIMER3) CASE_CPUARM(ITEM_MODEL_TIMER3)
CASE_CPUARM(ITEM_MODEL_TIMER3_NAME)
CASE_CPUARM(ITEM_MODEL_TIMER3_PERSISTENT) CASE_CPUARM(ITEM_MODEL_TIMER3_PERSISTENT)
CASE_CPUARM(ITEM_MODEL_TIMER3_MINUTE_BEEP) CASE_CPUARM(ITEM_MODEL_TIMER3_MINUTE_BEEP)
CASE_CPUARM(ITEM_MODEL_TIMER3_COUNTDOWN_BEEP) CASE_CPUARM(ITEM_MODEL_TIMER3_COUNTDOWN_BEEP)
@ -999,8 +1002,9 @@ void menuModelSetup(uint8_t event)
#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 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 MODEL_SETUP_MAX_LINES (1+ITEM_MODEL_SETUP_MAX) #define MODEL_SETUP_MAX_LINES (1+ITEM_MODEL_SETUP_MAX)
#define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0) #define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0)
#define TIMER_ROWS 2, 0, CASE_PERSISTENT_TIMERS(0) 0, 0
bool CURSOR_ON_CELL = (m_posHorz >= 0); bool CURSOR_ON_CELL = (m_posHorz >= 0);
MENU_TAB({ 0, 0, CASE_PCBTARANIS(0) 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 0, 1, 0, CASE_PCBTARANIS(LABEL(Throttle)) 0, 0, 0, CASE_CPUARM(LABEL(PreflightCheck)) CASE_CPUARM(0) 0, 7, POT_WARN_ITEMS(), NAVIGATION_LINE_BY_LINE|(NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1), 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_TAB({ 0, 0, CASE_PCBTARANIS(0) TIMER_ROWS, TIMER_ROWS, TIMER_ROWS, 0, 1, 0, CASE_PCBTARANIS(LABEL(Throttle)) 0, 0, 0, CASE_CPUARM(LABEL(PreflightCheck)) CASE_CPUARM(0) 0, 7, POT_WARN_ITEMS(), NAVIGATION_LINE_BY_LINE|(NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1), 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)});
#elif defined(CPUARM) #elif defined(CPUARM)
#define IF_EXTERNAL_MODULE_XJT(x) (IS_MODULE_XJT(EXTERNAL_MODULE) ? (uint8_t)x : HIDDEN_ROW) #define IF_EXTERNAL_MODULE_XJT(x) (IS_MODULE_XJT(EXTERNAL_MODULE) ? (uint8_t)x : HIDDEN_ROW)
#define IF_EXTERNAL_MODULE_ON(x) (g_model.externalModule == MODULE_TYPE_NONE ? HIDDEN_ROW : (uint8_t)(x)) #define IF_EXTERNAL_MODULE_ON(x) (g_model.externalModule == MODULE_TYPE_NONE ? HIDDEN_ROW : (uint8_t)(x))
@ -1012,13 +1016,14 @@ void menuModelSetup(uint8_t event)
#define CURSOR_ON_CELL (true) #define CURSOR_ON_CELL (true)
#define MODEL_SETUP_MAX_LINES (1+ITEM_MODEL_SETUP_MAX) #define MODEL_SETUP_MAX_LINES (1+ITEM_MODEL_SETUP_MAX)
#define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0) #define POT_WARN_ITEMS() ((g_model.nPotsToWarn >> 6) ? (uint8_t)NUM_POTS : (uint8_t)0)
#define TIMER_ROWS 2, 0, CASE_PERSISTENT_TIMERS(0) 0, 0
#if (defined(PCBSKY9X) && !defined(REVA) && !defined(REVX)) #if (defined(PCBSKY9X) && !defined(REVA) && !defined(REVX))
#define EXTRA_MODULE_ROWS LABEL(ExtraModule), 1, 2, #define EXTRA_MODULE_ROWS LABEL(ExtraModule), 1, 2,
#else #else
#define EXTRA_MODULE_ROWS #define EXTRA_MODULE_ROWS
#endif #endif
#define TRAINER_MODULE_ROWS #define TRAINER_MODULE_ROWS
MENU_TAB({ 0, 0, 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 2, CASE_PERSISTENT_TIMERS(0) 0, 0, 0, 1, 0, CASE_PCBTARANIS(LABEL(Throttle)) 0, 0, 0, CASE_CPUARM(LABEL(PreflightCheck)) CASE_CPUARM(0) 0, 6, NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1, 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)), EXTRA_MODULE_ROWS TRAINER_MODULE_ROWS }); MENU_TAB({ 0, 0, TIMER_ROWS, TIMER_ROWS, TIMER_ROWS, 0, 1, 0, CASE_PCBTARANIS(LABEL(Throttle)) 0, 0, 0, CASE_CPUARM(LABEL(PreflightCheck)) CASE_CPUARM(0) 0, 6, NUM_STICKS+NUM_POTS+NUM_ROTARY_ENCODERS-1, 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)), EXTRA_MODULE_ROWS TRAINER_MODULE_ROWS });
#elif defined(CPUM64) #elif defined(CPUM64)
#define CURSOR_ON_CELL (true) #define CURSOR_ON_CELL (true)
#define MODEL_SETUP_MAX_LINES ((IS_PPM_PROTOCOL(protocol)||IS_DSM2_PROTOCOL(protocol)||IS_PXX_PROTOCOL(protocol)) ? 1+ITEM_MODEL_SETUP_MAX : ITEM_MODEL_SETUP_MAX) #define MODEL_SETUP_MAX_LINES ((IS_PPM_PROTOCOL(protocol)||IS_DSM2_PROTOCOL(protocol)||IS_PXX_PROTOCOL(protocol)) ? 1+ITEM_MODEL_SETUP_MAX : ITEM_MODEL_SETUP_MAX)
@ -1095,22 +1100,10 @@ void menuModelSetup(uint8_t event)
case ITEM_MODEL_TIMER1: case ITEM_MODEL_TIMER1:
case ITEM_MODEL_TIMER2: case ITEM_MODEL_TIMER2:
case ITEM_MODEL_TIMER3: case ITEM_MODEL_TIMER3:
case ITEM_MODEL_TIMER1_MINUTE_BEEP:
case ITEM_MODEL_TIMER2_MINUTE_BEEP:
case ITEM_MODEL_TIMER3_MINUTE_BEEP:
case ITEM_MODEL_TIMER1_COUNTDOWN_BEEP:
case ITEM_MODEL_TIMER2_COUNTDOWN_BEEP:
case ITEM_MODEL_TIMER3_COUNTDOWN_BEEP:
{ {
TimerData *timer = &g_model.timers[k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0)]; unsigned int timerIdx = (k>=ITEM_MODEL_TIMER3 ? 2 : (k>=ITEM_MODEL_TIMER2 ? 1 : 0));
if (k==ITEM_MODEL_TIMER1_MINUTE_BEEP || k==ITEM_MODEL_TIMER2_MINUTE_BEEP || k==ITEM_MODEL_TIMER3_MINUTE_BEEP) { TimerData * timer = &g_model.timers[timerIdx];
timer->minuteBeep = onoffMenuItem(timer->minuteBeep, MODEL_SETUP_2ND_COLUMN, y, STR_MINUTEBEEP, attr, event); putsStrIdx(0*FW, y, STR_TIMER, timerIdx+1);
}
else if (k==ITEM_MODEL_TIMER1_COUNTDOWN_BEEP || k==ITEM_MODEL_TIMER2_COUNTDOWN_BEEP || k==ITEM_MODEL_TIMER3_COUNTDOWN_BEEP) {
timer->countdownBeep = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_BEEPCOUNTDOWN, STR_VBEEPCOUNTDOWN, timer->countdownBeep, 0, 2, attr, event);
}
else {
putsStrIdx(0*FW, y, STR_TIMER, k>=ITEM_MODEL_TIMER3 ? 3 : (k>=ITEM_MODEL_TIMER2 ? 2 : 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 defined(PCBTARANIS) #if defined(PCBTARANIS)
@ -1133,7 +1126,33 @@ void menuModelSetup(uint8_t event)
break; break;
} }
} }
break;
} }
case ITEM_MODEL_TIMER1_NAME:
case ITEM_MODEL_TIMER2_NAME:
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;
}
case ITEM_MODEL_TIMER1_MINUTE_BEEP:
case ITEM_MODEL_TIMER2_MINUTE_BEEP:
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;
}
case ITEM_MODEL_TIMER1_COUNTDOWN_BEEP:
case ITEM_MODEL_TIMER2_COUNTDOWN_BEEP:
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;
} }
@ -1141,8 +1160,8 @@ void menuModelSetup(uint8_t event)
case ITEM_MODEL_TIMER2_PERSISTENT: case ITEM_MODEL_TIMER2_PERSISTENT:
case ITEM_MODEL_TIMER3_PERSISTENT: case ITEM_MODEL_TIMER3_PERSISTENT:
{ {
TimerData &timer = g_model.timers[k==ITEM_MODEL_TIMER3_PERSISTENT ? 2 : (k==ITEM_MODEL_TIMER2_PERSISTENT ? 1 : 0)]; 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); timer->persistent = selectMenuItem(MODEL_SETUP_2ND_COLUMN, y, STR_PERSISTENT, STR_VPERSISTENT, timer->persistent, 0, 2, attr, event);
break; break;
} }
#else #else
@ -1988,7 +2007,7 @@ void menuModelFlightModesAll(uint8_t event)
break; break;
case ITEM_FLIGHT_MODES_SWITCH: case ITEM_FLIGHT_MODES_SWITCH:
putsSwitches((5+LEN_FP_NAME)*FW+FW/2, y, p->swtch, attr); putsSwitches((5+LEN_FLIGHT_MODE_NAME)*FW+FW/2, y, p->swtch, attr);
if (active) CHECK_INCDEC_MODELSWITCH(event, p->swtch, SWSRC_FIRST_IN_MIXES, SWSRC_LAST_IN_MIXES, isSwitchAvailableInMixes); if (active) CHECK_INCDEC_MODELSWITCH(event, p->swtch, SWSRC_FIRST_IN_MIXES, SWSRC_LAST_IN_MIXES, isSwitchAvailableInMixes);
break; break;
@ -1998,7 +2017,7 @@ void menuModelFlightModesAll(uint8_t event)
case ITEM_FLIGHT_MODES_TRIM_AIL: case ITEM_FLIGHT_MODES_TRIM_AIL:
{ {
uint8_t t = j-ITEM_FLIGHT_MODES_TRIM_RUD; uint8_t t = j-ITEM_FLIGHT_MODES_TRIM_RUD;
putsTrimMode((4+LEN_FP_NAME)*FW+j*(5*FW/2), y, k, t, attr); putsTrimMode((4+LEN_FLIGHT_MODE_NAME)*FW+j*(5*FW/2), y, k, t, attr);
if (active) { if (active) {
trim_t & v = p->trim[t]; trim_t & v = p->trim[t];
v.mode = checkIncDec(event, v.mode==TRIM_MODE_NONE ? -1 : v.mode, -1, k==0 ? 0 : 2*MAX_FLIGHT_MODES-1, EE_MODEL, isTrimModeAvailable); v.mode = checkIncDec(event, v.mode==TRIM_MODE_NONE ? -1 : v.mode, -1, k==0 ? 0 : 2*MAX_FLIGHT_MODES-1, EE_MODEL, isTrimModeAvailable);
@ -2231,16 +2250,16 @@ void menuModelFlightModesAll(uint8_t event)
lcd_putsnAtt(4*FW+NAME_OFS, y, p->name, sizeof(p->name), ZCHAR); lcd_putsnAtt(4*FW+NAME_OFS, y, p->name, sizeof(p->name), ZCHAR);
if (i == 0) { if (i == 0) {
lcd_puts((5+LEN_FP_NAME)*FW+SWITCH_OFS, y, STR_DEFAULT); lcd_puts((5+LEN_FLIGHT_MODE_NAME)*FW+SWITCH_OFS, y, STR_DEFAULT);
} }
else { else {
putsSwitches((5+LEN_FP_NAME)*FW+SWITCH_OFS, y, p->swtch, 0); putsSwitches((5+LEN_FLIGHT_MODE_NAME)*FW+SWITCH_OFS, y, p->swtch, 0);
for (uint8_t t=0; t<NUM_STICKS; t++) { for (uint8_t t=0; t<NUM_STICKS; t++) {
putsTrimMode((9+LEN_FP_NAME+t)*FW+TRIMS_OFS, y, i, t, 0); putsTrimMode((9+LEN_FLIGHT_MODE_NAME+t)*FW+TRIMS_OFS, y, i, t, 0);
} }
#if defined(PCBGRUVIN9X) #if defined(PCBGRUVIN9X)
for (uint8_t t=0; t<NUM_ROTARY_ENCODERS; t++) { for (uint8_t t=0; t<NUM_ROTARY_ENCODERS; t++) {
putsRotaryEncoderMode((13+LEN_FP_NAME+t)*FW+TRIMS_OFS+ROTARY_ENC_OFS, y, i, t, 0); putsRotaryEncoderMode((13+LEN_FLIGHT_MODE_NAME+t)*FW+TRIMS_OFS+ROTARY_ENC_OFS, y, i, t, 0);
} }
#endif #endif
} }

View file

@ -54,8 +54,8 @@
#define PHASE_Y (3*FH) #define PHASE_Y (3*FH)
#define PHASE_FLAGS (0) #define PHASE_FLAGS (0)
#define TIMERS_X 145 #define TIMERS_X 145
#define TIMER1_Y 20 #define TIMERS_Y 20
#define TIMER2_Y 45 #define TIMERS_H 25
#define TIMERS_R 193 #define TIMERS_R 193
#define REBOOT_X (LCD_W-FW) #define REBOOT_X (LCD_W-FW)
#define VSWITCH_X(i) (((i>=NUM_LOGICAL_SWITCH*3/4) ? BITMAP_X+28 : ((i>=NUM_LOGICAL_SWITCH/2) ? BITMAP_X+25 : ((i>=NUM_LOGICAL_SWITCH/4) ? 21 : 18))) + 3*i) #define VSWITCH_X(i) (((i>=NUM_LOGICAL_SWITCH*3/4) ? BITMAP_X+28 : ((i>=NUM_LOGICAL_SWITCH/2) ? BITMAP_X+25 : ((i>=NUM_LOGICAL_SWITCH/4) ? 21 : 18))) + 3*i)
@ -366,34 +366,31 @@ void displayTopBar()
#if LCD_W >= 212 #if LCD_W >= 212
void displayTimers() void displayTimers()
{ {
// Main timer // Main and Second timer
if (g_model.timers[0].mode) { for (unsigned int i=0; i<2; i++) {
TimerState & timerState = timersStates[0]; if (g_model.timers[i].mode) {
putsTimerMode(TIMERS_X, TIMER1_Y-6, g_model.timers[0].mode, SMLSIZE); TimerState & timerState = timersStates[i];
putsTimer(TIMERS_X, TIMER1_Y, timerState.val, TIMEHOUR|MIDSIZE|LEFT, TIMEHOUR|MIDSIZE|LEFT); TimerData & timerData = g_model.timers[i];
if (g_model.timers[0].persistent) lcd_putcAtt(TIMERS_R, TIMER1_Y+1, 'P', SMLSIZE); uint8_t y = TIMERS_Y + i*TIMERS_H;
if (zlen(timerData.name, LEN_TIMER_NAME) > 0) {
lcd_putsnAtt(TIMERS_X, y-7, timerData.name, LEN_TIMER_NAME, ZCHAR|SMLSIZE);
}
else {
putsTimerMode(TIMERS_X, y-7, timerData.mode, SMLSIZE);
}
putsTimer(TIMERS_X, y, timerState.val, TIMEHOUR|MIDSIZE|LEFT, TIMEHOUR|MIDSIZE|LEFT);
if (timerData.persistent) {
lcd_putcAtt(TIMERS_R, y+1, 'P', SMLSIZE);
}
if (timerState.val < 0) { if (timerState.val < 0) {
if (BLINK_ON_PHASE) { if (BLINK_ON_PHASE) {
lcd_filled_rect(TIMERS_X-7, TIMER1_Y-7, 60, 19); lcd_filled_rect(TIMERS_X-7, y-8, 60, 20);
} }
} }
} }
// Second timer
if (g_model.timers[1].mode) {
TimerState & timerState = timersStates[1];
putsTimerMode(TIMERS_X, TIMER2_Y-6, g_model.timers[1].mode, SMLSIZE);
putsTimer(TIMERS_X, TIMER2_Y, timerState.val, TIMEHOUR|MIDSIZE|LEFT, TIMEHOUR|MIDSIZE|LEFT);
if (g_model.timers[1].persistent) lcd_putcAtt(TIMERS_R, TIMER2_Y+1, 'P', SMLSIZE);
if (timerState.val < 0) {
if (BLINK_ON_PHASE) {
lcd_filled_rect(TIMERS_X-7, TIMER2_Y-7, 60, 19);
}
}
} }
} }
#else #else
void displayTimers() void displayTimers()
{ {
#if defined(TRANSLATIONS_CZ) #if defined(TRANSLATIONS_CZ)
@ -406,7 +403,19 @@ void displayTimers()
TimerState & timerState = timersStates[0]; TimerState & timerState = timersStates[0];
uint8_t att = DBLSIZE | (timerState.val<0 ? BLINK|INVERS : 0); uint8_t att = DBLSIZE | (timerState.val<0 ? BLINK|INVERS : 0);
putsTimer(12*FW+2+10*FWNUM-4, FH*2, timerState.val, att, att); putsTimer(12*FW+2+10*FWNUM-4, FH*2, timerState.val, att, att);
putsTimerMode(timerState.val >= 0 ? MAINTMR_LBL_COL : MAINTMR_LBL_COL-7, FH*3, g_model.timers[0].mode); uint8_t xLabel = (timerState.val >= 0 ? MAINTMR_LBL_COL : MAINTMR_LBL_COL-7);
#if defined(CPUARM)
uint8_t len = zlen(g_model.timers[0].name, LEN_TIMER_NAME);
if (len > 0) {
xLabel += (LEN_TIMER_NAME-len)*FW;
lcd_putsnAtt(xLabel, FH*3, g_model.timers[0].name, len, ZCHAR);
}
else {
putsTimerMode(xLabel, FH*3, g_model.timers[0].mode);
}
#else
putsTimerMode(xLabel, FH*3, g_model.timers[0].mode);
#endif
} }
} }
#endif #endif

View file

@ -160,9 +160,10 @@
#if defined(PCBTARANIS) #if defined(PCBTARANIS)
#define LEN_MODEL_NAME 12 #define LEN_MODEL_NAME 12
#define LEN_TIMER_NAME 8
#define LEN_FLIGHT_MODE_NAME 10
#define LEN_BITMAP_NAME 10 #define LEN_BITMAP_NAME 10
#define LEN_EXPOMIX_NAME 8 #define LEN_EXPOMIX_NAME 8
#define LEN_FP_NAME 10
#define LEN_CHANNEL_NAME 6 #define LEN_CHANNEL_NAME 6
#define LEN_INPUT_NAME 4 #define LEN_INPUT_NAME 4
enum CurveType { enum CurveType {
@ -181,14 +182,15 @@ PACK(typedef struct t_CurveInfo {
#define CURVDATA CurveInfo #define CURVDATA CurveInfo
#elif defined(CPUARM) #elif defined(CPUARM)
#define LEN_MODEL_NAME 10 #define LEN_MODEL_NAME 10
#define LEN_TIMER_NAME 3
#define LEN_FLIGHT_MODE_NAME 6
#define LEN_EXPOMIX_NAME 6 #define LEN_EXPOMIX_NAME 6
#define LEN_FP_NAME 6
#define MAX_CURVES 16 #define MAX_CURVES 16
#define NUM_POINTS 512 #define NUM_POINTS 512
#define CURVDATA int16_t #define CURVDATA int16_t
#else #else
#define LEN_MODEL_NAME 10 #define LEN_MODEL_NAME 10
#define LEN_FP_NAME 6 #define LEN_FLIGHT_MODE_NAME 6
#define MAX_CURVES 8 #define MAX_CURVES 8
#define NUM_POINTS (112-MAX_CURVES) #define NUM_POINTS (112-MAX_CURVES)
#define CURVDATA int8_t #define CURVDATA int8_t
@ -1343,7 +1345,7 @@ PACK(typedef struct t_SwashRingData { // Swash Ring data
PACK(typedef struct t_FlightModeData { PACK(typedef struct t_FlightModeData {
TRIMS_ARRAY; TRIMS_ARRAY;
int8_t swtch; // swtch of phase[0] is not used int8_t swtch; // swtch of phase[0] is not used
char name[LEN_FP_NAME]; char name[LEN_FLIGHT_MODE_NAME];
uint8_t fadeIn; uint8_t fadeIn;
uint8_t fadeOut; uint8_t fadeOut;
ROTARY_ENCODER_ARRAY; ROTARY_ENCODER_ARRAY;
@ -1353,7 +1355,7 @@ PACK(typedef struct t_FlightModeData {
PACK(typedef struct t_FlightModeData { PACK(typedef struct t_FlightModeData {
TRIMS_ARRAY; TRIMS_ARRAY;
int8_t swtch; // swtch of phase[0] is not used int8_t swtch; // swtch of phase[0] is not used
char name[LEN_FP_NAME]; char name[LEN_FLIGHT_MODE_NAME];
uint8_t fadeIn:4; uint8_t fadeIn:4;
uint8_t fadeOut:4; uint8_t fadeOut:4;
ROTARY_ENCODER_ARRAY; ROTARY_ENCODER_ARRAY;
@ -1647,6 +1649,7 @@ PACK(typedef struct t_TimerData {
uint8_t spare:3; uint8_t spare:3;
uint32_t start:24; uint32_t start:24;
int32_t value:24; int32_t value:24;
char name[LEN_TIMER_NAME];
}) TimerData; }) TimerData;
#define IS_MANUAL_RESET_TIMER(idx) (g_model.timers[idx].persistent == 2) #define IS_MANUAL_RESET_TIMER(idx) (g_model.timers[idx].persistent == 2)
#elif defined(CPUM2560) #elif defined(CPUM2560)

View file

@ -1578,7 +1578,7 @@ uint8_t zlen(const char *str, uint8_t size);
bool zexist(const char *str, uint8_t size); bool zexist(const char *str, uint8_t size);
char * strcat_zchar(char * dest, char * name, uint8_t size, const char *defaultName, uint8_t defaultNameSize, uint8_t defaultIdx); char * strcat_zchar(char * dest, char * name, uint8_t size, const char *defaultName, uint8_t defaultNameSize, uint8_t defaultIdx);
#define strcat_modelname(dest, idx) strcat_zchar(dest, modelHeaders[idx].name, LEN_MODEL_NAME, STR_MODEL, PSIZE(TR_MODEL), idx+1) #define strcat_modelname(dest, idx) strcat_zchar(dest, modelHeaders[idx].name, LEN_MODEL_NAME, STR_MODEL, PSIZE(TR_MODEL), idx+1)
#define strcat_phasename(dest, idx) strcat_zchar(dest, g_model.flightModeData[idx].name, LEN_FP_NAME, STR_FP, PSIZE(TR_FP), idx+1) #define strcat_phasename(dest, idx) strcat_zchar(dest, g_model.flightModeData[idx].name, LEN_FLIGHT_MODE_NAME, STR_FP, PSIZE(TR_FP), idx+1)
#define ZLEN(s) zlen(s, sizeof(s)) #define ZLEN(s) zlen(s, sizeof(s))
#define ZEXIST(s) zexist(s, sizeof(s)) #define ZEXIST(s) zexist(s, sizeof(s))
#endif #endif

View file

@ -224,6 +224,7 @@ const pm_char STR_ALARMWARNING[] PROGMEM = TR_ALARMWARNING;
const pm_char STR_RENAVIG[] PROGMEM = TR_RENAVIG; const pm_char STR_RENAVIG[] PROGMEM = TR_RENAVIG;
#endif #endif
const pm_char STR_THROTTLEREVERSE[] PROGMEM = TR_THROTTLEREVERSE; const pm_char STR_THROTTLEREVERSE[] PROGMEM = TR_THROTTLEREVERSE;
const pm_char STR_TIMER_NAME[] PROGMEM = TR_TIMER_NAME;
const pm_char STR_MINUTEBEEP[] PROGMEM = TR_MINUTEBEEP; const pm_char STR_MINUTEBEEP[] PROGMEM = TR_MINUTEBEEP;
const pm_char STR_BEEPCOUNTDOWN[] PROGMEM = TR_BEEPCOUNTDOWN; const pm_char STR_BEEPCOUNTDOWN[] PROGMEM = TR_BEEPCOUNTDOWN;
const pm_char STR_PERSISTENT[] PROGMEM = TR_PERSISTENT; const pm_char STR_PERSISTENT[] PROGMEM = TR_PERSISTENT;

View file

@ -392,6 +392,7 @@ extern const pm_char STR_MEMORYWARNING[];
extern const pm_char STR_ALARMWARNING[]; extern const pm_char STR_ALARMWARNING[];
extern const pm_char STR_RENAVIG[]; extern const pm_char STR_RENAVIG[];
extern const pm_char STR_THROTTLEREVERSE[]; extern const pm_char STR_THROTTLEREVERSE[];
extern const pm_char STR_TIMER_NAME[];
extern const pm_char STR_MINUTEBEEP[]; extern const pm_char STR_MINUTEBEEP[];
extern const pm_char STR_BEEPCOUNTDOWN[]; extern const pm_char STR_BEEPCOUNTDOWN[];
extern const pm_char STR_PERSISTENT[]; extern const pm_char STR_PERSISTENT[];

View file

@ -598,6 +598,7 @@
#define TR_RENAVIG "Navig. RotEnc" #define TR_RENAVIG "Navig. RotEnc"
#define TR_THROTTLE_LABEL "Plyn" #define TR_THROTTLE_LABEL "Plyn"
#define TR_THROTTLEREVERSE TR("ReversPlyn", INDENT"Revers plynu") #define TR_THROTTLEREVERSE TR("ReversPlyn", INDENT"Revers plynu")
#define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT"Minuta", INDENT"Oznamovat minuty") #define TR_MINUTEBEEP TR(INDENT"Minuta", INDENT"Oznamovat minuty")
#define TR_BEEPCOUNTDOWN INDENT"Odpočet" #define TR_BEEPCOUNTDOWN INDENT"Odpočet"
#define TR_PERSISTENT INDENT"Trvalé" #define TR_PERSISTENT INDENT"Trvalé"

View file

@ -600,22 +600,23 @@
#define TR_RENAVIG "Drehgeb. Navig." #define TR_RENAVIG "Drehgeb. Navig."
#define TR_THROTTLE_LABEL "---Gas-Kontrolle----" #define TR_THROTTLE_LABEL "---Gas-Kontrolle----"
#define TR_THROTTLEREVERSE TR("Gas invers", INDENT "Vollgas hinten?") //Änderung wg TH9x, Taranis #define TR_THROTTLEREVERSE TR("Gas invers", INDENT "Vollgas hinten?") //Änderung wg TH9x, Taranis
#define TR_MINUTEBEEP TR(INDENT"Min-Alarm",INDENT"Minuten-Alarm") #define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT"Min-Alarm", INDENT"Minuten-Alarm")
#define TR_BEEPCOUNTDOWN INDENT"Countdown" #define TR_BEEPCOUNTDOWN INDENT"Countdown"
#define TR_PERSISTENT TR(INDENT"Permanent",INDENT"Permanent") #define TR_PERSISTENT TR(INDENT"Permanent", INDENT"Permanent")
#define TR_BACKLIGHT_LABEL "----LCD-Beleuchtg----" #define TR_BACKLIGHT_LABEL "----LCD-Beleuchtg----"
#define TR_BLDELAY INDENT"Dauer" #define TR_BLDELAY INDENT"Dauer"
#define TR_BLONBRIGHTNESS INDENT"An-Helligkeit" #define TR_BLONBRIGHTNESS INDENT"An-Helligkeit"
#define TR_BLOFFBRIGHTNESS INDENT"Aus-Helligkeit" #define TR_BLOFFBRIGHTNESS INDENT"Aus-Helligkeit"
#define TR_BLCOLOR INDENT "Farbe" #define TR_BLCOLOR INDENT "Farbe"
#define TR_SPLASHSCREEN TR("Startbild Ein","Startbild Ein für") #define TR_SPLASHSCREEN TR("Startbild Ein", "Startbild Ein für")
#define TR_THROTTLEWARNING TR("Gasalarm", INDENT "Gas Alarm") #define TR_THROTTLEWARNING TR("Gasalarm", INDENT "Gas Alarm")
#define TR_SWITCHWARNING TR("Sch. Alarm", INDENT "Schalter-Alarm") #define TR_SWITCHWARNING TR("Sch. Alarm", INDENT "Schalter-Alarm")
#define TR_POTWARNING TR("Pot Warn.", INDENT "Poti-Warnung") #define TR_POTWARNING TR("Pot Warn.", INDENT "Poti-Warnung")
#define TR_TIMEZONE TR("Zeitzone","GPS-Zeitzone") #define TR_TIMEZONE TR("Zeitzone", "GPS-Zeitzone")
#define TR_RXCHANNELORD TR("Kanalanordnung","Kanalvoreinstellung") #define TR_RXCHANNELORD TR("Kanalanordnung", "Kanalvoreinstellung")
#define TR_SWITCHES_DELAY TR("Sw. Mitte Delay","Schaltermitte Verz.") //Schalter Mitten verzögern Anpassung #define TR_SWITCHES_DELAY TR("Sw. Mitte Delay", "Schaltermitte Verz.") //Schalter Mitten verzögern Anpassung
#define TR_SLAVE TR("Schüler PPM1-16","Schüler PPM1-16 als Ausgang") #define TR_SLAVE TR("Schüler PPM1-16", "Schüler PPM1-16 als Ausgang")
#define TR_MODESRC " Modus\003% Quelle" #define TR_MODESRC " Modus\003% Quelle"
#define TR_MULTIPLIER "Multiplikator" #define TR_MULTIPLIER "Multiplikator"
#define TR_CAL "Kal." #define TR_CAL "Kal."

View file

@ -600,6 +600,7 @@
#define TR_RENAVIG "RotEnc Navig" #define TR_RENAVIG "RotEnc Navig"
#define TR_THROTTLE_LABEL "Throttle" #define TR_THROTTLE_LABEL "Throttle"
#define TR_THROTTLEREVERSE TR("T-Reverse", INDENT "Reverse") #define TR_THROTTLEREVERSE TR("T-Reverse", INDENT "Reverse")
#define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT "Minute",INDENT "Minute call") #define TR_MINUTEBEEP TR(INDENT "Minute",INDENT "Minute call")
#define TR_BEEPCOUNTDOWN INDENT "Countdown" #define TR_BEEPCOUNTDOWN INDENT "Countdown"
#define TR_PERSISTENT TR(INDENT "Persist.",INDENT "Persistent") #define TR_PERSISTENT TR(INDENT "Persist.",INDENT "Persistent")

View file

@ -598,9 +598,10 @@
#define TR_RENAVIG "RotEnc Navig" #define TR_RENAVIG "RotEnc Navig"
#define TR_THROTTLE_LABEL "Throttle" #define TR_THROTTLE_LABEL "Throttle"
#define TR_THROTTLEREVERSE TR("Invert_Acel", INDENT "Invertir Acel.") #define TR_THROTTLEREVERSE TR("Invert_Acel", INDENT "Invertir Acel.")
#define TR_MINUTEBEEP TR(INDENT"Minuto",INDENT"Cada Minuto") #define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT"Minuto", INDENT"Cada Minuto")
#define TR_BEEPCOUNTDOWN INDENT"Cuentaatras" #define TR_BEEPCOUNTDOWN INDENT"Cuentaatras"
#define TR_PERSISTENT TR(INDENT"Persist.",INDENT"Persistente") #define TR_PERSISTENT TR(INDENT"Persist.", INDENT"Persistente")
#define TR_BACKLIGHT_LABEL "Luz Fondo" #define TR_BACKLIGHT_LABEL "Luz Fondo"
#define TR_BLDELAY INDENT"Duracion" #define TR_BLDELAY INDENT"Duracion"
#define TR_BLONBRIGHTNESS INDENT"MAS Brillo" #define TR_BLONBRIGHTNESS INDENT"MAS Brillo"

View file

@ -598,9 +598,10 @@
#define TR_RENAVIG "RotEnc Navig" #define TR_RENAVIG "RotEnc Navig"
#define TR_THROTTLE_LABEL "Throttle" #define TR_THROTTLE_LABEL "Throttle"
#define TR_THROTTLEREVERSE TR("T-Reverse", INDENT "Throttle reverse") #define TR_THROTTLEREVERSE TR("T-Reverse", INDENT "Throttle reverse")
#define TR_MINUTEBEEP TR(INDENT"Minute",INDENT"Minute call") #define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT"Minute", INDENT"Minute call")
#define TR_BEEPCOUNTDOWN INDENT"Countdown" #define TR_BEEPCOUNTDOWN INDENT"Countdown"
#define TR_PERSISTENT TR(INDENT"Persist.",INDENT"Persistent") #define TR_PERSISTENT TR(INDENT"Persist.", INDENT"Persistent")
#define TR_BACKLIGHT_LABEL "Backlight" #define TR_BACKLIGHT_LABEL "Backlight"
#define TR_BLDELAY INDENT"Duration" #define TR_BLDELAY INDENT"Duration"
#define TR_BLONBRIGHTNESS INDENT"ON Brightness" #define TR_BLONBRIGHTNESS INDENT"ON Brightness"

View file

@ -591,16 +591,17 @@
#define TR_CONTRAST "Contraste" #define TR_CONTRAST "Contraste"
#define TR_ALARMS_LABEL "Alarmes" #define TR_ALARMS_LABEL "Alarmes"
#define TR_BATTERY_RANGE "Plage batterie" #define TR_BATTERY_RANGE "Plage batterie"
#define TR_BATTERYWARNING TR(INDENT "Batterie",INDENT "Batterie faible") #define TR_BATTERYWARNING TR(INDENT "Batterie", INDENT "Batterie faible")
#define TR_INACTIVITYALARM INDENT "Inactivité" #define TR_INACTIVITYALARM INDENT "Inactivité"
#define TR_MEMORYWARNING INDENT "Mémoire pleine" #define TR_MEMORYWARNING INDENT "Mémoire pleine"
#define TR_ALARMWARNING TR(INDENT "Silence",INDENT "Sons désactivés") #define TR_ALARMWARNING TR(INDENT "Silence", INDENT "Sons désactivés")
#define TR_RENAVIG "Navig EncRot" #define TR_RENAVIG "Navig EncRot"
#define TR_THROTTLE_LABEL "Gaz" #define TR_THROTTLE_LABEL "Gaz"
#define TR_THROTTLEREVERSE TR("Inv. gaz", INDENT "Inversion gaz") #define TR_THROTTLEREVERSE TR("Inv. gaz", INDENT "Inversion gaz")
#define TR_MINUTEBEEP TR(INDENT "Bip min.",INDENT "Annonces minutes") #define TR_TIMER_NAME INDENT "Name"
#define TR_BEEPCOUNTDOWN TR(INDENT "Bip fin",INDENT "Compte à rebours") #define TR_MINUTEBEEP TR(INDENT "Bip min.", INDENT "Annonces minutes")
#define TR_PERSISTENT TR(INDENT "Persist.",INDENT "Persistant") #define TR_BEEPCOUNTDOWN TR(INDENT "Bip fin", INDENT "Compte à rebours")
#define TR_PERSISTENT TR(INDENT "Persist.", INDENT "Persistant")
#define TR_BACKLIGHT_LABEL "Rétroéclairage" #define TR_BACKLIGHT_LABEL "Rétroéclairage"
#define TR_BLDELAY INDENT "Durée" #define TR_BLDELAY INDENT "Durée"
#define TR_BLONBRIGHTNESS INDENT "Luminosité ON" #define TR_BLONBRIGHTNESS INDENT "Luminosité ON"

View file

@ -598,10 +598,11 @@
#define TR_RENAVIG "Navig EncRot " #define TR_RENAVIG "Navig EncRot "
#define TR_THROTTLE_LABEL "Motore" #define TR_THROTTLE_LABEL "Motore"
#define TR_THROTTLEREVERSE TR("Mot inv.", INDENT "Motore Inverso") #define TR_THROTTLEREVERSE TR("Mot inv.", INDENT "Motore Inverso")
#define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP INDENT"Minuto" #define TR_MINUTEBEEP INDENT"Minuto"
#define TR_BEEPCOUNTDOWN TR(INDENT"Conto rov",INDENT"Conto rovescia") #define TR_BEEPCOUNTDOWN TR(INDENT"Conto rov", INDENT"Conto rovescia")
#define TR_PERSISTENT TR(INDENT"Persist.",INDENT"Persistente") #define TR_PERSISTENT TR(INDENT"Persist.", INDENT"Persistente")
#define TR_BACKLIGHT_LABEL TR("Retroillum.","Retroilluminazione") #define TR_BACKLIGHT_LABEL TR("Retroillum.", "Retroilluminazione")
#define TR_BLDELAY INDENT"Durata" #define TR_BLDELAY INDENT"Durata"
#define TR_BLONBRIGHTNESS TR(INDENT"Lumin. ON",INDENT"Luminosità ON") #define TR_BLONBRIGHTNESS TR(INDENT"Lumin. ON",INDENT"Luminosità ON")
#define TR_BLOFFBRIGHTNESS TR(INDENT"Lumin. OFF",INDENT"Luminosità OFF") #define TR_BLOFFBRIGHTNESS TR(INDENT"Lumin. OFF",INDENT"Luminosità OFF")

View file

@ -598,9 +598,10 @@
#define TR_RENAVIG "Nawigacja potencjometrem" #define TR_RENAVIG "Nawigacja potencjometrem"
#define TR_THROTTLE_LABEL "Gaz " #define TR_THROTTLE_LABEL "Gaz "
#define TR_THROTTLEREVERSE TR("OdwrGaz", INDENT "OdwrGaz") #define TR_THROTTLEREVERSE TR("OdwrGaz", INDENT "OdwrGaz")
#define TR_TIMER_NAME INDENT "Name"
#define TR_MINUTEBEEP TR(INDENT "Minuta", INDENT "PikCoMinutę") #define TR_MINUTEBEEP TR(INDENT "Minuta", INDENT "PikCoMinutę")
#define TR_BEEPCOUNTDOWN INDENT "Odliczanie" #define TR_BEEPCOUNTDOWN INDENT "Odliczanie"
#define TR_PERSISTENT TR(INDENT "Dokł.",INDENT "Dokładny") #define TR_PERSISTENT TR(INDENT "Dokł.", INDENT "Dokładny")
#define TR_BACKLIGHT_LABEL "Podświetl" #define TR_BACKLIGHT_LABEL "Podświetl"
#define TR_BLDELAY INDENT"Czas trwania" #define TR_BLDELAY INDENT"Czas trwania"
#define TR_BLONBRIGHTNESS INDENT"Jasnośc wł." #define TR_BLONBRIGHTNESS INDENT"Jasnośc wł."

View file

@ -598,13 +598,14 @@
#define TR_RENAVIG "RotEnc Navig" #define TR_RENAVIG "RotEnc Navig"
#define TR_THROTTLE_LABEL "Throttle" #define TR_THROTTLE_LABEL "Throttle"
#define TR_THROTTLEREVERSE TR("Inverte Acel.", INDENT "Inverte Acel.") #define TR_THROTTLEREVERSE TR("Inverte Acel.", INDENT "Inverte Acel.")
#define TR_MINUTEBEEP INDENT"Beep Minuto" #define TR_TIMER_NAME INDENT "Name"
#define TR_BEEPCOUNTDOWN INDENT"Beep Regressivo" #define TR_MINUTEBEEP INDENT "Beep Minuto"
#define TR_PERSISTENT INDENT"Persist." #define TR_BEEPCOUNTDOWN INDENT "Beep Regressivo"
#define TR_PERSISTENT INDENT "Persist."
#define TR_BACKLIGHT_LABEL "Backlight" #define TR_BACKLIGHT_LABEL "Backlight"
#define TR_BLDELAY INDENT"Tempo Backlight" #define TR_BLDELAY INDENT "Tempo Backlight"
#define TR_BLONBRIGHTNESS INDENT"ON Brightness" #define TR_BLONBRIGHTNESS INDENT "ON Brightness"
#define TR_BLOFFBRIGHTNESS INDENT"OFF Brightness" #define TR_BLOFFBRIGHTNESS INDENT "OFF Brightness"
#define TR_BLCOLOR INDENT "Color" #define TR_BLCOLOR INDENT "Color"
#define TR_SPLASHSCREEN "Splash screen" #define TR_SPLASHSCREEN "Splash screen"
#define TR_THROTTLEWARNING TR("Avisa Acel", INDENT "Avisa Acel") #define TR_THROTTLEWARNING TR("Avisa Acel", INDENT "Avisa Acel")

View file

@ -598,19 +598,20 @@
#define TR_RENAVIG "RotEnc Navig" #define TR_RENAVIG "RotEnc Navig"
#define TR_THROTTLE_LABEL "Gas" #define TR_THROTTLE_LABEL "Gas"
#define TR_THROTTLEREVERSE TR("Inv.Gas", INDENT "Inverterad Gas") #define TR_THROTTLEREVERSE TR("Inv.Gas", INDENT "Inverterad Gas")
#define TR_MINUTEBEEP INDENT"Minutpip" #define TR_TIMER_NAME INDENT "Name"
#define TR_BEEPCOUNTDOWN INDENT"Nedräkning" #define TR_MINUTEBEEP INDENT "Minutpip"
#define TR_PERSISTENT TR("Jämt på ",INDENT"Alltid På") #define TR_BEEPCOUNTDOWN INDENT "Nedräkning"
#define TR_PERSISTENT TR("Jämt på ", INDENT"Alltid På")
#define TR_BACKLIGHT_LABEL "Belysning" #define TR_BACKLIGHT_LABEL "Belysning"
#define TR_BLDELAY INDENT"Av efter" #define TR_BLDELAY INDENT "Av efter"
#define TR_BLONBRIGHTNESS INDENT"På Ljusstyrka" #define TR_BLONBRIGHTNESS INDENT "På Ljusstyrka"
#define TR_BLOFFBRIGHTNESS INDENT"Av Ljusstyrka" #define TR_BLOFFBRIGHTNESS INDENT "Av Ljusstyrka"
#define TR_SPLASHSCREEN "Startbild" #define TR_SPLASHSCREEN "Startbild"
#define TR_BLCOLOR INDENT "Color" #define TR_BLCOLOR INDENT "Color"
#define TR_THROTTLEWARNING TR("Gasvarning", INDENT "Gasvarning") #define TR_THROTTLEWARNING TR("Gasvarning", INDENT "Gasvarning")
#define TR_SWITCHWARNING TR("Bryt.varn.", INDENT "Brytarvarning") #define TR_SWITCHWARNING TR("Bryt.varn.", INDENT "Brytarvarning")
#define TR_POTWARNING TR("Rattvarn.", INDENT "Rattvarning") #define TR_POTWARNING TR("Rattvarn.", INDENT "Rattvarning")
#define TR_TIMEZONE TR("Tidszon","GPS Tidszon") #define TR_TIMEZONE TR("Tidszon", "GPS Tidszon")
#define TR_RXCHANNELORD "Kanaler i RX" #define TR_RXCHANNELORD "Kanaler i RX"
#define TR_SWITCHES_DELAY "Brytarfördröjning" #define TR_SWITCHES_DELAY "Brytarfördröjning"
#define TR_SLAVE "Elev" #define TR_SLAVE "Elev"