servo: Use new GCodeCommand wrappers

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-04-25 00:15:47 -04:00
parent 53093a7a15
commit a11535fc86
1 changed files with 15 additions and 16 deletions

View File

@ -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)