mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2024-11-27 13:56:24 +00:00
FTDI EVE Touch UI fixes (#21706)
This commit is contained in:
parent
81d7a6b81d
commit
e640d9246d
@ -32,7 +32,7 @@
|
|||||||
class MediaFileReader {
|
class MediaFileReader {
|
||||||
private:
|
private:
|
||||||
#if ENABLED(SDSUPPORT)
|
#if ENABLED(SDSUPPORT)
|
||||||
Sd2Card card;
|
DiskIODriver_SPI_SD card;
|
||||||
SdVolume volume;
|
SdVolume volume;
|
||||||
SdFile root, file;
|
SdFile root, file;
|
||||||
#endif
|
#endif
|
||||||
|
@ -40,8 +40,7 @@ using namespace Theme;
|
|||||||
#define DISPLAY_POS BTN_POS(1,3), BTN_SIZE(1,1)
|
#define DISPLAY_POS BTN_POS(1,3), BTN_SIZE(1,1)
|
||||||
#define INTERFACE_POS BTN_POS(2,3), BTN_SIZE(1,1)
|
#define INTERFACE_POS BTN_POS(2,3), BTN_SIZE(1,1)
|
||||||
#define ENDSTOPS_POS BTN_POS(3,3), BTN_SIZE(1,1)
|
#define ENDSTOPS_POS BTN_POS(3,3), BTN_SIZE(1,1)
|
||||||
#define CASE_LIGHT_POS BTN_POS(1,4), BTN_SIZE(1,1)
|
#define RESTORE_DEFAULTS_POS BTN_POS(1,4), BTN_SIZE(2,1)
|
||||||
#define RESTORE_DEFAULTS_POS BTN_POS(2,4), BTN_SIZE(1,1)
|
|
||||||
#define BACK_POS BTN_POS(3,4), BTN_SIZE(1,1)
|
#define BACK_POS BTN_POS(3,4), BTN_SIZE(1,1)
|
||||||
|
|
||||||
void AdvancedSettingsMenu::onRedraw(draw_mode_t what) {
|
void AdvancedSettingsMenu::onRedraw(draw_mode_t what) {
|
||||||
@ -66,9 +65,7 @@ void AdvancedSettingsMenu::onRedraw(draw_mode_t what) {
|
|||||||
.tag(8) .button(ENDSTOPS_POS, GET_TEXT_F(MSG_LCD_ENDSTOPS))
|
.tag(8) .button(ENDSTOPS_POS, GET_TEXT_F(MSG_LCD_ENDSTOPS))
|
||||||
.tag(9) .button(INTERFACE_POS, GET_TEXT_F(MSG_INTERFACE))
|
.tag(9) .button(INTERFACE_POS, GET_TEXT_F(MSG_INTERFACE))
|
||||||
.tag(10).button(DISPLAY_POS, GET_TEXT_F(MSG_DISPLAY_MENU))
|
.tag(10).button(DISPLAY_POS, GET_TEXT_F(MSG_DISPLAY_MENU))
|
||||||
.enabled(ENABLED(CASE_LIGHT_ENABLE))
|
.tag(11).button(RESTORE_DEFAULTS_POS, GET_TEXT_F(MSG_RESTORE_DEFAULTS))
|
||||||
.tag(11).button(CASE_LIGHT_POS, GET_TEXT_F(MSG_CASE_LIGHT))
|
|
||||||
.tag(12).button(RESTORE_DEFAULTS_POS, GET_TEXT_F(MSG_RESTORE_DEFAULTS))
|
|
||||||
.colors(action_btn)
|
.colors(action_btn)
|
||||||
.tag(1).button(BACK_POS, GET_TEXT_F(MSG_BACK));
|
.tag(1).button(BACK_POS, GET_TEXT_F(MSG_BACK));
|
||||||
}
|
}
|
||||||
@ -90,10 +87,7 @@ bool AdvancedSettingsMenu::onTouchEnd(uint8_t tag) {
|
|||||||
case 8: GOTO_SCREEN(EndstopStatesScreen); break;
|
case 8: GOTO_SCREEN(EndstopStatesScreen); break;
|
||||||
case 9: GOTO_SCREEN(InterfaceSettingsScreen); LockScreen::check_passcode(); break;
|
case 9: GOTO_SCREEN(InterfaceSettingsScreen); LockScreen::check_passcode(); break;
|
||||||
case 10: GOTO_SCREEN(DisplayTuningScreen); break;
|
case 10: GOTO_SCREEN(DisplayTuningScreen); break;
|
||||||
#if ENABLED(CASE_LIGHT_ENABLE)
|
case 11: GOTO_SCREEN(RestoreFailsafeDialogBox); LockScreen::check_passcode(); break;
|
||||||
case 11: GOTO_SCREEN(CaseLightScreen); break;
|
|
||||||
#endif
|
|
||||||
case 12: GOTO_SCREEN(RestoreFailsafeDialogBox); LockScreen::check_passcode(); break;
|
|
||||||
default: return false;
|
default: return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
using namespace FTDI;
|
using namespace FTDI;
|
||||||
using namespace Theme;
|
using namespace Theme;
|
||||||
|
|
||||||
#define GRID_ROWS 5
|
#define GRID_ROWS 6
|
||||||
#define GRID_COLS 2
|
#define GRID_COLS 2
|
||||||
|
|
||||||
#define ZPROBE_ZOFFSET_POS BTN_POS(1,1), BTN_SIZE(1,1)
|
#define ZPROBE_ZOFFSET_POS BTN_POS(1,1), BTN_SIZE(1,1)
|
||||||
@ -37,11 +37,12 @@ using namespace Theme;
|
|||||||
#define TEMPERATURE_POS BTN_POS(2,1), BTN_SIZE(1,1)
|
#define TEMPERATURE_POS BTN_POS(2,1), BTN_SIZE(1,1)
|
||||||
#define MOVE_E_POS BTN_POS(2,2), BTN_SIZE(1,1)
|
#define MOVE_E_POS BTN_POS(2,2), BTN_SIZE(1,1)
|
||||||
#define SPEED_POS BTN_POS(1,3), BTN_SIZE(1,1)
|
#define SPEED_POS BTN_POS(1,3), BTN_SIZE(1,1)
|
||||||
#define ADVANCED_SETTINGS_POS BTN_POS(2,3), BTN_SIZE(1,1)
|
#define FLOW_POS BTN_POS(2,3), BTN_SIZE(1,1)
|
||||||
#define DISABLE_STEPPERS_POS BTN_POS(1,4), BTN_SIZE(1,1)
|
#define ADVANCED_SETTINGS_POS BTN_POS(1,4), BTN_SIZE(1,1)
|
||||||
#define LEVELING_POS BTN_POS(2,4), BTN_SIZE(1,1)
|
#define DISABLE_STEPPERS_POS BTN_POS(2,4), BTN_SIZE(1,1)
|
||||||
#define ABOUT_PRINTER_POS BTN_POS(1,5), BTN_SIZE(1,1)
|
#define LEVELING_POS BTN_POS(1,5), BTN_SIZE(1,1)
|
||||||
#define BACK_POS BTN_POS(2,5), BTN_SIZE(1,1)
|
#define ABOUT_PRINTER_POS BTN_POS(2,5), BTN_SIZE(1,1)
|
||||||
|
#define BACK_POS BTN_POS(1,6), BTN_SIZE(2,1)
|
||||||
|
|
||||||
void MainMenu::onRedraw(draw_mode_t what) {
|
void MainMenu::onRedraw(draw_mode_t what) {
|
||||||
if (what & BACKGROUND) {
|
if (what & BACKGROUND) {
|
||||||
@ -60,11 +61,12 @@ void MainMenu::onRedraw(draw_mode_t what) {
|
|||||||
.tag( 4).button(ZPROBE_ZOFFSET_POS, GET_TEXT_F(MSG_ZPROBE_ZOFFSET))
|
.tag( 4).button(ZPROBE_ZOFFSET_POS, GET_TEXT_F(MSG_ZPROBE_ZOFFSET))
|
||||||
.tag( 5).button(MOVE_E_POS, GET_TEXT_F(MSG_E_MOVE))
|
.tag( 5).button(MOVE_E_POS, GET_TEXT_F(MSG_E_MOVE))
|
||||||
.tag( 6).button(SPEED_POS, GET_TEXT_F(MSG_PRINT_SPEED))
|
.tag( 6).button(SPEED_POS, GET_TEXT_F(MSG_PRINT_SPEED))
|
||||||
.tag( 7).button(ADVANCED_SETTINGS_POS, GET_TEXT_F(MSG_ADVANCED_SETTINGS))
|
.tag( 7).button(FLOW_POS, GET_TEXT_F(MSG_FLOW))
|
||||||
.tag( 8).button(DISABLE_STEPPERS_POS, GET_TEXT_F(MSG_DISABLE_STEPPERS))
|
.tag( 8).button(ADVANCED_SETTINGS_POS, GET_TEXT_F(MSG_ADVANCED_SETTINGS))
|
||||||
|
.tag( 9).button(DISABLE_STEPPERS_POS, GET_TEXT_F(MSG_DISABLE_STEPPERS))
|
||||||
.enabled(HAS_LEVELING)
|
.enabled(HAS_LEVELING)
|
||||||
.tag( 9).button(LEVELING_POS, GET_TEXT_F(MSG_LEVELING))
|
.tag(10).button(LEVELING_POS, GET_TEXT_F(MSG_LEVELING))
|
||||||
.tag(10).button(ABOUT_PRINTER_POS, GET_TEXT_F(MSG_INFO_MENU))
|
.tag(11).button(ABOUT_PRINTER_POS, GET_TEXT_F(MSG_INFO_MENU))
|
||||||
.colors(action_btn)
|
.colors(action_btn)
|
||||||
.tag(1).button(BACK_POS, GET_TEXT_F(MSG_BACK));
|
.tag(1).button(BACK_POS, GET_TEXT_F(MSG_BACK));
|
||||||
}
|
}
|
||||||
@ -82,12 +84,13 @@ bool MainMenu::onTouchEnd(uint8_t tag) {
|
|||||||
#endif
|
#endif
|
||||||
case 5: GOTO_SCREEN(MoveEScreen); break;
|
case 5: GOTO_SCREEN(MoveEScreen); break;
|
||||||
case 6: GOTO_SCREEN(FeedratePercentScreen); break;
|
case 6: GOTO_SCREEN(FeedratePercentScreen); break;
|
||||||
case 7: GOTO_SCREEN(AdvancedSettingsMenu); break;
|
case 7: GOTO_SCREEN(FlowPercentScreen); break;
|
||||||
case 8: injectCommands_P(PSTR("M84")); break;
|
case 8: GOTO_SCREEN(AdvancedSettingsMenu); break;
|
||||||
|
case 9: injectCommands_P(PSTR("M84")); break;
|
||||||
#if HAS_LEVELING
|
#if HAS_LEVELING
|
||||||
case 9: GOTO_SCREEN(LevelingMenu); break;
|
case 10: GOTO_SCREEN(LevelingMenu); break;
|
||||||
#endif
|
#endif
|
||||||
case 10: GOTO_SCREEN(AboutScreen); break;
|
case 11: GOTO_SCREEN(AboutScreen); break;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,50 @@
|
|||||||
|
/***************************
|
||||||
|
* flow_percent_screen.cpp *
|
||||||
|
***************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Written By Marcio Teixeira 2021 - Cocoa Press *
|
||||||
|
* *
|
||||||
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
|
* it under the terms of the GNU General Public License as published by *
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or *
|
||||||
|
* (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* To view a copy of the GNU General Public License, go to the following *
|
||||||
|
* location: <https://www.gnu.org/licenses/>. *
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include "../config.h"
|
||||||
|
#include "screens.h"
|
||||||
|
|
||||||
|
#ifdef FTDI_FLOW_PERCENT_SCREEN
|
||||||
|
|
||||||
|
using namespace FTDI;
|
||||||
|
using namespace ExtUI;
|
||||||
|
|
||||||
|
void FlowPercentScreen::onRedraw(draw_mode_t what) {
|
||||||
|
widgets_t w(what);
|
||||||
|
w.precision(0).units(GET_TEXT_F(MSG_UNITS_PERCENT));
|
||||||
|
|
||||||
|
w.heading(GET_TEXT_F(MSG_FLOW));
|
||||||
|
w.adjuster(4, GET_TEXT_F(MSG_FLOW), getFlow_percent(E0));
|
||||||
|
w.increments();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool FlowPercentScreen::onTouchHeld(uint8_t tag) {
|
||||||
|
const float increment = getIncrement();
|
||||||
|
switch (tag) {
|
||||||
|
case 4: UI_DECREMENT(Flow_percent, E0); break;
|
||||||
|
case 5: UI_INCREMENT(Flow_percent, E0); break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // FTDI_FLOW_PERCENT_SCREEN
|
@ -0,0 +1,31 @@
|
|||||||
|
/*************************
|
||||||
|
* flow_percent_screen.h *
|
||||||
|
*************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Written By Marcio Teixeira 2021 - Cocoa Press *
|
||||||
|
* *
|
||||||
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
|
* it under the terms of the GNU General Public License as published by *
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or *
|
||||||
|
* (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* To view a copy of the GNU General Public License, go to the following *
|
||||||
|
* location: <https://www.gnu.org/licenses/>. *
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define FTDI_FLOW_PERCENT_SCREEN
|
||||||
|
#define FTDI_FLOW_PERCENT_SCREEN_CLASS FlowPercentScreen
|
||||||
|
|
||||||
|
class FlowPercentScreen : public BaseNumericAdjustmentScreen, public CachedScreen<FLOW_PERCENT_SCREEN_CACHE> {
|
||||||
|
public:
|
||||||
|
static void onRedraw(draw_mode_t);
|
||||||
|
static bool onTouchHeld(uint8_t tag);
|
||||||
|
};
|
@ -81,9 +81,8 @@ void LevelingMenu::onRedraw(draw_mode_t what) {
|
|||||||
.text(BLTOUCH_TITLE_POS, GET_TEXT_F(MSG_BLTOUCH))
|
.text(BLTOUCH_TITLE_POS, GET_TEXT_F(MSG_BLTOUCH))
|
||||||
#endif
|
#endif
|
||||||
.font(font_medium).colors(normal_btn)
|
.font(font_medium).colors(normal_btn)
|
||||||
#if EITHER(Z_STEPPER_AUTO_ALIGN,MECHANICAL_GANTRY_CALIBRATION)
|
.enabled(EITHER(Z_STEPPER_AUTO_ALIGN,MECHANICAL_GANTRY_CALIBRATION))
|
||||||
.tag(2).button(LEVEL_AXIS_POS, GET_TEXT_F(MSG_LEVEL_X_AXIS))
|
.tag(2).button(LEVEL_AXIS_POS, GET_TEXT_F(MSG_LEVEL_X_AXIS))
|
||||||
#endif
|
|
||||||
.tag(3).button(PROBE_BED_POS, GET_TEXT_F(MSG_PROBE_BED))
|
.tag(3).button(PROBE_BED_POS, GET_TEXT_F(MSG_PROBE_BED))
|
||||||
.enabled(ENABLED(HAS_MESH))
|
.enabled(ENABLED(HAS_MESH))
|
||||||
.tag(4).button(SHOW_MESH_POS, GET_TEXT_F(MSG_SHOW_MESH))
|
.tag(4).button(SHOW_MESH_POS, GET_TEXT_F(MSG_SHOW_MESH))
|
||||||
|
@ -80,6 +80,7 @@ SCREEN_TABLE {
|
|||||||
DECL_SCREEN_IF_INCLUDED(FTDI_NOZZLE_OFFSETS_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_NOZZLE_OFFSETS_SCREEN)
|
||||||
DECL_SCREEN_IF_INCLUDED(FTDI_BACKLASH_COMP_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_BACKLASH_COMP_SCREEN)
|
||||||
DECL_SCREEN_IF_INCLUDED(FTDI_FEEDRATE_PERCENT_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_FEEDRATE_PERCENT_SCREEN)
|
||||||
|
DECL_SCREEN_IF_INCLUDED(FTDI_FLOW_PERCENT_SCREEN)
|
||||||
DECL_SCREEN_IF_INCLUDED(FTDI_MAX_VELOCITY_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_MAX_VELOCITY_SCREEN)
|
||||||
DECL_SCREEN_IF_INCLUDED(FTDI_MAX_ACCELERATION_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_MAX_ACCELERATION_SCREEN)
|
||||||
DECL_SCREEN_IF_INCLUDED(FTDI_DEFAULT_ACCELERATION_SCREEN)
|
DECL_SCREEN_IF_INCLUDED(FTDI_DEFAULT_ACCELERATION_SCREEN)
|
||||||
|
@ -55,6 +55,7 @@ enum {
|
|||||||
MAX_VELOCITY_SCREEN_CACHE,
|
MAX_VELOCITY_SCREEN_CACHE,
|
||||||
MAX_ACCELERATION_SCREEN_CACHE,
|
MAX_ACCELERATION_SCREEN_CACHE,
|
||||||
DEFAULT_ACCELERATION_SCREEN_CACHE,
|
DEFAULT_ACCELERATION_SCREEN_CACHE,
|
||||||
|
FLOW_PERCENT_SCREEN_CACHE,
|
||||||
#if HAS_LEVELING
|
#if HAS_LEVELING
|
||||||
LEVELING_SCREEN_CACHE,
|
LEVELING_SCREEN_CACHE,
|
||||||
#if HAS_BED_PROBE
|
#if HAS_BED_PROBE
|
||||||
@ -150,6 +151,7 @@ enum {
|
|||||||
#include "cocoa_press_preheat_screen.h"
|
#include "cocoa_press_preheat_screen.h"
|
||||||
#include "cocoa_press_load_chocolate.h"
|
#include "cocoa_press_load_chocolate.h"
|
||||||
#include "move_axis_screen.h"
|
#include "move_axis_screen.h"
|
||||||
|
#include "flow_percent_screen.h"
|
||||||
#include "cocoa_press_move_xyz_screen.h"
|
#include "cocoa_press_move_xyz_screen.h"
|
||||||
#include "cocoa_press_move_e_screen.h"
|
#include "cocoa_press_move_e_screen.h"
|
||||||
#include "tune_menu.h"
|
#include "tune_menu.h"
|
||||||
|
@ -237,7 +237,7 @@ void NextionTFT::PanelInfo(uint8_t req) {
|
|||||||
SEND_VALasTXT("tmppage.tool", getActiveTool());
|
SEND_VALasTXT("tmppage.tool", getActiveTool());
|
||||||
SEND_VALasTXT("tmppage.fan", ui8tostr3rj(getActualFan_percent(FAN0)));
|
SEND_VALasTXT("tmppage.fan", ui8tostr3rj(getActualFan_percent(FAN0)));
|
||||||
SEND_VALasTXT("tmppage.speed", getFeedrate_percent());
|
SEND_VALasTXT("tmppage.speed", getFeedrate_percent());
|
||||||
SEND_VALasTXT("tmppage.flow", getFlowPercentage(getActiveTool()));
|
SEND_VALasTXT("tmppage.flow", getFlow_percent(getActiveTool()));
|
||||||
SEND_VALasTXT("tmppage.progress", ui8tostr3rj(getProgress_percent()));
|
SEND_VALasTXT("tmppage.progress", ui8tostr3rj(getProgress_percent()));
|
||||||
SEND_VALasTXT("tmppage.layer", layer);
|
SEND_VALasTXT("tmppage.layer", layer);
|
||||||
SEND_VALasTXT("tmppage.x", getAxisPosition_mm(X));
|
SEND_VALasTXT("tmppage.x", getAxisPosition_mm(X));
|
||||||
@ -640,9 +640,9 @@ void NextionTFT::UpdateOnChange() {
|
|||||||
|
|
||||||
// tmppage Flow
|
// tmppage Flow
|
||||||
static uint8_t last_flow_speed = 99;
|
static uint8_t last_flow_speed = 99;
|
||||||
if (last_flow_speed != getFlowPercentage(getActiveTool())) {
|
if (last_flow_speed != getFlow_percent(getActiveTool())) {
|
||||||
SEND_VALasTXT("tmppage.flow", getFlowPercentage(getActiveTool()));
|
SEND_VALasTXT("tmppage.flow", getFlow_percent(getActiveTool()));
|
||||||
last_flow_speed = getFlowPercentage(getActiveTool());
|
last_flow_speed = getFlow_percent(getActiveTool());
|
||||||
}
|
}
|
||||||
|
|
||||||
// tmppage Progress + Layer + Time
|
// tmppage Progress + Layer + Time
|
||||||
|
@ -691,7 +691,7 @@ namespace ExtUI {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
feedRate_t getFeedrate_mm_s() { return feedrate_mm_s; }
|
feedRate_t getFeedrate_mm_s() { return feedrate_mm_s; }
|
||||||
int16_t getFlowPercentage(const extruder_t extr) { return planner.flow_percentage[extr]; }
|
int16_t getFlow_percent(const extruder_t extr) { return planner.flow_percentage[extr]; }
|
||||||
feedRate_t getMinFeedrate_mm_s() { return planner.settings.min_feedrate_mm_s; }
|
feedRate_t getMinFeedrate_mm_s() { return planner.settings.min_feedrate_mm_s; }
|
||||||
feedRate_t getMinTravelFeedrate_mm_s() { return planner.settings.min_travel_feedrate_mm_s; }
|
feedRate_t getMinTravelFeedrate_mm_s() { return planner.settings.min_travel_feedrate_mm_s; }
|
||||||
float getPrintingAcceleration_mm_s2() { return planner.settings.acceleration; }
|
float getPrintingAcceleration_mm_s2() { return planner.settings.acceleration; }
|
||||||
|
@ -129,7 +129,7 @@ namespace ExtUI {
|
|||||||
float getRetractAcceleration_mm_s2();
|
float getRetractAcceleration_mm_s2();
|
||||||
float getTravelAcceleration_mm_s2();
|
float getTravelAcceleration_mm_s2();
|
||||||
float getFeedrate_percent();
|
float getFeedrate_percent();
|
||||||
int16_t getFlowPercentage(const extruder_t);
|
int16_t getFlow_percent(const extruder_t);
|
||||||
|
|
||||||
inline uint8_t getProgress_percent() { return ui.get_progress_percent(); }
|
inline uint8_t getProgress_percent() { return ui.get_progress_percent(); }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user