mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2025-01-17 23:18:34 +00:00
parent
a1632cfa0a
commit
fe7e890b09
1 changed files with 17 additions and 26 deletions
|
@ -4026,44 +4026,34 @@ void kill_screen(const char* lcd_msg) {
|
|||
*/
|
||||
#if ENABLED(ADC_KEYPAD)
|
||||
|
||||
inline void handle_adc_keypad() {
|
||||
inline bool handle_adc_keypad() {
|
||||
static uint8_t adc_steps = 0;
|
||||
if (buttons_reprapworld_keypad) {
|
||||
adc_steps++;
|
||||
NOMORE(adc_steps, 20);
|
||||
|
||||
if (adc_steps < 20) ++adc_steps;
|
||||
lcd_quick_feedback();
|
||||
lcdDrawUpdate = LCDVIEW_REDRAW_NOW;
|
||||
return_to_status_ms = millis() + LCD_TIMEOUT_TO_STATUS;
|
||||
if (encoderDirection == -1) { // side effect which signals we are inside a menu
|
||||
if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_DOWN)
|
||||
encoderPosition -= ENCODER_STEPS_PER_MENU_ITEM;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_UP)
|
||||
encoderPosition += ENCODER_STEPS_PER_MENU_ITEM;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_LEFT)
|
||||
menu_action_back();
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_RIGHT)
|
||||
// enqueue_and_echo_commands_P(PSTR("M0 Pause"));
|
||||
lcd_return_to_status();
|
||||
if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_DOWN) encoderPosition -= ENCODER_STEPS_PER_MENU_ITEM;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_UP) encoderPosition += ENCODER_STEPS_PER_MENU_ITEM;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_LEFT) menu_action_back();
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_RIGHT) lcd_return_to_status();
|
||||
}
|
||||
else {
|
||||
const int8_t step = adc_steps > 19 ? 100 : adc_steps > 10 ? 10 : 1;
|
||||
if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_DOWN)
|
||||
encoderPosition += ENCODER_PULSES_PER_STEP * step;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_UP)
|
||||
encoderPosition -= ENCODER_PULSES_PER_STEP * step;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_RIGHT)
|
||||
encoderPosition = 0;
|
||||
if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_DOWN) encoderPosition += ENCODER_PULSES_PER_STEP * step;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_UP) encoderPosition -= ENCODER_PULSES_PER_STEP * step;
|
||||
else if (buttons_reprapworld_keypad & EN_REPRAPWORLD_KEYPAD_RIGHT) encoderPosition = 0;
|
||||
}
|
||||
#if ENABLED(ADC_KEYPAD_DEBUG)
|
||||
SERIAL_PROTOCOLLNPAIR("buttons_reprapworld_keypad = ", (uint32_t)buttons_reprapworld_keypad);
|
||||
SERIAL_PROTOCOLLNPAIR("encoderPosition = ", (uint32_t)encoderPosition);
|
||||
#endif
|
||||
return true;
|
||||
}
|
||||
else if (!thermalManager.current_ADCKey_raw) {
|
||||
// reset stepping acceleration
|
||||
adc_steps = 0;
|
||||
}
|
||||
else if (!thermalManager.current_ADCKey_raw)
|
||||
adc_steps = 0; // reset stepping acceleration
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
#elif ENABLED(REPRAPWORLD_KEYPAD)
|
||||
|
@ -4360,7 +4350,8 @@ void lcd_update() {
|
|||
|
||||
#if ENABLED(ADC_KEYPAD)
|
||||
|
||||
handle_adc_keypad();
|
||||
if (handle_adc_keypad())
|
||||
return_to_status_ms = ms + LCD_TIMEOUT_TO_STATUS;
|
||||
|
||||
#elif ENABLED(REPRAPWORLD_KEYPAD)
|
||||
|
||||
|
@ -4792,7 +4783,7 @@ void lcd_reset_alert_level() { lcd_status_message_level = 0; }
|
|||
uint8_t ADCKeyNo;
|
||||
} _stADCKeypadTable_;
|
||||
|
||||
static const _stADCKeypadTable_ stADCKeyTable[] = PROGMEM {
|
||||
static const _stADCKeypadTable_ stADCKeyTable[] PROGMEM = {
|
||||
// VALUE_MIN, VALUE_MAX, KEY
|
||||
{ 4000, 4096, BLEN_REPRAPWORLD_KEYPAD_F1 + 1 }, // F1
|
||||
{ 4000, 4096, BLEN_REPRAPWORLD_KEYPAD_F2 + 1 }, // F2
|
||||
|
|
Loading…
Reference in a new issue