✨ DOGM Display Sleep (#23992)
Co-authored-by: borland1 <barryorlando@hotmail.com>
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							4ae54a6229
						
					
				
				
					commit
					dbd00d9927
				
			| @@ -1671,6 +1671,17 @@ | ||||
|   // Western only. Not available for Cyrillic, Kana, Turkish, Greek, or Chinese. | ||||
|   //#define USE_SMALL_INFOFONT | ||||
|  | ||||
|   /** | ||||
|    * Graphical Display Sleep | ||||
|    * | ||||
|    * The U8G library provides sleep / wake functions for SH1106, SSD1306, | ||||
|    * SSD1309, and some other DOGM displays. | ||||
|    * Enable this option to save energy and prevent OLED pixel burn-in. | ||||
|    * Adds the menu item Configuration > LCD Timeout (m) to set a wait period | ||||
|    * from 0 (disabled) to 99 minutes. | ||||
|    */ | ||||
|   //#define DISPLAY_SLEEP_MINUTES 2  // (minutes) Timeout before turning off the screen | ||||
|  | ||||
|   /** | ||||
|    * ST7920-based LCDs can emulate a 16 x 4 character display using | ||||
|    * the ST7920 character-generator for very fast screen updates. | ||||
|   | ||||
| @@ -315,6 +315,7 @@ | ||||
| #define STR_MATERIAL_HEATUP                 "Material heatup parameters" | ||||
| #define STR_LCD_CONTRAST                    "LCD Contrast" | ||||
| #define STR_LCD_BRIGHTNESS                  "LCD Brightness" | ||||
| #define STR_DISPLAY_SLEEP                   "Display Sleep" | ||||
| #define STR_UI_LANGUAGE                     "UI Language" | ||||
| #define STR_Z_PROBE_OFFSET                  "Z-Probe Offset" | ||||
| #define STR_TEMPERATURE_UNITS               "Temperature Units" | ||||
|   | ||||
| @@ -202,6 +202,7 @@ | ||||
|  * M226 - Wait until a pin is in a given state: "M226 P<pin> S<state>" (Requires DIRECT_PIN_CONTROL) | ||||
|  * M240 - Trigger a camera to take a photograph. (Requires PHOTO_GCODE) | ||||
|  * M250 - Set LCD contrast: "M250 C<contrast>" (0-63). (Requires LCD support) | ||||
|  * M255 - Set LCD sleep time: "M255 S<minutes>" (0-99). (Requires an LCD with brightness or sleep/wake) | ||||
|  * M256 - Set LCD brightness: "M256 B<brightness>" (0-255). (Requires an LCD with brightness control) | ||||
|  * M260 - i2c Send Data (Requires EXPERIMENTAL_I2CBUS) | ||||
|  * M261 - i2c Request Data (Requires EXPERIMENTAL_I2CBUS) | ||||
| @@ -878,6 +879,11 @@ private: | ||||
|     static void M250_report(const bool forReplay=true); | ||||
|   #endif | ||||
|  | ||||
|   #if HAS_DISPLAY_SLEEP | ||||
|     static void M255(); | ||||
|     static void M255_report(const bool forReplay=true); | ||||
|   #endif | ||||
|  | ||||
|   #if HAS_LCD_BRIGHTNESS | ||||
|     static void M256(); | ||||
|     static void M256_report(const bool forReplay=true); | ||||
|   | ||||
							
								
								
									
										58
									
								
								Marlin/src/gcode/lcd/M255.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								Marlin/src/gcode/lcd/M255.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| /** | ||||
|  * Marlin 3D Printer Firmware | ||||
|  * Copyright (c) 2022 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/MarlinConfig.h" | ||||
|  | ||||
| #if HAS_GCODE_M255 | ||||
|  | ||||
| #include "../gcode.h" | ||||
| #include "../../lcd/marlinui.h" | ||||
|  | ||||
| /** | ||||
|  * M255: Set the LCD sleep timeout (in minutes) | ||||
|  *  S<minutes> - Period of inactivity required for display / backlight sleep | ||||
|  */ | ||||
| void GcodeSuite::M255() { | ||||
|   if (parser.seenval('S')) { | ||||
|     #if HAS_DISPLAY_SLEEP | ||||
|       const int m = parser.value_int(); | ||||
|       ui.sleep_timeout_minutes = constrain(m, SLEEP_TIMEOUT_MIN, SLEEP_TIMEOUT_MAX); | ||||
|     #else | ||||
|       const int s = parser.value_int() * 60; | ||||
|       ui.lcd_backlight_timeout = constrain(s, LCD_BKL_TIMEOUT_MIN, LCD_BKL_TIMEOUT_MAX); | ||||
|     #endif | ||||
|   } | ||||
|   else | ||||
|     M255_report(); | ||||
| } | ||||
|  | ||||
| void GcodeSuite::M255_report(const bool forReplay/*=true*/) { | ||||
|   report_heading_etc(forReplay, F(STR_DISPLAY_SLEEP)); | ||||
|   SERIAL_ECHOLNPGM("  M255 S", | ||||
|     #if HAS_DISPLAY_SLEEP | ||||
|       ui.sleep_timeout_minutes, " ; (minutes)" | ||||
|     #else | ||||
|       ui.lcd_backlight_timeout, " ; (seconds)" | ||||
|     #endif | ||||
|   ); | ||||
| } | ||||
|  | ||||
| #endif // HAS_GCODE_M255 | ||||
| @@ -628,6 +628,12 @@ | ||||
| #if ALL(HAS_RESUME_CONTINUE, PRINTER_EVENT_LEDS, SDSUPPORT) | ||||
|   #define HAS_LEDS_OFF_FLAG 1 | ||||
| #endif | ||||
| #ifdef DISPLAY_SLEEP_MINUTES | ||||
|   #define HAS_DISPLAY_SLEEP 1 | ||||
| #endif | ||||
| #if HAS_DISPLAY_SLEEP || LCD_BACKLIGHT_TIMEOUT | ||||
|   #define HAS_GCODE_M255 1 | ||||
| #endif | ||||
|  | ||||
| #if EITHER(DIGIPOT_MCP4018, DIGIPOT_MCP4451) | ||||
|   #define HAS_MOTOR_CURRENT_I2C 1 | ||||
|   | ||||
| @@ -2885,6 +2885,17 @@ static_assert(Y_MAX_LENGTH >= Y_BED_SIZE, "Movement bounds (Y_MIN_POS, Y_MAX_POS | ||||
|   #endif | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * Display Sleep is not supported by these common displays | ||||
|  */ | ||||
| #if HAS_DISPLAY_SLEEP | ||||
|   #if ANY(IS_U8GLIB_LM6059_AF, IS_U8GLIB_ST7565_64128, REPRAPWORLD_GRAPHICAL_LCD, FYSETC_MINI, ENDER2_STOCKDISPLAY, MINIPANEL) | ||||
|     #error "DISPLAY_SLEEP_MINUTES is not supported by your display." | ||||
|   #elif !WITHIN(DISPLAY_SLEEP_MINUTES, 0, 255) | ||||
|     #error "DISPLAY_SLEEP_MINUTES must be between 0 and 255." | ||||
|   #endif | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * Some boards forbid the use of -1 Native USB | ||||
|  */ | ||||
|   | ||||
| @@ -342,6 +342,11 @@ void MarlinUI::draw_kill_screen() { | ||||
|  | ||||
| void MarlinUI::clear_lcd() { } // Automatically cleared by Picture Loop | ||||
|  | ||||
| #if HAS_DISPLAY_SLEEP | ||||
|   void MarlinUI::sleep_on()  { u8g.sleepOn(); } | ||||
|   void MarlinUI::sleep_off() { u8g.sleepOff(); } | ||||
| #endif | ||||
|  | ||||
| #if HAS_LCD_BRIGHTNESS | ||||
|  | ||||
|   void MarlinUI::_set_brightness() { | ||||
|   | ||||
| @@ -442,6 +442,7 @@ namespace Language_en { | ||||
|   LSTR MSG_CONTRAST                       = _UxGT("LCD Contrast"); | ||||
|   LSTR MSG_BRIGHTNESS                     = _UxGT("LCD Brightness"); | ||||
|   LSTR MSG_LCD_TIMEOUT_SEC                = _UxGT("LCD Timeout (s)"); | ||||
|   LSTR MSG_SCREEN_TIMEOUT                 = _UxGT("LCD Timeout (m)"); | ||||
|   LSTR MSG_BRIGHTNESS_OFF                 = _UxGT("Backlight Off"); | ||||
|   LSTR MSG_STORE_EEPROM                   = _UxGT("Store Settings"); | ||||
|   LSTR MSG_LOAD_EEPROM                    = _UxGT("Load Settings"); | ||||
|   | ||||
| @@ -191,6 +191,15 @@ constexpr uint8_t epps = ENCODER_PULSES_PER_STEP; | ||||
|     WRITE(LCD_BACKLIGHT_PIN, HIGH); | ||||
|   } | ||||
|  | ||||
| #elif HAS_DISPLAY_SLEEP | ||||
|  | ||||
|   uint8_t MarlinUI::sleep_timeout_minutes; // Initialized by settings.load() | ||||
|   millis_t MarlinUI::screen_timeout_millis = 0; | ||||
|   void MarlinUI::refresh_screen_timeout() { | ||||
|     screen_timeout_millis = sleep_timeout_minutes ? millis() + sleep_timeout_minutes * 60UL * 1000UL : 0; | ||||
|     sleep_off(); | ||||
|   } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| void MarlinUI::init() { | ||||
| @@ -1060,6 +1069,8 @@ void MarlinUI::init() { | ||||
|  | ||||
|           #if LCD_BACKLIGHT_TIMEOUT | ||||
|             refresh_backlight_timeout(); | ||||
|           #elif HAS_DISPLAY_SLEEP | ||||
|             refresh_screen_timeout(); | ||||
|           #endif | ||||
|  | ||||
|           refresh(LCDVIEW_REDRAW_NOW); | ||||
| @@ -1171,6 +1182,9 @@ void MarlinUI::init() { | ||||
|           WRITE(LCD_BACKLIGHT_PIN, LOW); // Backlight off | ||||
|           backlight_off_ms = 0; | ||||
|         } | ||||
|       #elif HAS_DISPLAY_SLEEP | ||||
|         if (screen_timeout_millis && ELAPSED(ms, screen_timeout_millis)) | ||||
|           sleep_on(); | ||||
|       #endif | ||||
|  | ||||
|       // Change state of drawing flag between screen updates | ||||
|   | ||||
| @@ -279,6 +279,14 @@ public: | ||||
|     static uint16_t lcd_backlight_timeout; | ||||
|     static millis_t backlight_off_ms; | ||||
|     static void refresh_backlight_timeout(); | ||||
|   #elif HAS_DISPLAY_SLEEP | ||||
|     #define SLEEP_TIMEOUT_MIN 0 | ||||
|     #define SLEEP_TIMEOUT_MAX 99 | ||||
|     static uint8_t sleep_timeout_minutes; | ||||
|     static millis_t screen_timeout_millis; | ||||
|     static void refresh_screen_timeout(); | ||||
|     static void sleep_on(); | ||||
|     static void sleep_off(); | ||||
|   #endif | ||||
|  | ||||
|   #if HAS_DWIN_E3V2_BASIC | ||||
|   | ||||
| @@ -549,6 +549,8 @@ void menu_configuration() { | ||||
|   // | ||||
|   #if LCD_BACKLIGHT_TIMEOUT && LCD_BKL_TIMEOUT_MIN < LCD_BKL_TIMEOUT_MAX | ||||
|     EDIT_ITEM(uint16_4, MSG_LCD_TIMEOUT_SEC, &ui.lcd_backlight_timeout, LCD_BKL_TIMEOUT_MIN, LCD_BKL_TIMEOUT_MAX, ui.refresh_backlight_timeout); | ||||
|   #elif HAS_DISPLAY_SLEEP | ||||
|     EDIT_ITEM(uint8, MSG_SCREEN_TIMEOUT, &ui.sleep_timeout_minutes, SLEEP_TIMEOUT_MIN, SLEEP_TIMEOUT_MAX, ui.refresh_screen_timeout); | ||||
|   #endif | ||||
|  | ||||
|   #if ENABLED(FWRETRACT) | ||||
|   | ||||
| @@ -402,7 +402,9 @@ typedef struct SettingsDataStruct { | ||||
|   // Display Sleep | ||||
|   // | ||||
|   #if LCD_BACKLIGHT_TIMEOUT | ||||
|     uint16_t lcd_backlight_timeout;                     // (G-code needed) | ||||
|     uint16_t lcd_backlight_timeout;                     // M255 S | ||||
|   #elif HAS_DISPLAY_SLEEP | ||||
|     uint8_t sleep_timeout_minutes;                      // M255 S | ||||
|   #endif | ||||
|  | ||||
|   // | ||||
| @@ -631,6 +633,8 @@ void MarlinSettings::postprocess() { | ||||
|  | ||||
|   #if LCD_BACKLIGHT_TIMEOUT | ||||
|     ui.refresh_backlight_timeout(); | ||||
|   #elif HAS_DISPLAY_SLEEP | ||||
|     ui.refresh_screen_timeout(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| @@ -1146,6 +1150,8 @@ void MarlinSettings::postprocess() { | ||||
|     // | ||||
|     #if LCD_BACKLIGHT_TIMEOUT | ||||
|       EEPROM_WRITE(ui.lcd_backlight_timeout); | ||||
|     #elif HAS_DISPLAY_SLEEP | ||||
|       EEPROM_WRITE(ui.sleep_timeout_minutes); | ||||
|     #endif | ||||
|  | ||||
|     // | ||||
| @@ -2077,6 +2083,8 @@ void MarlinSettings::postprocess() { | ||||
|       // | ||||
|       #if LCD_BACKLIGHT_TIMEOUT | ||||
|         EEPROM_READ(ui.lcd_backlight_timeout); | ||||
|       #elif HAS_DISPLAY_SLEEP | ||||
|         EEPROM_READ(ui.sleep_timeout_minutes); | ||||
|       #endif | ||||
|  | ||||
|       // | ||||
| @@ -3128,6 +3136,8 @@ void MarlinSettings::reset() { | ||||
|   // | ||||
|   #if LCD_BACKLIGHT_TIMEOUT | ||||
|     ui.lcd_backlight_timeout = LCD_BACKLIGHT_TIMEOUT; | ||||
|   #elif HAS_DISPLAY_SLEEP | ||||
|     ui.sleep_timeout_minutes = DISPLAY_SLEEP_MINUTES; | ||||
|   #endif | ||||
|  | ||||
|   // | ||||
| @@ -3464,6 +3474,11 @@ void MarlinSettings::reset() { | ||||
|     // | ||||
|     TERN_(HAS_LCD_CONTRAST, gcode.M250_report(forReplay)); | ||||
|  | ||||
|     // | ||||
|     // Display Sleep | ||||
|     // | ||||
|     TERN_(HAS_GCODE_M255, gcode.M255_report(forReplay)); | ||||
|  | ||||
|     // | ||||
|     // LCD Brightness | ||||
|     // | ||||
|   | ||||
		Reference in New Issue
	
	Block a user