stepper: Restore mcu_position on set_stepper_kinematics() and set_step_dist()
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
1506043477
commit
0bc0767997
|
@ -84,8 +84,10 @@ class MCU_stepper:
|
|||
def get_step_dist(self):
|
||||
return self._step_dist
|
||||
def set_step_dist(self, dist):
|
||||
mcu_pos = self.get_mcu_position()
|
||||
self._step_dist = dist
|
||||
self.set_stepper_kinematics(self._stepper_kinematics)
|
||||
self._set_mcu_position(mcu_pos)
|
||||
def is_dir_inverted(self):
|
||||
return self._invert_dir
|
||||
def calc_position_from_coord(self, coord):
|
||||
|
@ -93,21 +95,23 @@ class MCU_stepper:
|
|||
return ffi_lib.itersolve_calc_position_from_coord(
|
||||
self._stepper_kinematics, coord[0], coord[1], coord[2])
|
||||
def set_position(self, coord):
|
||||
opos = self.get_commanded_position()
|
||||
mcu_pos = self.get_mcu_position()
|
||||
sk = self._stepper_kinematics
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
ffi_lib.itersolve_set_position(sk, coord[0], coord[1], coord[2])
|
||||
self._mcu_position_offset += opos - self.get_commanded_position()
|
||||
self._set_mcu_position(mcu_pos)
|
||||
def get_commanded_position(self):
|
||||
sk = self._stepper_kinematics
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
return ffi_lib.itersolve_get_commanded_pos(sk)
|
||||
return ffi_lib.itersolve_get_commanded_pos(self._stepper_kinematics)
|
||||
def get_mcu_position(self):
|
||||
mcu_pos_dist = self.get_commanded_position() + self._mcu_position_offset
|
||||
mcu_pos = mcu_pos_dist / self._step_dist
|
||||
if mcu_pos >= 0.:
|
||||
return int(mcu_pos + 0.5)
|
||||
return int(mcu_pos - 0.5)
|
||||
def _set_mcu_position(self, mcu_pos):
|
||||
mcu_pos_dist = mcu_pos * self._step_dist
|
||||
self._mcu_position_offset = mcu_pos_dist - self.get_commanded_position()
|
||||
def get_past_mcu_position(self, print_time):
|
||||
clock = self._mcu.print_time_to_clock(print_time)
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
|
@ -117,12 +121,14 @@ class MCU_stepper:
|
|||
return mcu_pos * self._step_dist - self._mcu_position_offset
|
||||
def set_stepper_kinematics(self, sk):
|
||||
old_sk = self._stepper_kinematics
|
||||
mcu_pos = 0
|
||||
if old_sk is not None:
|
||||
mcu_pos = self.get_mcu_position()
|
||||
self._stepper_kinematics = sk
|
||||
if sk is not None:
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
ffi_lib.itersolve_set_stepcompress(sk, self._stepqueue,
|
||||
self._step_dist)
|
||||
ffi_lib.itersolve_set_stepcompress(sk, self._stepqueue, self._step_dist)
|
||||
self.set_trapq(self._trapq)
|
||||
self._set_mcu_position(mcu_pos)
|
||||
return old_sk
|
||||
def note_homing_end(self, did_trigger=False):
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
|
@ -142,8 +148,7 @@ class MCU_stepper:
|
|||
ret = ffi_lib.stepcompress_set_last_position(self._stepqueue, last_pos)
|
||||
if ret:
|
||||
raise error("Internal error in stepcompress")
|
||||
mcu_pos_dist = last_pos * self._step_dist
|
||||
self._mcu_position_offset = mcu_pos_dist - self.get_commanded_position()
|
||||
self._set_mcu_position(last_pos)
|
||||
def set_trapq(self, tq):
|
||||
ffi_main, ffi_lib = chelper.get_ffi()
|
||||
if tq is None:
|
||||
|
@ -157,16 +162,16 @@ class MCU_stepper:
|
|||
def generate_steps(self, flush_time):
|
||||
# Check for activity if necessary
|
||||
if self._active_callbacks:
|
||||
ret = self._itersolve_check_active(self._stepper_kinematics,
|
||||
flush_time)
|
||||
sk = self._stepper_kinematics
|
||||
ret = self._itersolve_check_active(sk, flush_time)
|
||||
if ret:
|
||||
cbs = self._active_callbacks
|
||||
self._active_callbacks = []
|
||||
for cb in cbs:
|
||||
cb(ret)
|
||||
# Generate steps
|
||||
ret = self._itersolve_generate_steps(self._stepper_kinematics,
|
||||
flush_time)
|
||||
sk = self._stepper_kinematics
|
||||
ret = self._itersolve_generate_steps(sk, flush_time)
|
||||
if ret:
|
||||
raise error("Internal error in stepcompress")
|
||||
def is_active_axis(self, axis):
|
||||
|
|
Loading…
Reference in New Issue