|
@ -29,6 +29,13 @@ |
|
|
#if HAS_LCD_MENU |
|
|
#if HAS_LCD_MENU |
|
|
|
|
|
|
|
|
#include "menu.h" |
|
|
#include "menu.h" |
|
|
|
|
|
|
|
|
|
|
|
#include "../lcdprint.h" |
|
|
|
|
|
|
|
|
|
|
|
#if HAS_GRAPHICAL_LCD |
|
|
|
|
|
#include "../dogm/ultralcd_DOGM.h" |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
#include "../../module/motion.h" |
|
|
#include "../../module/motion.h" |
|
|
|
|
|
|
|
|
#if ENABLED(DELTA) |
|
|
#if ENABLED(DELTA) |
|
@ -230,6 +237,10 @@ inline void lcd_move_e() { _lcd_move_e(); } |
|
|
// "Motion" > "Move Xmm" > "Move XYZ" submenu
|
|
|
// "Motion" > "Move Xmm" > "Move XYZ" submenu
|
|
|
//
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef SHORT_MANUAL_Z_MOVE |
|
|
|
|
|
#define SHORT_MANUAL_Z_MOVE 0.025 |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
screenFunc_t _manual_move_func_ptr; |
|
|
screenFunc_t _manual_move_func_ptr; |
|
|
|
|
|
|
|
|
void _goto_manual_move(const float scale) { |
|
|
void _goto_manual_move(const float scale) { |
|
@ -240,7 +251,6 @@ void _goto_manual_move(const float scale) { |
|
|
void menu_move_10mm() { _goto_manual_move(10); } |
|
|
void menu_move_10mm() { _goto_manual_move(10); } |
|
|
void menu_move_1mm() { _goto_manual_move( 1); } |
|
|
void menu_move_1mm() { _goto_manual_move( 1); } |
|
|
void menu_move_01mm() { _goto_manual_move( 0.1f); } |
|
|
void menu_move_01mm() { _goto_manual_move( 0.1f); } |
|
|
void menu_move_0025mm() { _goto_manual_move( 0.025f); } |
|
|
|
|
|
|
|
|
|
|
|
void _menu_move_distance(const AxisEnum axis, const screenFunc_t func, const int8_t eindex=-1) { |
|
|
void _menu_move_distance(const AxisEnum axis, const screenFunc_t func, const int8_t eindex=-1) { |
|
|
_manual_move_func_ptr = func; |
|
|
_manual_move_func_ptr = func; |
|
@ -268,8 +278,18 @@ void _menu_move_distance(const AxisEnum axis, const screenFunc_t func, const int |
|
|
MENU_ITEM(submenu, MSG_MOVE_10MM, menu_move_10mm); |
|
|
MENU_ITEM(submenu, MSG_MOVE_10MM, menu_move_10mm); |
|
|
MENU_ITEM(submenu, MSG_MOVE_1MM, menu_move_1mm); |
|
|
MENU_ITEM(submenu, MSG_MOVE_1MM, menu_move_1mm); |
|
|
MENU_ITEM(submenu, MSG_MOVE_01MM, menu_move_01mm); |
|
|
MENU_ITEM(submenu, MSG_MOVE_01MM, menu_move_01mm); |
|
|
if (axis == Z_AXIS) |
|
|
if (axis == Z_AXIS && (SHORT_MANUAL_Z_MOVE) > 0.0f && (SHORT_MANUAL_Z_MOVE) < 0.1f) { |
|
|
MENU_ITEM(submenu, MSG_MOVE_0025MM, menu_move_0025mm); |
|
|
MENU_ITEM(submenu, "", []{ _goto_manual_move(float(SHORT_MANUAL_Z_MOVE)); }); |
|
|
|
|
|
MENU_ITEM_ADDON_START(1); |
|
|
|
|
|
char tmp[20], numstr[10]; |
|
|
|
|
|
// Determine digits needed right of decimal
|
|
|
|
|
|
const uint8_t digs = !UNEAR_ZERO((SHORT_MANUAL_Z_MOVE) * 1000 - int((SHORT_MANUAL_Z_MOVE) * 1000)) ? 4 : |
|
|
|
|
|
!UNEAR_ZERO((SHORT_MANUAL_Z_MOVE) * 100 - int((SHORT_MANUAL_Z_MOVE) * 100)) ? 3 : 2; |
|
|
|
|
|
dtostrf(SHORT_MANUAL_Z_MOVE, 1, digs, numstr); |
|
|
|
|
|
sprintf_P(tmp, PSTR(MSG_MOVE_Z_DIST), numstr); |
|
|
|
|
|
LCDPRINT(tmp); |
|
|
|
|
|
MENU_ITEM_ADDON_END(); |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
END_MENU(); |
|
|
END_MENU(); |
|
|
} |
|
|
} |
|
|