gcode: Store internal speed in mm/s
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
b8a4cf7701
commit
7792b0f2bb
|
@ -1,6 +1,6 @@
|
||||||
# Parse gcode commands
|
# Parse gcode commands
|
||||||
#
|
#
|
||||||
# Copyright (C) 2016-2018 Kevin O'Connor <kevin@koconnor.net>
|
# Copyright (C) 2016-2019 Kevin O'Connor <kevin@koconnor.net>
|
||||||
#
|
#
|
||||||
# This file may be distributed under the terms of the GNU GPLv3 license.
|
# This file may be distributed under the terms of the GNU GPLv3 license.
|
||||||
import os, re, logging, collections, shlex
|
import os, re, logging, collections, shlex
|
||||||
|
@ -50,6 +50,7 @@ class GCodeParser:
|
||||||
self.base_position = [0.0, 0.0, 0.0, 0.0]
|
self.base_position = [0.0, 0.0, 0.0, 0.0]
|
||||||
self.last_position = [0.0, 0.0, 0.0, 0.0]
|
self.last_position = [0.0, 0.0, 0.0, 0.0]
|
||||||
self.homing_position = [0.0, 0.0, 0.0, 0.0]
|
self.homing_position = [0.0, 0.0, 0.0, 0.0]
|
||||||
|
self.speed = 25.
|
||||||
self.speed_factor = 1. / 60.
|
self.speed_factor = 1. / 60.
|
||||||
self.extrude_factor = 1.
|
self.extrude_factor = 1.
|
||||||
self.move_transform = self.move_with_transform = None
|
self.move_transform = self.move_with_transform = None
|
||||||
|
@ -58,7 +59,6 @@ class GCodeParser:
|
||||||
self.need_ack = False
|
self.need_ack = False
|
||||||
self.toolhead = self.fan = self.extruder = None
|
self.toolhead = self.fan = self.extruder = None
|
||||||
self.heaters = None
|
self.heaters = None
|
||||||
self.speed = 25. * 60.
|
|
||||||
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):
|
||||||
if func is None:
|
if func is None:
|
||||||
|
@ -102,16 +102,20 @@ class GCodeParser:
|
||||||
self.position_with_transform = transform.get_position
|
self.position_with_transform = transform.get_position
|
||||||
def stats(self, eventtime):
|
def stats(self, eventtime):
|
||||||
return False, "gcodein=%d" % (self.bytes_read,)
|
return False, "gcodein=%d" % (self.bytes_read,)
|
||||||
def _get_current_position(self):
|
def _get_gcode_position(self):
|
||||||
p = [lp - bp for lp, bp in zip(self.last_position, self.base_position)]
|
p = [lp - bp for lp, bp in zip(self.last_position, self.base_position)]
|
||||||
p[3] /= self.extrude_factor
|
p[3] /= self.extrude_factor
|
||||||
return p
|
return p
|
||||||
|
def _get_gcode_speed(self):
|
||||||
|
return self.speed / self.speed_factor
|
||||||
|
def _get_gcode_speed_override(self):
|
||||||
|
return self.speed_factor * 60.
|
||||||
def get_status(self, eventtime):
|
def get_status(self, eventtime):
|
||||||
move_position = self._get_current_position()
|
move_position = self._get_gcode_position()
|
||||||
busy = self.is_processing_data
|
busy = self.is_processing_data
|
||||||
return {
|
return {
|
||||||
'speed_factor': self.speed_factor * 60.,
|
'speed_factor': self._get_gcode_speed_override(),
|
||||||
'speed': self.speed,
|
'speed': self._get_gcode_speed(),
|
||||||
'extrude_factor': self.extrude_factor,
|
'extrude_factor': self.extrude_factor,
|
||||||
'abs_extrude': self.absoluteextrude,
|
'abs_extrude': self.absoluteextrude,
|
||||||
'busy': busy,
|
'busy': busy,
|
||||||
|
@ -509,16 +513,15 @@ class GCodeParser:
|
||||||
# value relative to base coordinate position
|
# value relative to base coordinate position
|
||||||
self.last_position[3] = v + self.base_position[3]
|
self.last_position[3] = v + self.base_position[3]
|
||||||
if 'F' in params:
|
if 'F' in params:
|
||||||
speed = float(params['F'])
|
gcode_speed = float(params['F'])
|
||||||
if speed <= 0.:
|
if gcode_speed <= 0.:
|
||||||
raise error("Invalid speed in '%s'" % (
|
raise error("Invalid speed in '%s'" % (
|
||||||
params['#original'],))
|
params['#original'],))
|
||||||
self.speed = speed
|
self.speed = gcode_speed * self.speed_factor
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
raise error("Unable to parse move '%s'" % (params['#original'],))
|
raise error("Unable to parse move '%s'" % (params['#original'],))
|
||||||
try:
|
try:
|
||||||
self.move_with_transform(self.last_position,
|
self.move_with_transform(self.last_position, self.speed)
|
||||||
self.speed * self.speed_factor)
|
|
||||||
except homing.EndstopError as e:
|
except homing.EndstopError as e:
|
||||||
raise error(str(e))
|
raise error(str(e))
|
||||||
def cmd_G4(self, params):
|
def cmd_G4(self, params):
|
||||||
|
@ -582,11 +585,12 @@ class GCodeParser:
|
||||||
cmd_M114_when_not_ready = True
|
cmd_M114_when_not_ready = True
|
||||||
def cmd_M114(self, params):
|
def cmd_M114(self, params):
|
||||||
# Get Current Position
|
# Get Current Position
|
||||||
p = self._get_current_position()
|
p = self._get_gcode_position()
|
||||||
self.respond("X:%.3f Y:%.3f Z:%.3f E:%.3f" % tuple(p))
|
self.respond("X:%.3f Y:%.3f Z:%.3f E:%.3f" % tuple(p))
|
||||||
def cmd_M220(self, params):
|
def cmd_M220(self, params):
|
||||||
# Set speed factor override percentage
|
# Set speed factor override percentage
|
||||||
value = self.get_float('S', params, 100., above=0.) / (60. * 100.)
|
value = self.get_float('S', params, 100., above=0.) / (60. * 100.)
|
||||||
|
self.speed = self._get_gcode_speed() * value
|
||||||
self.speed_factor = value
|
self.speed_factor = value
|
||||||
def cmd_M221(self, params):
|
def cmd_M221(self, params):
|
||||||
# Set extrude factor override percentage
|
# Set extrude factor override percentage
|
||||||
|
|
Loading…
Reference in New Issue