12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- /**
- * Marlin 3D Printer Firmware
- * Copyright (c) 2021 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/>.
- *
- */
-
- /**
- * Print Stats page for PRO UI
- * Author: Miguel A. Risco-Castillo (MRISCOC)
- * Version: 1.3.0
- * Date: 2022/02/24
- */
-
- #include "../../../inc/MarlinConfigPre.h"
-
- #if BOTH(DWIN_LCD_PROUI, PRINTCOUNTER)
-
- #include "printstats.h"
-
- #include "../../../core/types.h"
- #include "../../../MarlinCore.h"
- #include "../../marlinui.h"
- #include "../../../module/printcounter.h"
- #include "dwin_lcd.h"
- #include "dwinui.h"
- #include "dwin_popup.h"
- #include "dwin.h"
-
- PrintStatsClass PrintStats;
-
- void PrintStatsClass::Draw() {
- char buf[50] = "";
- char str[30] = "";
- constexpr int8_t MRG = 30;
-
- Title.ShowCaption(GET_TEXT_F(MSG_INFO_STATS_MENU));
- DWINUI::ClearMainArea();
- Draw_Popup_Bkgd();
- DWINUI::Draw_Button(BTN_Continue, 86, 250);
- printStatistics ps = print_job_timer.getStats();
-
- sprintf_P(buf, PSTR(S_FMT ": %i"), GET_TEXT(MSG_INFO_PRINT_COUNT), ps.totalPrints);
- DWINUI::Draw_String(MRG, 80, buf);
- sprintf_P(buf, PSTR(S_FMT ": %i"), GET_TEXT(MSG_INFO_COMPLETED_PRINTS), ps.finishedPrints);
- DWINUI::Draw_String(MRG, 100, buf);
- duration_t(print_job_timer.getStats().printTime).toDigital(str, true);
- sprintf_P(buf, PSTR(S_FMT ": %s"), GET_TEXT(MSG_INFO_PRINT_TIME), str);
- DWINUI::Draw_String(MRG, 120, buf);
- duration_t(print_job_timer.getStats().longestPrint).toDigital(str, true);
- sprintf_P(buf, PSTR(S_FMT ": %s"), GET_TEXT(MSG_INFO_PRINT_LONGEST), str);
- DWINUI::Draw_String(MRG, 140, buf);
- sprintf_P(buf, PSTR(S_FMT ": %s m"), GET_TEXT(MSG_INFO_PRINT_FILAMENT), dtostrf(ps.filamentUsed / 1000, 1, 2, str));
- DWINUI::Draw_String(MRG, 160, buf);
- }
-
- void PrintStatsClass::Reset() {
- print_job_timer.initStats();
- DONE_BUZZ(true);
- }
-
- void Goto_PrintStats() {
- PrintStats.Draw();
- HMI_SaveProcessID(WaitResponse);
- }
-
- #endif // DWIN_LCD_PROUI && PRINTCOUNTER
|