|
@ -157,11 +157,13 @@ 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 |
|
|
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 |
|
|
uint8_t active_extruder = 0; |
|
|
uint8_t active_extruder = 0; |
|
|
int fanSpeed=0; |
|
|
int fanSpeed=0; |
|
|
|
|
|
|
|
@ -1378,7 +1380,8 @@ void process_commands() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
}break; |
|
|
}break; |
|
|
#endif // FWRETRACT
|
|
|
#endif // FWRETRACT
|
|
|
|
|
|
#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>
|
|
|
{ |
|
|
{ |
|
|
if(setTargetedHotend(218)){ |
|
|
if(setTargetedHotend(218)){ |
|
@ -1402,7 +1405,8 @@ 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 |
|
|
case 220: // M220 S<factor in percent>- set speed factor override percentage
|
|
|
case 220: // M220 S<factor in percent>- set speed factor override percentage
|
|
|
{ |
|
|
{ |
|
|
if(code_seen('S')) |
|
|
if(code_seen('S')) |
|
@ -1734,6 +1738,7 @@ void process_commands() |
|
|
feedrate = next_feedrate; |
|
|
feedrate = next_feedrate; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
#if EXTRUDERS > 1 |
|
|
if(tmp_extruder != active_extruder) { |
|
|
if(tmp_extruder != active_extruder) { |
|
|
// Save current position to return to after applying extruder offset
|
|
|
// Save current position to return to after applying extruder offset
|
|
|
memcpy(destination, current_position, sizeof(destination)); |
|
|
memcpy(destination, current_position, sizeof(destination)); |
|
@ -1751,7 +1756,8 @@ void process_commands() |
|
|
if(make_move && Stopped == false) { |
|
|
if(make_move && Stopped == false) { |
|
|
prepare_move(); |
|
|
prepare_move(); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
#endif |
|
|
SERIAL_ECHO_START; |
|
|
SERIAL_ECHO_START; |
|
|
SERIAL_ECHO(MSG_ACTIVE_EXTRUDER); |
|
|
SERIAL_ECHO(MSG_ACTIVE_EXTRUDER); |
|
|
SERIAL_PROTOCOLLN((int)active_extruder); |
|
|
SERIAL_PROTOCOLLN((int)active_extruder); |
|
|