servo: Use new GCodeCommand wrappers
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
53093a7a15
commit
a11535fc86
|
@ -26,8 +26,8 @@ class PrinterServo:
|
||||||
self.enable = config.getboolean('enable', True)
|
self.enable = config.getboolean('enable', True)
|
||||||
self.last_enable = not self.enable
|
self.last_enable = not self.enable
|
||||||
servo_name = config.get_name().split()[1]
|
servo_name = config.get_name().split()[1]
|
||||||
self.gcode = self.printer.lookup_object('gcode')
|
gcode = self.printer.lookup_object('gcode')
|
||||||
self.gcode.register_mux_command("SET_SERVO", "SERVO", servo_name,
|
gcode.register_mux_command("SET_SERVO", "SERVO", servo_name,
|
||||||
self.cmd_SET_SERVO,
|
self.cmd_SET_SERVO,
|
||||||
desc=self.cmd_SET_SERVO_help)
|
desc=self.cmd_SET_SERVO_help)
|
||||||
# Check to see if an initial angle or pulse width is
|
# Check to see if an initial angle or pulse width is
|
||||||
|
@ -71,18 +71,17 @@ class PrinterServo:
|
||||||
width = max(self.min_width, min(self.max_width, width))
|
width = max(self.min_width, min(self.max_width, width))
|
||||||
return width * self.width_to_value
|
return width * self.width_to_value
|
||||||
cmd_SET_SERVO_help = "Set servo angle"
|
cmd_SET_SERVO_help = "Set servo angle"
|
||||||
def cmd_SET_SERVO(self, params):
|
def cmd_SET_SERVO(self, gcmd):
|
||||||
print_time = self.printer.lookup_object('toolhead').get_last_move_time()
|
print_time = self.printer.lookup_object('toolhead').get_last_move_time()
|
||||||
if 'ENABLE' in params:
|
enable = gcmd.get_int('ENABLE', None)
|
||||||
value = self.gcode.get_int('ENABLE', params)
|
width = gcmd.get_float('WIDTH', None)
|
||||||
self.enable = value != 0
|
angle = gcmd.get_float('ANGLE', None)
|
||||||
if 'WIDTH' in params:
|
if enable is not None:
|
||||||
self._set_pwm(print_time, self._get_pwm_from_pulse_width(
|
self.enable = enable != 0
|
||||||
self.gcode.get_float('WIDTH', params)))
|
if width is not None:
|
||||||
else:
|
self._set_pwm(print_time, self._get_pwm_from_pulse_width(width))
|
||||||
if 'ANGLE' in params:
|
elif angle is not None:
|
||||||
self._set_pwm(print_time, self._get_pwm_from_angle(
|
self._set_pwm(print_time, self._get_pwm_from_angle(angle))
|
||||||
self.gcode.get_float('ANGLE', params)))
|
|
||||||
else:
|
else:
|
||||||
self._set_pwm(print_time, self.last_value)
|
self._set_pwm(print_time, self.last_value)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue