SMUFF (MMU2 clone) support (#19912)
This commit is contained in:
committed by
Scott Lahteine
parent
b6d2671260
commit
bd38e59479
@ -46,7 +46,7 @@
|
||||
#define MACHINE_CAN_PAUSE 1
|
||||
#endif
|
||||
|
||||
#if ENABLED(PRUSA_MMU2)
|
||||
#if ENABLED(MMU2_MENUS)
|
||||
#include "../../lcd/menu/menu_mmu2.h"
|
||||
#endif
|
||||
|
||||
|
@ -24,13 +24,10 @@
|
||||
|
||||
#if BOTH(HAS_LCD_MENU, MMU2_MENUS)
|
||||
|
||||
#include "../../feature/mmu2/mmu2.h"
|
||||
#include "../../feature/mmu/mmu2.h"
|
||||
#include "menu_mmu2.h"
|
||||
#include "menu_item.h"
|
||||
|
||||
uint8_t currentTool;
|
||||
bool mmuMenuWait;
|
||||
|
||||
//
|
||||
// Load Filament
|
||||
//
|
||||
@ -123,9 +120,12 @@ void menu_mmu2() {
|
||||
// T* Choose Filament
|
||||
//
|
||||
|
||||
inline void action_mmu2_choose(const uint8_t tool) {
|
||||
currentTool = tool;
|
||||
mmuMenuWait = false;
|
||||
uint8_t feeder_index;
|
||||
bool wait_for_mmu_menu;
|
||||
|
||||
inline void action_mmu2_chosen(const uint8_t index) {
|
||||
feeder_index = index;
|
||||
wait_for_mmu_menu = false;
|
||||
}
|
||||
|
||||
void menu_mmu2_choose_filament() {
|
||||
@ -133,7 +133,7 @@ void menu_mmu2_choose_filament() {
|
||||
#if LCD_HEIGHT > 2
|
||||
STATIC_ITEM(MSG_MMU2_CHOOSE_FILAMENT_HEADER, SS_DEFAULT|SS_INVERT);
|
||||
#endif
|
||||
LOOP_L_N(i, 5) ACTION_ITEM_N(i, MSG_MMU2_FILAMENT_N, []{ action_mmu2_choose(MenuItemBase::itemIndex); });
|
||||
LOOP_L_N(i, 5) ACTION_ITEM_N(i, MSG_MMU2_FILAMENT_N, []{ action_mmu2_chosen(MenuItemBase::itemIndex); });
|
||||
END_MENU();
|
||||
}
|
||||
|
||||
@ -142,32 +142,32 @@ void menu_mmu2_choose_filament() {
|
||||
//
|
||||
|
||||
void menu_mmu2_pause() {
|
||||
currentTool = mmu2.get_current_tool();
|
||||
feeder_index = mmu2.get_current_tool();
|
||||
START_MENU();
|
||||
#if LCD_HEIGHT > 2
|
||||
STATIC_ITEM(MSG_FILAMENT_CHANGE_HEADER, SS_DEFAULT|SS_INVERT);
|
||||
#endif
|
||||
ACTION_ITEM(MSG_MMU2_RESUME, []{ mmuMenuWait = false; });
|
||||
ACTION_ITEM(MSG_MMU2_RESUME, []{ wait_for_mmu_menu = false; });
|
||||
ACTION_ITEM(MSG_MMU2_UNLOAD_FILAMENT, []{ mmu2.unload(); });
|
||||
ACTION_ITEM(MSG_MMU2_LOAD_FILAMENT, []{ mmu2.load_filament(currentTool); });
|
||||
ACTION_ITEM(MSG_MMU2_LOAD_TO_NOZZLE, []{ mmu2.load_filament_to_nozzle(currentTool); });
|
||||
ACTION_ITEM(MSG_MMU2_LOAD_FILAMENT, []{ mmu2.load_filament(feeder_index); });
|
||||
ACTION_ITEM(MSG_MMU2_LOAD_TO_NOZZLE, []{ mmu2.load_filament_to_nozzle(feeder_index); });
|
||||
END_MENU();
|
||||
}
|
||||
|
||||
void mmu2_M600() {
|
||||
ui.defer_status_screen();
|
||||
ui.goto_screen(menu_mmu2_pause);
|
||||
mmuMenuWait = true;
|
||||
while (mmuMenuWait) idle();
|
||||
wait_for_mmu_menu = true;
|
||||
while (wait_for_mmu_menu) idle();
|
||||
}
|
||||
|
||||
uint8_t mmu2_choose_filament() {
|
||||
ui.defer_status_screen();
|
||||
ui.goto_screen(menu_mmu2_choose_filament);
|
||||
mmuMenuWait = true;
|
||||
while (mmuMenuWait) idle();
|
||||
wait_for_mmu_menu = true;
|
||||
while (wait_for_mmu_menu) idle();
|
||||
ui.return_to_status();
|
||||
return currentTool;
|
||||
return feeder_index;
|
||||
}
|
||||
|
||||
#endif // HAS_LCD_MENU && MMU2_MENUS
|
||||
|
Reference in New Issue
Block a user