heaters: Add a TEMPERATURE_WAIT command
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
d339839a91
commit
e83801daab
|
@ -156,6 +156,8 @@ The following standard commands are supported:
|
||||||
/tmp/heattest.txt will be created with a log of all temperature
|
/tmp/heattest.txt will be created with a log of all temperature
|
||||||
samples taken during the test.
|
samples taken during the test.
|
||||||
- `TURN_OFF_HEATERS`: Turn off all heaters.
|
- `TURN_OFF_HEATERS`: Turn off all heaters.
|
||||||
|
- `TEMPERATURE_WAIT SENSOR=<config_name> MINIMUM=<target>`: Wait until
|
||||||
|
the given temperature sensor is at or above the given target value.
|
||||||
- `SET_VELOCITY_LIMIT [VELOCITY=<value>] [ACCEL=<value>]
|
- `SET_VELOCITY_LIMIT [VELOCITY=<value>] [ACCEL=<value>]
|
||||||
[ACCEL_TO_DECEL=<value>] [SQUARE_CORNER_VELOCITY=<value>]`: Modify
|
[ACCEL_TO_DECEL=<value>] [SQUARE_CORNER_VELOCITY=<value>]`: Modify
|
||||||
the printer's velocity limits. Note that one may only set values
|
the printer's velocity limits. Note that one may only set values
|
||||||
|
|
|
@ -241,6 +241,8 @@ class PrinterHeaters:
|
||||||
gcode.register_command("TURN_OFF_HEATERS", self.cmd_TURN_OFF_HEATERS,
|
gcode.register_command("TURN_OFF_HEATERS", self.cmd_TURN_OFF_HEATERS,
|
||||||
desc=self.cmd_TURN_OFF_HEATERS_help)
|
desc=self.cmd_TURN_OFF_HEATERS_help)
|
||||||
gcode.register_command("M105", self.cmd_M105, when_not_ready=True)
|
gcode.register_command("M105", self.cmd_M105, when_not_ready=True)
|
||||||
|
gcode.register_command("TEMPERATURE_WAIT", self.cmd_TEMPERATURE_WAIT,
|
||||||
|
desc=self.cmd_TEMPERATURE_WAIT_help)
|
||||||
def add_sensor_factory(self, sensor_type, sensor_factory):
|
def add_sensor_factory(self, sensor_type, sensor_factory):
|
||||||
self.sensor_factories[sensor_type] = sensor_factory
|
self.sensor_factories[sensor_type] = sensor_factory
|
||||||
def setup_heater(self, config, gcode_id=None):
|
def setup_heater(self, config, gcode_id=None):
|
||||||
|
@ -282,8 +284,8 @@ class PrinterHeaters:
|
||||||
"G-Code sensor id %s already registered" % (gcode_id,))
|
"G-Code sensor id %s already registered" % (gcode_id,))
|
||||||
self.gcode_id_to_sensor[gcode_id] = psensor
|
self.gcode_id_to_sensor[gcode_id] = psensor
|
||||||
def get_status(self, eventtime):
|
def get_status(self, eventtime):
|
||||||
return {'available_heaters': self.available_heaters,
|
return {'available_heaters': list(self.available_heaters),
|
||||||
'available_sensors': self.available_sensors}
|
'available_sensors': list(self.available_sensors)}
|
||||||
def turn_off_all_heaters(self, print_time=0.):
|
def turn_off_all_heaters(self, print_time=0.):
|
||||||
for heater in self.heaters.values():
|
for heater in self.heaters.values():
|
||||||
heater.set_temp(0.)
|
heater.set_temp(0.)
|
||||||
|
@ -322,6 +324,25 @@ class PrinterHeaters:
|
||||||
print_time = toolhead.get_last_move_time()
|
print_time = toolhead.get_last_move_time()
|
||||||
gcode.respond_raw(self._get_temp(eventtime))
|
gcode.respond_raw(self._get_temp(eventtime))
|
||||||
eventtime = reactor.pause(eventtime + 1.)
|
eventtime = reactor.pause(eventtime + 1.)
|
||||||
|
cmd_TEMPERATURE_WAIT_help = "Wait for a temperature on a sensor"
|
||||||
|
def cmd_TEMPERATURE_WAIT(self, gcmd):
|
||||||
|
sensor_name = gcmd.get('SENSOR')
|
||||||
|
if sensor_name not in self.available_sensors:
|
||||||
|
raise gcmd.error("Unknown sensor '%s'" % (sensor_name,))
|
||||||
|
min_temp = gcmd.get_float('MINIMUM')
|
||||||
|
if self.printer.get_start_args().get('debugoutput') is not None:
|
||||||
|
return
|
||||||
|
sensor = self.printer.lookup_object(sensor_name)
|
||||||
|
toolhead = self.printer.lookup_object("toolhead")
|
||||||
|
reactor = self.printer.get_reactor()
|
||||||
|
eventtime = reactor.monotonic()
|
||||||
|
while not self.printer.is_shutdown():
|
||||||
|
temp, target = sensor.get_temp(eventtime)
|
||||||
|
if temp >= min_temp:
|
||||||
|
return
|
||||||
|
print_time = toolhead.get_last_move_time()
|
||||||
|
gcmd.respond_raw(self._get_temp(eventtime))
|
||||||
|
eventtime = reactor.pause(eventtime + 1.)
|
||||||
|
|
||||||
def load_config(config):
|
def load_config(config):
|
||||||
return PrinterHeaters(config)
|
return PrinterHeaters(config)
|
||||||
|
|
Loading…
Reference in New Issue