2020-07-25 05:52:07 +00:00
|
|
|
/**
|
|
|
|
* Marlin 3D Printer Firmware
|
|
|
|
* Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
|
|
|
*
|
|
|
|
* Based on Sprinter and grbl.
|
|
|
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#include "../../../../inc/MarlinConfigPre.h"
|
|
|
|
|
|
|
|
#if HAS_TFT_LVGL_UI
|
|
|
|
|
|
|
|
#include "../../../../MarlinCore.h"
|
|
|
|
|
|
|
|
#include "lv_conf.h"
|
|
|
|
#include "draw_ui.h"
|
|
|
|
#include "../../../../module/temperature.h"
|
|
|
|
#include "../../../../module/motion.h"
|
|
|
|
#include "../../../../sd/cardreader.h"
|
|
|
|
#include "../../../../gcode/queue.h"
|
|
|
|
|
|
|
|
#if ENABLED(POWER_LOSS_RECOVERY)
|
|
|
|
#include "../../../../feature/powerloss.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "../../../../gcode/gcode.h"
|
|
|
|
#include "../../../../module/planner.h"
|
|
|
|
|
|
|
|
extern uint32_t To_pre_view;
|
|
|
|
extern uint8_t flash_preview_begin, default_preview_flg, gcode_preview_over;
|
|
|
|
|
|
|
|
void printer_state_polling() {
|
|
|
|
if (uiCfg.print_state == PAUSING) {
|
|
|
|
#if ENABLED(SDSUPPORT)
|
|
|
|
if (!planner.has_blocks_queued() && card.getIndex() > MIN_FILE_PRINTED)
|
|
|
|
uiCfg.waitEndMoves++;
|
|
|
|
|
|
|
|
if (uiCfg.waitEndMoves > 20) {
|
|
|
|
uiCfg.waitEndMoves = 0;
|
|
|
|
planner.synchronize();
|
2020-09-21 00:07:59 +00:00
|
|
|
|
2020-07-25 05:52:07 +00:00
|
|
|
gcode.process_subcommands_now_P(PSTR("M25"));
|
2020-09-21 01:55:02 +00:00
|
|
|
|
|
|
|
//save the positon
|
|
|
|
uiCfg.current_x_position_bak = current_position.x;
|
|
|
|
uiCfg.current_y_position_bak = current_position.y;
|
|
|
|
|
2020-07-25 05:52:07 +00:00
|
|
|
if (gCfgItems.pausePosZ != (float)-1) {
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G91"));
|
|
|
|
ZERO(public_buf_l);
|
|
|
|
sprintf_P(public_buf_l, PSTR("G1 Z%.1f"), gCfgItems.pausePosZ);
|
|
|
|
gcode.process_subcommands_now(public_buf_l);
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G90"));
|
|
|
|
}
|
|
|
|
if (gCfgItems.pausePosX != (float)-1 && gCfgItems.pausePosY != (float)-1) {
|
|
|
|
ZERO(public_buf_l);
|
|
|
|
sprintf_P(public_buf_l, PSTR("G1 X%.1f Y%.1f"), gCfgItems.pausePosX, gCfgItems.pausePosY);
|
|
|
|
gcode.process_subcommands_now(public_buf_l);
|
|
|
|
}
|
|
|
|
uiCfg.print_state = PAUSED;
|
2020-09-21 01:55:02 +00:00
|
|
|
uiCfg.current_e_position_bak = current_position.e;
|
2020-07-25 05:52:07 +00:00
|
|
|
|
|
|
|
// #if ENABLED(POWER_LOSS_RECOVERY)
|
|
|
|
// if (recovery.enabled) recovery.save(true);
|
|
|
|
// #endif
|
|
|
|
gCfgItems.pause_reprint = 1;
|
|
|
|
update_spi_flash();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
else
|
|
|
|
uiCfg.waitEndMoves = 0;
|
|
|
|
|
|
|
|
if (uiCfg.print_state == PAUSED) {
|
|
|
|
}
|
|
|
|
|
|
|
|
if (uiCfg.print_state == RESUMING) {
|
|
|
|
if (IS_SD_PAUSED()) {
|
2020-09-21 01:55:02 +00:00
|
|
|
if (gCfgItems.pausePosX != (float)-1 && gCfgItems.pausePosY != (float)-1) {
|
|
|
|
ZERO(public_buf_m);
|
|
|
|
sprintf_P(public_buf_m, PSTR("G1 X%.1f Y%.1f"), uiCfg.current_x_position_bak, uiCfg.current_y_position_bak);
|
|
|
|
gcode.process_subcommands_now(public_buf_m);
|
|
|
|
}
|
|
|
|
if (gCfgItems.pausePosZ != (float)-1) {
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G91"));
|
|
|
|
ZERO(public_buf_l);
|
|
|
|
sprintf_P(public_buf_l, PSTR("G1 Z-%.1f"), gCfgItems.pausePosZ);
|
|
|
|
gcode.process_subcommands_now(public_buf_l);
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G90"));
|
|
|
|
}
|
|
|
|
gcode.process_subcommands_now_P(PSTR("M24"));
|
2020-07-25 05:52:07 +00:00
|
|
|
uiCfg.print_state = WORKING;
|
|
|
|
start_print_time();
|
|
|
|
|
|
|
|
gCfgItems.pause_reprint = 0;
|
|
|
|
update_spi_flash();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#if ENABLED(POWER_LOSS_RECOVERY)
|
|
|
|
if (uiCfg.print_state == REPRINTED) {
|
|
|
|
ZERO(public_buf_m);
|
|
|
|
#if HAS_HOTEND
|
|
|
|
HOTEND_LOOP() {
|
|
|
|
const int16_t et = recovery.info.target_temperature[e];
|
|
|
|
if (et) {
|
|
|
|
#if HAS_MULTI_HOTEND
|
|
|
|
sprintf_P(public_buf_m, PSTR("T%i"), e);
|
|
|
|
gcode.process_subcommands_now(public_buf_m);
|
|
|
|
#endif
|
|
|
|
sprintf_P(public_buf_m, PSTR("M109 S%i"), et);
|
|
|
|
gcode.process_subcommands_now(public_buf_m);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
recovery.resume();
|
2020-09-21 01:55:02 +00:00
|
|
|
#if 0
|
|
|
|
// Move back to the saved XY
|
|
|
|
char str_1[16], str_2[16];
|
|
|
|
ZERO(public_buf_m);
|
|
|
|
sprintf_P(public_buf_m, PSTR("G1 X%s Y%s F2000"),
|
|
|
|
dtostrf(recovery.info.current_position.x, 1, 3, str_1),
|
|
|
|
dtostrf(recovery.info.current_position.y, 1, 3, str_2)
|
|
|
|
);
|
|
|
|
gcode.process_subcommands_now(public_buf_m);
|
|
|
|
|
|
|
|
if ((gCfgItems.pause_reprint) == 1 && (gCfgItems.pausePosZ != (float)-1)) {
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G91"));
|
|
|
|
ZERO(public_buf_l);
|
|
|
|
sprintf_P(public_buf_l, PSTR("G1 Z-%.1f"), gCfgItems.pausePosZ);
|
|
|
|
gcode.process_subcommands_now(public_buf_l);
|
|
|
|
gcode.process_subcommands_now_P(PSTR("G90"));
|
|
|
|
}
|
|
|
|
#endif
|
2020-07-25 05:52:07 +00:00
|
|
|
uiCfg.print_state = WORKING;
|
|
|
|
start_print_time();
|
|
|
|
|
|
|
|
gCfgItems.pause_reprint = 0;
|
|
|
|
update_spi_flash();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (uiCfg.print_state == WORKING)
|
|
|
|
filament_check();
|
2020-09-21 01:55:02 +00:00
|
|
|
|
|
|
|
TERN_(USE_WIFI_FUNCTION, wifi_looping());
|
2020-07-25 05:52:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void filament_pin_setup() {
|
|
|
|
#if PIN_EXISTS(MT_DET_1)
|
|
|
|
pinMode(MT_DET_1_PIN, INPUT_PULLUP);
|
|
|
|
#endif
|
|
|
|
#if PIN_EXISTS(MT_DET_2)
|
|
|
|
pinMode(MT_DET_2_PIN, INPUT_PULLUP);
|
|
|
|
#endif
|
|
|
|
#if PIN_EXISTS(MT_DET_3)
|
|
|
|
pinMode(MT_DET_3_PIN, INPUT_PULLUP);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void filament_check() {
|
|
|
|
const int FIL_DELAY = 20;
|
|
|
|
#if PIN_EXISTS(MT_DET_1)
|
|
|
|
static int fil_det_count_1 = 0;
|
|
|
|
if (!READ(MT_DET_1_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_1++;
|
|
|
|
else if (READ(MT_DET_1_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_1++;
|
|
|
|
else if (fil_det_count_1 > 0)
|
|
|
|
fil_det_count_1--;
|
|
|
|
|
|
|
|
if (!READ(MT_DET_1_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_1++;
|
|
|
|
else if (READ(MT_DET_1_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_1++;
|
|
|
|
else if (fil_det_count_1 > 0)
|
|
|
|
fil_det_count_1--;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if PIN_EXISTS(MT_DET_2)
|
|
|
|
static int fil_det_count_2 = 0;
|
|
|
|
if (!READ(MT_DET_2_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_2++;
|
|
|
|
else if (READ(MT_DET_2_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_2++;
|
|
|
|
else if (fil_det_count_2 > 0)
|
|
|
|
fil_det_count_2--;
|
|
|
|
|
|
|
|
if (!READ(MT_DET_2_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_2++;
|
|
|
|
else if (READ(MT_DET_2_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_2++;
|
|
|
|
else if (fil_det_count_2 > 0)
|
|
|
|
fil_det_count_2--;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if PIN_EXISTS(MT_DET_3)
|
|
|
|
static int fil_det_count_3 = 0;
|
|
|
|
if (!READ(MT_DET_3_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_3++;
|
|
|
|
else if (READ(MT_DET_3_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_3++;
|
|
|
|
else if (fil_det_count_3 > 0)
|
|
|
|
fil_det_count_3--;
|
|
|
|
|
|
|
|
if (!READ(MT_DET_3_PIN) && !MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_3++;
|
|
|
|
else if (READ(MT_DET_3_PIN) && MT_DET_PIN_INVERTING)
|
|
|
|
fil_det_count_3++;
|
|
|
|
else if (fil_det_count_3 > 0)
|
|
|
|
fil_det_count_3--;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (false
|
|
|
|
#if PIN_EXISTS(MT_DET_1)
|
|
|
|
|| fil_det_count_1 >= FIL_DELAY
|
|
|
|
#endif
|
|
|
|
#if PIN_EXISTS(MT_DET_2)
|
|
|
|
|| fil_det_count_2 >= FIL_DELAY
|
|
|
|
#endif
|
|
|
|
#if PIN_EXISTS(MT_DET_3)
|
|
|
|
|| fil_det_count_3 >= FIL_DELAY
|
|
|
|
#endif
|
|
|
|
) {
|
|
|
|
clear_cur_ui();
|
|
|
|
card.pauseSDPrint();
|
|
|
|
stop_print_time();
|
|
|
|
uiCfg.print_state = PAUSING;
|
|
|
|
|
|
|
|
if (gCfgItems.from_flash_pic == 1)
|
|
|
|
flash_preview_begin = 1;
|
|
|
|
else
|
|
|
|
default_preview_flg = 1;
|
|
|
|
|
|
|
|
lv_draw_printing();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // HAS_TFT_LVGL_UI
|