Group and adjust LCD buttons code
This commit is contained in:
		@@ -45,7 +45,6 @@
 | 
				
			|||||||
    #include "../feature/pause.h"
 | 
					    #include "../feature/pause.h"
 | 
				
			||||||
  #endif
 | 
					  #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
  bool lcd_hasstatus();
 | 
					  bool lcd_hasstatus();
 | 
				
			||||||
  void lcd_setstatus(const char* message, const bool persist=false);
 | 
					  void lcd_setstatus(const char* message, const bool persist=false);
 | 
				
			||||||
  void lcd_setstatusPGM(const char* message, const int8_t level=0);
 | 
					  void lcd_setstatusPGM(const char* message, const int8_t level=0);
 | 
				
			||||||
@@ -90,7 +89,7 @@
 | 
				
			|||||||
  #define BUTTON_EXISTS(BN) (defined(BTN_## BN) && BTN_## BN >= 0)
 | 
					  #define BUTTON_EXISTS(BN) (defined(BTN_## BN) && BTN_## BN >= 0)
 | 
				
			||||||
  #define BUTTON_PRESSED(BN) !READ(BTN_## BN)
 | 
					  #define BUTTON_PRESSED(BN) !READ(BTN_## BN)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  #if ENABLED(ULTIPANEL)
 | 
					  #if ENABLED(ULTIPANEL) // LCD with a click-wheel input
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    extern bool defer_return_to_status;
 | 
					    extern bool defer_return_to_status;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -114,27 +113,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    void lcd_goto_screen(screenFunc_t screen, const uint32_t encoder=0);
 | 
					    void lcd_goto_screen(screenFunc_t screen, const uint32_t encoder=0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Encoder click is directly connected
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    #define BLEN_A 0
 | 
					 | 
				
			||||||
    #define BLEN_B 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    #define EN_A (_BV(BLEN_A))
 | 
					 | 
				
			||||||
    #define EN_B (_BV(BLEN_B))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    #if BUTTON_EXISTS(ENC)
 | 
					 | 
				
			||||||
      #define BLEN_C 2
 | 
					 | 
				
			||||||
      #define EN_C (_BV(BLEN_C))
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    #if BUTTON_EXISTS(BACK)
 | 
					 | 
				
			||||||
      #define BLEN_D 3
 | 
					 | 
				
			||||||
      #define EN_D _BV(BLEN_D)
 | 
					 | 
				
			||||||
      #define LCD_BACK_CLICKED (buttons & EN_D)
 | 
					 | 
				
			||||||
    #endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    extern volatile uint8_t buttons;  // The last-checked buttons in a bit array.
 | 
					 | 
				
			||||||
    void lcd_buttons_update();
 | 
					 | 
				
			||||||
    void lcd_completion_feedback(const bool good=true);
 | 
					    void lcd_completion_feedback(const bool good=true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    #if ENABLED(ADVANCED_PAUSE_FEATURE)
 | 
					    #if ENABLED(ADVANCED_PAUSE_FEATURE)
 | 
				
			||||||
@@ -142,7 +120,7 @@
 | 
				
			|||||||
      void lcd_advanced_pause_show_message(const AdvancedPauseMessage message,
 | 
					      void lcd_advanced_pause_show_message(const AdvancedPauseMessage message,
 | 
				
			||||||
                                           const AdvancedPauseMode mode=ADVANCED_PAUSE_MODE_PAUSE_PRINT,
 | 
					                                           const AdvancedPauseMode mode=ADVANCED_PAUSE_MODE_PAUSE_PRINT,
 | 
				
			||||||
                                           const uint8_t extruder=active_extruder);
 | 
					                                           const uint8_t extruder=active_extruder);
 | 
				
			||||||
    #endif // ADVANCED_PAUSE_FEATURE
 | 
					    #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    #if ENABLED(G26_MESH_VALIDATION)
 | 
					    #if ENABLED(G26_MESH_VALIDATION)
 | 
				
			||||||
      void lcd_chirp();
 | 
					      void lcd_chirp();
 | 
				
			||||||
@@ -155,10 +133,6 @@
 | 
				
			|||||||
      float lcd_z_offset_edit();
 | 
					      float lcd_z_offset_edit();
 | 
				
			||||||
    #endif
 | 
					    #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  #else
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    inline void lcd_buttons_update() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  #endif
 | 
					  #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  #if ENABLED(FILAMENT_LCD_DISPLAY) && ENABLED(SDSUPPORT)
 | 
					  #if ENABLED(FILAMENT_LCD_DISPLAY) && ENABLED(SDSUPPORT)
 | 
				
			||||||
@@ -243,7 +217,6 @@
 | 
				
			|||||||
  constexpr bool lcd_wait_for_move = false;
 | 
					  constexpr bool lcd_wait_for_move = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  inline void lcd_refresh() {}
 | 
					  inline void lcd_refresh() {}
 | 
				
			||||||
  inline void lcd_buttons_update() {}
 | 
					 | 
				
			||||||
  inline bool lcd_hasstatus() { return false; }
 | 
					  inline bool lcd_hasstatus() { return false; }
 | 
				
			||||||
  inline void lcd_setstatus(const char* const message, const bool persist=false) { UNUSED(message); UNUSED(persist); }
 | 
					  inline void lcd_setstatus(const char* const message, const bool persist=false) { UNUSED(message); UNUSED(persist); }
 | 
				
			||||||
  inline void lcd_setstatusPGM(const char* const message, const int8_t level=0) { UNUSED(message); UNUSED(level); }
 | 
					  inline void lcd_setstatusPGM(const char* const message, const int8_t level=0) { UNUSED(message); UNUSED(level); }
 | 
				
			||||||
@@ -253,6 +226,39 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#endif // ULTRA_LCD
 | 
					#endif // ULTRA_LCD
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if ENABLED(ULTIPANEL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  #if ENABLED(NEWPANEL) // Uses digital switches, not a shift register
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Wheel spin pins where BA is 00, 10, 11, 01 (1 bit always changes)
 | 
				
			||||||
 | 
					    #define BLEN_A 0
 | 
				
			||||||
 | 
					    #define BLEN_B 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    #define EN_A _BV(BLEN_A)
 | 
				
			||||||
 | 
					    #define EN_B _BV(BLEN_B)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    #if BUTTON_EXISTS(ENC)
 | 
				
			||||||
 | 
					      #define BLEN_C 2
 | 
				
			||||||
 | 
					      #define EN_C _BV(BLEN_C)
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    #if BUTTON_EXISTS(BACK)
 | 
				
			||||||
 | 
					      #define BLEN_D 3
 | 
				
			||||||
 | 
					      #define EN_D _BV(BLEN_D)
 | 
				
			||||||
 | 
					      #define LCD_BACK_CLICKED (buttons & EN_D)
 | 
				
			||||||
 | 
					    #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  #endif // NEWPANEL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  extern volatile uint8_t buttons;  // The last-checked buttons in a bit array.
 | 
				
			||||||
 | 
					  void lcd_buttons_update();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  inline void lcd_buttons_update() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define LCD_MESSAGEPGM(x)      lcd_setstatusPGM(PSTR(x))
 | 
					#define LCD_MESSAGEPGM(x)      lcd_setstatusPGM(PSTR(x))
 | 
				
			||||||
#define LCD_ALERTMESSAGEPGM(x) lcd_setalertstatusPGM(PSTR(x))
 | 
					#define LCD_ALERTMESSAGEPGM(x) lcd_setalertstatusPGM(PSTR(x))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -72,19 +72,19 @@ extern volatile uint8_t buttons;  //an extended version of the last checked butt
 | 
				
			|||||||
    #define B_I2C_BTN_OFFSET 3 // (the first three bit positions reserved for EN_A, EN_B, EN_C)
 | 
					    #define B_I2C_BTN_OFFSET 3 // (the first three bit positions reserved for EN_A, EN_B, EN_C)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // button and encoder bit positions within 'buttons'
 | 
					    // button and encoder bit positions within 'buttons'
 | 
				
			||||||
    #define B_LE (BUTTON_LEFT<<B_I2C_BTN_OFFSET)    // The remaining normalized buttons are all read via I2C
 | 
					    #define B_LE (BUTTON_LEFT   << B_I2C_BTN_OFFSET)    // The remaining normalized buttons are all read via I2C
 | 
				
			||||||
    #define B_UP (BUTTON_UP<<B_I2C_BTN_OFFSET)
 | 
					    #define B_UP (BUTTON_UP     << B_I2C_BTN_OFFSET)
 | 
				
			||||||
    #define B_MI (BUTTON_SELECT<<B_I2C_BTN_OFFSET)
 | 
					    #define B_MI (BUTTON_SELECT << B_I2C_BTN_OFFSET)
 | 
				
			||||||
    #define B_DW (BUTTON_DOWN<<B_I2C_BTN_OFFSET)
 | 
					    #define B_DW (BUTTON_DOWN   << B_I2C_BTN_OFFSET)
 | 
				
			||||||
    #define B_RI (BUTTON_RIGHT<<B_I2C_BTN_OFFSET)
 | 
					    #define B_RI (BUTTON_RIGHT  << B_I2C_BTN_OFFSET)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    #undef LCD_CLICKED
 | 
					    #undef LCD_CLICKED
 | 
				
			||||||
    #if BUTTON_EXISTS(ENC)
 | 
					    #if BUTTON_EXISTS(ENC)
 | 
				
			||||||
      // the pause/stop/restart button is connected to BTN_ENC when used
 | 
					      // the pause/stop/restart button is connected to BTN_ENC when used
 | 
				
			||||||
      #define B_ST (EN_C)                            // Map the pause/stop/resume button into its normalized functional name
 | 
					      #define B_ST (EN_C)                            // Map the pause/stop/resume button into its normalized functional name
 | 
				
			||||||
      #define LCD_CLICKED (buttons&(B_MI|B_RI|B_ST)) // pause/stop button also acts as click until we implement proper pause/stop.
 | 
					      #define LCD_CLICKED (buttons & (B_MI|B_RI|B_ST)) // pause/stop button also acts as click until we implement proper pause/stop.
 | 
				
			||||||
    #else
 | 
					    #else
 | 
				
			||||||
      #define LCD_CLICKED (buttons&(B_MI|B_RI))
 | 
					      #define LCD_CLICKED (buttons & (B_MI|B_RI))
 | 
				
			||||||
    #endif
 | 
					    #endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // I2C buttons take too long to read inside an interrupt context and so we read them during lcd_update
 | 
					    // I2C buttons take too long to read inside an interrupt context and so we read them during lcd_update
 | 
				
			||||||
@@ -96,7 +96,7 @@ extern volatile uint8_t buttons;  //an extended version of the last checked butt
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      #define B_I2C_BTN_OFFSET 3 // (the first three bit positions reserved for EN_A, EN_B, EN_C)
 | 
					      #define B_I2C_BTN_OFFSET 3 // (the first three bit positions reserved for EN_A, EN_B, EN_C)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      #define B_MI (PANELOLU2_ENCODER_C<<B_I2C_BTN_OFFSET) // requires LiquidTWI2 library v1.2.3 or later
 | 
					      #define B_MI (PANELOLU2_ENCODER_C << B_I2C_BTN_OFFSET) // requires LiquidTWI2 library v1.2.3 or later
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      #undef LCD_CLICKED
 | 
					      #undef LCD_CLICKED
 | 
				
			||||||
      #define LCD_CLICKED (buttons & B_MI)
 | 
					      #define LCD_CLICKED (buttons & B_MI)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user