fan: Move M106/M107 commands from gcode.py to fan.py
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
0a39c339c7
commit
e0e2f15498
|
@ -10,15 +10,15 @@ class PrinterFan:
|
||||||
def __init__(self, config, default_shutdown_speed=0.):
|
def __init__(self, config, default_shutdown_speed=0.):
|
||||||
self.last_fan_value = 0.
|
self.last_fan_value = 0.
|
||||||
self.last_fan_time = 0.
|
self.last_fan_time = 0.
|
||||||
printer = config.get_printer()
|
self.printer = config.get_printer()
|
||||||
printer.register_event_handler("gcode:request_restart",
|
self.printer.register_event_handler("gcode:request_restart",
|
||||||
self.handle_request_restart)
|
self.handle_request_restart)
|
||||||
self.max_power = config.getfloat('max_power', 1., above=0., maxval=1.)
|
self.max_power = config.getfloat('max_power', 1., above=0., maxval=1.)
|
||||||
self.kick_start_time = config.getfloat('kick_start_time', 0.1,
|
self.kick_start_time = config.getfloat('kick_start_time', 0.1,
|
||||||
minval=0.)
|
minval=0.)
|
||||||
self.off_below = config.getfloat(
|
self.off_below = config.getfloat(
|
||||||
'off_below', default=0., minval=0., maxval=1.)
|
'off_below', default=0., minval=0., maxval=1.)
|
||||||
ppins = printer.lookup_object('pins')
|
ppins = self.printer.lookup_object('pins')
|
||||||
self.mcu_fan = ppins.setup_pin('pwm', config.get('pin'))
|
self.mcu_fan = ppins.setup_pin('pwm', config.get('pin'))
|
||||||
self.mcu_fan.setup_max_duration(0.)
|
self.mcu_fan.setup_max_duration(0.)
|
||||||
cycle_time = config.getfloat('cycle_time', 0.010, above=0.)
|
cycle_time = config.getfloat('cycle_time', 0.010, above=0.)
|
||||||
|
@ -28,6 +28,11 @@ class PrinterFan:
|
||||||
'shutdown_speed', default_shutdown_speed, minval=0., maxval=1.)
|
'shutdown_speed', default_shutdown_speed, minval=0., maxval=1.)
|
||||||
self.mcu_fan.setup_start_value(
|
self.mcu_fan.setup_start_value(
|
||||||
0., max(0., min(self.max_power, shutdown_speed)))
|
0., max(0., min(self.max_power, shutdown_speed)))
|
||||||
|
# Register commands
|
||||||
|
if config.get_name() == 'fan':
|
||||||
|
gcode = self.printer.lookup_object('gcode')
|
||||||
|
gcode.register_command("M106", self.cmd_M106)
|
||||||
|
gcode.register_command("M107", self.cmd_M107)
|
||||||
def handle_request_restart(self, print_time):
|
def handle_request_restart(self, print_time):
|
||||||
self.set_speed(print_time, 0.)
|
self.set_speed(print_time, 0.)
|
||||||
def set_speed(self, print_time, value):
|
def set_speed(self, print_time, value):
|
||||||
|
@ -47,6 +52,16 @@ class PrinterFan:
|
||||||
self.last_fan_value = value
|
self.last_fan_value = value
|
||||||
def get_status(self, eventtime):
|
def get_status(self, eventtime):
|
||||||
return {'speed': self.last_fan_value}
|
return {'speed': self.last_fan_value}
|
||||||
|
def cmd_M106(self, params):
|
||||||
|
# Set fan speed
|
||||||
|
print_time = self.printer.lookup_object('toolhead').get_last_move_time()
|
||||||
|
gcode = self.printer.lookup_object('gcode')
|
||||||
|
value = gcode.get_float('S', params, 255., minval=0.) / 255.
|
||||||
|
self.set_speed(print_time, value)
|
||||||
|
def cmd_M107(self, params):
|
||||||
|
# Turn fan off
|
||||||
|
print_time = self.printer.lookup_object('toolhead').get_last_move_time()
|
||||||
|
self.set_speed(print_time, 0.)
|
||||||
|
|
||||||
def load_config(config):
|
def load_config(config):
|
||||||
return PrinterFan(config)
|
return PrinterFan(config)
|
||||||
|
|
|
@ -56,7 +56,7 @@ class GCodeParser:
|
||||||
self.move_transform = self.move_with_transform = None
|
self.move_transform = self.move_with_transform = None
|
||||||
self.position_with_transform = (lambda: [0., 0., 0., 0.])
|
self.position_with_transform = (lambda: [0., 0., 0., 0.])
|
||||||
self.need_ack = False
|
self.need_ack = False
|
||||||
self.toolhead = self.fan = None
|
self.toolhead = None
|
||||||
self.heaters = None
|
self.heaters = None
|
||||||
self.axis2pos = {'X': 0, 'Y': 1, 'Z': 2, 'E': 3}
|
self.axis2pos = {'X': 0, 'Y': 1, 'Z': 2, 'E': 3}
|
||||||
def register_command(self, cmd, func, when_not_ready=False, desc=None):
|
def register_command(self, cmd, func, when_not_ready=False, desc=None):
|
||||||
|
@ -171,7 +171,6 @@ class GCodeParser:
|
||||||
if self.move_transform is None:
|
if self.move_transform is None:
|
||||||
self.move_with_transform = self.toolhead.move
|
self.move_with_transform = self.toolhead.move
|
||||||
self.position_with_transform = self.toolhead.get_position
|
self.position_with_transform = self.toolhead.get_position
|
||||||
self.fan = self.printer.lookup_object('fan', None)
|
|
||||||
if self.is_fileinput and self.fd_handle is None:
|
if self.is_fileinput and self.fd_handle is None:
|
||||||
self.fd_handle = self.reactor.register_fd(self.fd,
|
self.fd_handle = self.reactor.register_fd(self.fd,
|
||||||
self._process_data)
|
self._process_data)
|
||||||
|
@ -419,13 +418,6 @@ class GCodeParser:
|
||||||
raise self.error(str(e))
|
raise self.error(str(e))
|
||||||
if wait and temp:
|
if wait and temp:
|
||||||
self.bg_temp(heater)
|
self.bg_temp(heater)
|
||||||
def _set_fan_speed(self, speed):
|
|
||||||
if self.fan is None:
|
|
||||||
if speed and not self.is_fileinput:
|
|
||||||
self.respond_info("Fan not configured")
|
|
||||||
return
|
|
||||||
print_time = self.toolhead.get_last_move_time()
|
|
||||||
self.fan.set_speed(print_time, speed)
|
|
||||||
# G-Code special command handlers
|
# G-Code special command handlers
|
||||||
def cmd_default(self, params):
|
def cmd_default(self, params):
|
||||||
if not self.is_printer_ready:
|
if not self.is_printer_ready:
|
||||||
|
@ -445,6 +437,10 @@ class GCodeParser:
|
||||||
if handler is not None:
|
if handler is not None:
|
||||||
handler(params)
|
handler(params)
|
||||||
return
|
return
|
||||||
|
elif cmd == 'M107' or (cmd == 'M106' and (
|
||||||
|
not self.get_float('S', params, 1.) or self.is_fileinput)):
|
||||||
|
# Don't warn about requests to turn off fan when fan not present
|
||||||
|
return
|
||||||
self.respond_info('Unknown command:"%s"' % (cmd,))
|
self.respond_info('Unknown command:"%s"' % (cmd,))
|
||||||
def cmd_Tn(self, params):
|
def cmd_Tn(self, params):
|
||||||
# Select Tool
|
# Select Tool
|
||||||
|
@ -481,7 +477,7 @@ class GCodeParser:
|
||||||
'G1', 'G4', 'G28', 'M400',
|
'G1', 'G4', 'G28', 'M400',
|
||||||
'G20', 'M82', 'M83', 'G90', 'G91', 'G92', 'M114', 'M220', 'M221',
|
'G20', 'M82', 'M83', 'G90', 'G91', 'G92', 'M114', 'M220', 'M221',
|
||||||
'SET_GCODE_OFFSET', 'M206', 'SAVE_GCODE_STATE', 'RESTORE_GCODE_STATE',
|
'SET_GCODE_OFFSET', 'M206', 'SAVE_GCODE_STATE', 'RESTORE_GCODE_STATE',
|
||||||
'M105', 'M104', 'M109', 'M140', 'M190', 'M106', 'M107',
|
'M105', 'M104', 'M109', 'M140', 'M190',
|
||||||
'M112', 'M115', 'IGNORE', 'GET_POSITION',
|
'M112', 'M115', 'IGNORE', 'GET_POSITION',
|
||||||
'RESTART', 'FIRMWARE_RESTART', 'ECHO', 'STATUS', 'HELP']
|
'RESTART', 'FIRMWARE_RESTART', 'ECHO', 'STATUS', 'HELP']
|
||||||
# G-Code movement commands
|
# G-Code movement commands
|
||||||
|
@ -648,7 +644,7 @@ class GCodeParser:
|
||||||
speed = self.get_float('MOVE_SPEED', params, self.speed, above=0.)
|
speed = self.get_float('MOVE_SPEED', params, self.speed, above=0.)
|
||||||
self.last_position[:3] = state['last_position'][:3]
|
self.last_position[:3] = state['last_position'][:3]
|
||||||
self.move_with_transform(self.last_position, speed)
|
self.move_with_transform(self.last_position, speed)
|
||||||
# G-Code temperature and fan commands
|
# G-Code temperature commands
|
||||||
cmd_M105_when_not_ready = True
|
cmd_M105_when_not_ready = True
|
||||||
def cmd_M105(self, params):
|
def cmd_M105(self, params):
|
||||||
# Get Extruder Temperature
|
# Get Extruder Temperature
|
||||||
|
@ -669,12 +665,6 @@ class GCodeParser:
|
||||||
def cmd_M190(self, params):
|
def cmd_M190(self, params):
|
||||||
# Set Bed Temperature and Wait
|
# Set Bed Temperature and Wait
|
||||||
self._set_temp(params, is_bed=True, wait=True)
|
self._set_temp(params, is_bed=True, wait=True)
|
||||||
def cmd_M106(self, params):
|
|
||||||
# Set fan speed
|
|
||||||
self._set_fan_speed(self.get_float('S', params, 255., minval=0.) / 255.)
|
|
||||||
def cmd_M107(self, params):
|
|
||||||
# Turn fan off
|
|
||||||
self._set_fan_speed(0.)
|
|
||||||
# G-Code miscellaneous commands
|
# G-Code miscellaneous commands
|
||||||
cmd_M112_when_not_ready = True
|
cmd_M112_when_not_ready = True
|
||||||
def cmd_M112(self, params):
|
def cmd_M112(self, params):
|
||||||
|
|
Loading…
Reference in New Issue