|
|
@ -157,12 +157,12 @@ float add_homeing[3]={0,0,0};
|
|
|
|
float min_pos[3] = { X_MIN_POS, Y_MIN_POS, Z_MIN_POS };
|
|
|
|
float min_pos[3] = { X_MIN_POS, Y_MIN_POS, Z_MIN_POS };
|
|
|
|
float max_pos[3] = { X_MAX_POS, Y_MAX_POS, Z_MAX_POS };
|
|
|
|
float max_pos[3] = { X_MAX_POS, Y_MAX_POS, Z_MAX_POS };
|
|
|
|
// Extruder offset, only in XY plane
|
|
|
|
// Extruder offset, only in XY plane
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
float extruder_offset[2][EXTRUDERS] = {
|
|
|
|
float extruder_offset[2][EXTRUDERS] = {
|
|
|
|
#if defined(EXTRUDER_OFFSET_X) && defined(EXTRUDER_OFFSET_Y)
|
|
|
|
#if defined(EXTRUDER_OFFSET_X) && defined(EXTRUDER_OFFSET_Y)
|
|
|
|
EXTRUDER_OFFSET_X, EXTRUDER_OFFSET_Y
|
|
|
|
EXTRUDER_OFFSET_X, EXTRUDER_OFFSET_Y
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
uint8_t active_extruder = 0;
|
|
|
|
uint8_t active_extruder = 0;
|
|
|
|
int fanSpeed=0;
|
|
|
|
int fanSpeed=0;
|
|
|
@ -376,6 +376,14 @@ void setup()
|
|
|
|
setup_photpin();
|
|
|
|
setup_photpin();
|
|
|
|
|
|
|
|
|
|
|
|
lcd_init();
|
|
|
|
lcd_init();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef CONTROLLERFAN_PIN
|
|
|
|
|
|
|
|
SET_OUTPUT(CONTROLLERFAN_PIN); //Set pin used for driver cooling fan
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef EXTRUDERFAN_PIN
|
|
|
|
|
|
|
|
SET_OUTPUT(EXTRUDERFAN_PIN); //Set pin used for extruder cooling fan
|
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -1380,7 +1388,7 @@ void process_commands()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}break;
|
|
|
|
}break;
|
|
|
|
#endif // FWRETRACT
|
|
|
|
#endif // FWRETRACT
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
case 218: // M218 - set hotend offset (in mm), T<extruder_number> X<offset_on_X> Y<offset_on_Y>
|
|
|
|
case 218: // M218 - set hotend offset (in mm), T<extruder_number> X<offset_on_X> Y<offset_on_Y>
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1405,7 +1413,7 @@ void process_commands()
|
|
|
|
SERIAL_ECHO(extruder_offset[Y_AXIS][tmp_extruder]);
|
|
|
|
SERIAL_ECHO(extruder_offset[Y_AXIS][tmp_extruder]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
SERIAL_ECHOLN("");
|
|
|
|
SERIAL_ECHOLN("");
|
|
|
|
}break;
|
|
|
|
}break;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
case 220: // M220 S<factor in percent>- set speed factor override percentage
|
|
|
|
case 220: // M220 S<factor in percent>- set speed factor override percentage
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1756,7 +1764,7 @@ void process_commands()
|
|
|
|
if(make_move && Stopped == false) {
|
|
|
|
if(make_move && Stopped == false) {
|
|
|
|
prepare_move();
|
|
|
|
prepare_move();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO(MSG_ACTIVE_EXTRUDER);
|
|
|
|
SERIAL_ECHO(MSG_ACTIVE_EXTRUDER);
|
|
|
@ -1953,6 +1961,27 @@ void controllerFan()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef EXTRUDERFAN_PIN
|
|
|
|
|
|
|
|
unsigned long lastExtruderCheck = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void extruderFan()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if ((millis() - lastExtruderCheck) >= 2500) //Not a time critical function, so we only check every 2500ms
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
lastExtruderCheck = millis();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (degHotend(active_extruder) < EXTRUDERFAN_DEC)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
WRITE(EXTRUDERFAN_PIN, LOW); //... turn the fan off
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
WRITE(EXTRUDERFAN_PIN, HIGH); //... turn the fan on
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
void manage_inactivity()
|
|
|
|
void manage_inactivity()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( (millis() - previous_millis_cmd) > max_inactive_time )
|
|
|
|
if( (millis() - previous_millis_cmd) > max_inactive_time )
|
|
|
|