Fixed extruder issue: the e-move was shorter than other axises
This commit is contained in:
parent
fcd6fe728c
commit
dc53111a71
1 changed files with 6 additions and 1 deletions
|
|
@ -872,7 +872,12 @@ void linear_move(unsigned long x_steps_remaining, unsigned long y_steps_remainin
|
|||
|
||||
if(e_steps_remaining){
|
||||
timediff=micros()-previous_micros_e;
|
||||
while(timediff >= e_interval && e_steps_remaining) { do_e_step(); e_steps_remaining--; timediff-=e_interval;}
|
||||
unsigned int final_e_steps_remaining = 0;
|
||||
if (steep_x && x_steps_to_take > 0) final_e_steps_remaining = e_steps_to_take * (x_steps_remaining) / ((float) x_steps_to_take);
|
||||
else if (steep_y && y_steps_to_take > 0) final_e_steps_remaining = e_steps_to_take * (y_steps_remaining) / ((float) y_steps_to_take);
|
||||
if (final_e_steps_remaining > 0) while(e_steps_remaining > final_e_steps_remaining) { do_e_step(); e_steps_remaining--; timediff-=e_interval;}
|
||||
else if (x_steps_to_take > 0 || y_steps_to_take > 0) while(e_steps_remaining) { do_e_step(); e_steps_remaining--; timediff-=e_interval;}
|
||||
else while (timediff >= e_interval && e_steps_remaining) { do_e_step(); e_steps_remaining--; timediff-=e_interval;}
|
||||
}
|
||||
if( (millis() - previous_millis_heater) >= 500 ) {
|
||||
manage_heater();
|
||||
|
|
|
|||
Loading…
Reference in a new issue