|
@ -12,7 +12,7 @@ LiquidCrystal lcd(LCD_PINS_RS, LCD_PINS_ENABLE, LCD_PINS_D4, LCD_PINS_D5,LCD_PIN |
|
|
|
|
|
|
|
|
unsigned long previous_millis_lcd=0; |
|
|
unsigned long previous_millis_lcd=0; |
|
|
|
|
|
|
|
|
|
|
|
inline int intround(const float &x){return int(0.5+x);} |
|
|
|
|
|
|
|
|
volatile char buttons=0; //the last checked buttons in a bit array. |
|
|
volatile char buttons=0; //the last checked buttons in a bit array. |
|
|
int encoderpos=0; |
|
|
int encoderpos=0; |
|
@ -29,13 +29,10 @@ void lcd_status(const char* message) |
|
|
strncpy(messagetext,message,LCD_WIDTH); |
|
|
strncpy(messagetext,message,LCD_WIDTH); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void clear() |
|
|
inline void clear() |
|
|
{ |
|
|
{ |
|
|
//lcd.setCursor(0,0); |
|
|
|
|
|
lcd.clear(); |
|
|
lcd.clear(); |
|
|
//delay(1); |
|
|
|
|
|
// lcd.begin(LCD_WIDTH,LCD_HEIGHT); |
|
|
|
|
|
//lcd_init(); |
|
|
|
|
|
} |
|
|
} |
|
|
long previous_millis_buttons=0; |
|
|
long previous_millis_buttons=0; |
|
|
|
|
|
|
|
@ -102,6 +99,7 @@ void beepshort() |
|
|
} |
|
|
} |
|
|
#endif |
|
|
#endif |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void lcd_status() |
|
|
void lcd_status() |
|
|
{ |
|
|
{ |
|
|
#ifdef ULTIPANEL |
|
|
#ifdef ULTIPANEL |
|
@ -161,8 +159,7 @@ void buttons_check() |
|
|
if((blocking<millis()) &&(READ(BTN_ENC)==0)) |
|
|
if((blocking<millis()) &&(READ(BTN_ENC)==0)) |
|
|
newbutton|=EN_C; |
|
|
newbutton|=EN_C; |
|
|
buttons=newbutton; |
|
|
buttons=newbutton; |
|
|
#else |
|
|
#else //read it from the shift register |
|
|
//read it from the shift register |
|
|
|
|
|
uint8_t newbutton=0; |
|
|
uint8_t newbutton=0; |
|
|
WRITE(SHIFT_LD,LOW); |
|
|
WRITE(SHIFT_LD,LOW); |
|
|
WRITE(SHIFT_LD,HIGH); |
|
|
WRITE(SHIFT_LD,HIGH); |
|
@ -238,8 +235,8 @@ extern volatile bool feedmultiplychanged; |
|
|
void MainMenu::showStatus() |
|
|
void MainMenu::showStatus() |
|
|
{ |
|
|
{ |
|
|
#if LCD_HEIGHT==4 |
|
|
#if LCD_HEIGHT==4 |
|
|
static int oldcurrentraw=-1; |
|
|
static int olddegHotEnd0=-1; |
|
|
static int oldtargetraw=-1; |
|
|
static int oldtargetHotEnd0=-1; |
|
|
//force_lcd_update=true; |
|
|
//force_lcd_update=true; |
|
|
if(force_lcd_update||feedmultiplychanged) //initial display of content |
|
|
if(force_lcd_update||feedmultiplychanged) //initial display of content |
|
|
{ |
|
|
{ |
|
@ -252,33 +249,36 @@ void MainMenu::showStatus() |
|
|
#endif |
|
|
#endif |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
int tHotEnd0=intround(degHotend0()); |
|
|
if((abs(current_raw[TEMPSENSOR_HOTEND_0]-oldcurrentraw)>3)||force_lcd_update) |
|
|
if((abs(tHotEnd0-olddegHotEnd0)>1)||force_lcd_update) //>1 because otherwise the lcd is refreshed to often. |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(1,0); |
|
|
lcd.setCursor(1,0); |
|
|
lcd.print(ftostr3(analog2temp(current_raw[TEMPSENSOR_HOTEND_0]))); |
|
|
lcd.print(ftostr3(tHotEnd0)); |
|
|
oldcurrentraw=current_raw[TEMPSENSOR_HOTEND_0]; |
|
|
olddegHotEnd0=tHotEnd0; |
|
|
} |
|
|
} |
|
|
if((target_raw[TEMPSENSOR_HOTEND_0]!=oldtargetraw)||force_lcd_update) |
|
|
int ttHotEnd0=intround(degTargetHotend0()); |
|
|
|
|
|
if((ttHotEnd0!=oldtargetHotEnd0)||force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(5,0); |
|
|
lcd.setCursor(5,0); |
|
|
lcd.print(ftostr3(analog2temp(target_raw[TEMPSENSOR_HOTEND_0]))); |
|
|
lcd.print(ftostr3(ttHotEnd0)); |
|
|
oldtargetraw=target_raw[TEMPSENSOR_HOTEND_0]; |
|
|
oldtargetHotEnd0=ttHotEnd0; |
|
|
} |
|
|
} |
|
|
#if defined BED_USES_THERMISTOR || defined BED_USES_AD595 |
|
|
#if defined BED_USES_THERMISTOR || defined BED_USES_AD595 |
|
|
static int oldcurrentbedraw=-1; |
|
|
static int oldtBed=-1; |
|
|
static int oldtargetbedraw=-1; |
|
|
static int oldtargetBed=-1; |
|
|
if((current_bed_raw!=oldcurrentbedraw)||force_lcd_update) |
|
|
int tBed=intround(degBed()); |
|
|
|
|
|
if((tBed!=oldtBed)||force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(1,0); |
|
|
lcd.setCursor(1,0); |
|
|
lcd.print(ftostr3(analog2temp(current_bed_raw))); |
|
|
lcd.print(ftostr3(tBed)); |
|
|
oldcurrentraw=current_raw[TEMPSENSOR_BED]; |
|
|
olddegHotEnd0=tBed; |
|
|
} |
|
|
} |
|
|
if((target_bed_raw!=oldtargebedtraw)||force_lcd_update) |
|
|
int targetBed=intround(degTargetBed()); |
|
|
|
|
|
if((targetBed!=oldtargetBed)||force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(5,0); |
|
|
lcd.setCursor(5,0); |
|
|
lcd.print(ftostr3(analog2temp(target_bed_raw))); |
|
|
lcd.print(ftostr3(targetBed)); |
|
|
oldtargetraw=target_bed_raw; |
|
|
oldtargetBed=targetBed; |
|
|
} |
|
|
} |
|
|
#endif |
|
|
#endif |
|
|
//starttime=2; |
|
|
//starttime=2; |
|
@ -327,8 +327,8 @@ void MainMenu::showStatus() |
|
|
messagetext[0]='\0'; |
|
|
messagetext[0]='\0'; |
|
|
} |
|
|
} |
|
|
#else //smaller LCDS---------------------------------- |
|
|
#else //smaller LCDS---------------------------------- |
|
|
static int oldcurrentraw=-1; |
|
|
static int olddegHotEnd0=-1; |
|
|
static int oldtargetraw=-1; |
|
|
static int oldtargetHotEnd0=-1; |
|
|
if(force_lcd_update) //initial display of content |
|
|
if(force_lcd_update) //initial display of content |
|
|
{ |
|
|
{ |
|
|
encoderpos=feedmultiply; |
|
|
encoderpos=feedmultiply; |
|
@ -338,18 +338,21 @@ void MainMenu::showStatus() |
|
|
#endif |
|
|
#endif |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
int tHotEnd0=intround(degHotend0()); |
|
|
|
|
|
int ttHotEnd0=intround(degTargetHotend0()); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if((abs(current_raw[TEMPSENSOR_HOTEND]-oldcurrentraw)>3)||force_lcd_update) |
|
|
if((abs(tHotEnd0-olddegHotEnd0)>1)||force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(1,0); |
|
|
lcd.setCursor(1,0); |
|
|
lcd.print(ftostr3(analog2temp(current_raw[TEMPSENSOR_HOTEND]))); |
|
|
lcd.print(ftostr3(tHotEnd0)); |
|
|
oldcurrentraw=current_raw[TEMPSENSOR_HOTEND]; |
|
|
olddegHotEnd0=tHotEnd0; |
|
|
} |
|
|
} |
|
|
if((target_raw[TEMPSENSOR_HOTEND]!=oldtargetraw)||force_lcd_update) |
|
|
if((ttHotEnd0!=oldtargetHotEnd0)||force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(5,0); |
|
|
lcd.setCursor(5,0); |
|
|
lcd.print(ftostr3(analog2temp(target_raw[TEMPSENSOR_HOTEND]))); |
|
|
lcd.print(ftostr3(ttHotEnd0)); |
|
|
oldtargetraw=target_raw[TEMPSENSOR_HOTEND]; |
|
|
oldtargetHotEnd0=ttHotEnd0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if(messagetext[0]!='\0') |
|
|
if(messagetext[0]!='\0') |
|
@ -426,7 +429,7 @@ void MainMenu::showPrepare() |
|
|
if((activeline==line) && CLICKED) |
|
|
if((activeline==line) && CLICKED) |
|
|
{ |
|
|
{ |
|
|
BLOCK |
|
|
BLOCK |
|
|
target_raw[TEMPSENSOR_HOTEND_0] = temp2analog(170); |
|
|
setTargetHotend0(170); |
|
|
beepshort(); |
|
|
beepshort(); |
|
|
} |
|
|
} |
|
|
}break; |
|
|
}break; |
|
@ -531,7 +534,7 @@ void MainMenu::showControl() |
|
|
if(force_lcd_update) |
|
|
if(force_lcd_update) |
|
|
{ |
|
|
{ |
|
|
lcd.setCursor(0,line);lcd.print(" \002Nozzle:"); |
|
|
lcd.setCursor(0,line);lcd.print(" \002Nozzle:"); |
|
|
lcd.setCursor(13,line);lcd.print(ftostr3(analog2temp(target_raw[TEMPSENSOR_HOTEND_0]))); |
|
|
lcd.setCursor(13,line);lcd.print(ftostr3(intround(degHotend0()))); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if((activeline==line) ) |
|
|
if((activeline==line) ) |
|
@ -541,11 +544,11 @@ void MainMenu::showControl() |
|
|
linechanging=!linechanging; |
|
|
linechanging=!linechanging; |
|
|
if(linechanging) |
|
|
if(linechanging) |
|
|
{ |
|
|
{ |
|
|
encoderpos=(int)analog2temp(target_raw[TEMPSENSOR_HOTEND_0]); |
|
|
encoderpos=intround(degHotend0()); |
|
|
} |
|
|
} |
|
|
else |
|
|
else |
|
|
{ |
|
|
{ |
|
|
target_raw[TEMPSENSOR_HOTEND_0] = temp2analog(encoderpos); |
|
|
setTargetHotend0(encoderpos); |
|
|
encoderpos=activeline*lcdslow; |
|
|
encoderpos=activeline*lcdslow; |
|
|
beepshort(); |
|
|
beepshort(); |
|
|
} |
|
|
} |
|
@ -1591,3 +1594,4 @@ char *fillto(int8_t n,char *c) |
|
|
inline void lcd_status() {}; |
|
|
inline void lcd_status() {}; |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|