79 lines
2.5 KiB
C++
79 lines
2.5 KiB
C++
/**
|
|
* 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/>.
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* DWIN Print Stats page
|
|
* Author: Miguel A. Risco-Castillo (MRISCOC)
|
|
* Version: 1.1
|
|
* Date: 2022/01/09
|
|
*
|
|
* Based on the original code provided by Creality under GPL
|
|
*/
|
|
|
|
#include "../../../inc/MarlinConfigPre.h"
|
|
|
|
#if BOTH(DWIN_LCD_PROUI, PRINTCOUNTER)
|
|
|
|
#include "printstats.h"
|
|
|
|
#include "../../../core/types.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::ClearMenuArea();
|
|
Draw_Popup_Bkgd();
|
|
DWINUI::Draw_Icon(ICON_Continue_E, 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();
|
|
HMI_AudioFeedback();
|
|
}
|
|
|
|
#endif // DWIN_LCD_PROUI && PRINTCOUNTER
|