menu: Show current positions based on gcode positions (#1389)

menu: Show current positions based on gcode positions

Added "move_[xyze]pos" properties to the "gcode" object for use in menus.
The new properties track the toolhead's position in gcode coordinates,
taking gcode and bed leveling offsets into account.
This position is equal to the value returned by M114 gcode.

Changes the move menus to show current position based on gcode
position. This allows gcode offsets and bed leveling offsets
to be taken into account, and prevents unexpected toolhead
movements when moving it using the menu.

Signed-off-by: Robert Konklewski <nythil@gmail.com>
This commit is contained in:
Robert Konklewski 2019-03-21 15:37:28 +01:00 committed by KevinOConnor
parent d76658756e
commit 6f91574cd9
2 changed files with 59 additions and 25 deletions

View File

@ -222,30 +222,36 @@ items:
[menu __control __move_10mm __axis_x] [menu __control __move_10mm __axis_x]
type: input type: input
name: "X:{0:05.1f} " name: "X:{0:05.1f} "
parameter: toolhead.xpos parameter: gcode.move_xpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 10.0 input_step: 10.0
gcode: G1 X{0:.1f} gcode:
G90
G1 X{0:.1f}
[menu __control __move_10mm __axis_y] [menu __control __move_10mm __axis_y]
type: input type: input
name: "Y:{0:05.1f} " name: "Y:{0:05.1f} "
parameter: toolhead.ypos parameter: gcode.move_ypos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 10.0 input_step: 10.0
gcode: G1 Y{0:.1f} gcode:
G90
G1 Y{0:.1f}
[menu __control __move_10mm __axis_z] [menu __control __move_10mm __axis_z]
type: input type: input
enable: !toolhead.is_printing enable: !toolhead.is_printing
name: "Move Z:{0:05.1f}" name: "Move Z:{0:05.1f}"
parameter: toolhead.zpos parameter: gcode.move_zpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 10.0 input_step: 10.0
gcode: G1 Z{0:.1f} gcode:
G90
G1 Z{0:.1f}
[menu __control __move_10mm __axis_e] [menu __control __move_10mm __axis_e]
type: input type: input
@ -255,7 +261,9 @@ parameter: 0
input_min: -50.0 input_min: -50.0
input_max: 50.0 input_max: 50.0
input_step: 10.0 input_step: 10.0
gcode: G1 E{0:.1f} F240 gcode:
M83
G1 E{0:.1f} F240
### menu move 1mm ### ### menu move 1mm ###
[menu __control __move_1mm] [menu __control __move_1mm]
@ -270,30 +278,36 @@ items:
[menu __control __move_1mm __axis_x] [menu __control __move_1mm __axis_x]
type: input type: input
name: "X:{0:05.1f} " name: "X:{0:05.1f} "
parameter: toolhead.xpos parameter: gcode.move_xpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 1.0 input_step: 1.0
gcode: G1 X{0:.1f} gcode:
G90
G1 X{0:.1f}
[menu __control __move_1mm __axis_y] [menu __control __move_1mm __axis_y]
type: input type: input
name: "Y:{0:05.1f} " name: "Y:{0:05.1f} "
parameter: toolhead.ypos parameter: gcode.move_ypos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 1.0 input_step: 1.0
gcode: G1 Y{0:.1f} gcode:
G90
G1 Y{0:.1f}
[menu __control __move_1mm __axis_z] [menu __control __move_1mm __axis_z]
type: input type: input
enable: !toolhead.is_printing enable: !toolhead.is_printing
name: "Move Z:{0:05.1f}" name: "Move Z:{0:05.1f}"
parameter: toolhead.zpos parameter: gcode.move_zpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 1.0 input_step: 1.0
gcode: G1 Z{0:.1f} gcode:
G90
G1 Z{0:.1f}
[menu __control __move_1mm __axis_e] [menu __control __move_1mm __axis_e]
type: input type: input
@ -303,7 +317,9 @@ parameter: 0
input_min: -50.0 input_min: -50.0
input_max: 50.0 input_max: 50.0
input_step: 1.0 input_step: 1.0
gcode: G1 E{0:.1f} F240 gcode:
M83
G1 E{0:.1f} F240
### menu move 0.1mm ### ### menu move 0.1mm ###
[menu __control __move_01mm] [menu __control __move_01mm]
@ -318,30 +334,36 @@ items:
[menu __control __move_01mm __axis_x] [menu __control __move_01mm __axis_x]
type: input type: input
name: "X:{0:05.1f} " name: "X:{0:05.1f} "
parameter: toolhead.xpos parameter: gcode.move_xpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 0.1 input_step: 0.1
gcode: G1 X{0:.1f} gcode:
G90
G1 X{0:.1f}
[menu __control __move_01mm __axis_y] [menu __control __move_01mm __axis_y]
type: input type: input
name: "Y:{0:05.1f} " name: "Y:{0:05.1f} "
parameter: toolhead.ypos parameter: gcode.move_ypos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 0.1 input_step: 0.1
gcode: G1 Y{0:.1f} gcode:
G90
G1 Y{0:.1f}
[menu __control __move_01mm __axis_z] [menu __control __move_01mm __axis_z]
type: input type: input
enable: !toolhead.is_printing enable: !toolhead.is_printing
name: "Move Z:{0:05.1f}" name: "Move Z:{0:05.1f}"
parameter: toolhead.zpos parameter: gcode.move_zpos
input_min: 0 input_min: 0
input_max: 200.0 input_max: 200.0
input_step: 0.1 input_step: 0.1
gcode: G1 Z{0:.1f} gcode:
G90
G1 Z{0:.1f}
[menu __control __move_01mm __axis_e] [menu __control __move_01mm __axis_e]
type: input type: input
@ -351,7 +373,9 @@ parameter: 0
input_min: -50.0 input_min: -50.0
input_max: 50.0 input_max: 50.0
input_step: 0.1 input_step: 0.1
gcode: G1 E{0:.1f} F240 gcode:
M83
G1 E{0:.1f} F240
### menu temperature ### ### menu temperature ###
[menu __temp] [menu __temp]
@ -542,9 +566,11 @@ gcode:
[menu __filament __feed] [menu __filament __feed]
type: input type: input
name: Feed Filament: {0:.1f} name: Feed Filament: {0:.1f}
parameter: toolhead.epos parameter: 0
input_step: 0.1 input_step: 0.1
gcode: G1 E{0:.1f} F30 gcode:
M83
G1 E{0:.1f} F30
### menu prepare ### ### menu prepare ###
[menu __prepare] [menu __prepare]

View File

@ -102,7 +102,12 @@ 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):
p = [lp - bp for lp, bp in zip(self.last_position, self.base_position)]
p[3] /= self.extrude_factor
return p
def get_status(self, eventtime): def get_status(self, eventtime):
move_position = self.get_current_position()
busy = self.is_processing_data busy = self.is_processing_data
return { return {
'speed_factor': self.speed_factor * 60., 'speed_factor': self.speed_factor * 60.,
@ -110,6 +115,10 @@ class GCodeParser:
'extrude_factor': self.extrude_factor, 'extrude_factor': self.extrude_factor,
'abs_extrude': self.absoluteextrude, 'abs_extrude': self.absoluteextrude,
'busy': busy, 'busy': busy,
'move_xpos': move_position[0],
'move_ypos': move_position[1],
'move_zpos': move_position[2],
'move_epos': move_position[3],
'last_xpos': self.last_position[0], 'last_xpos': self.last_position[0],
'last_ypos': self.last_position[1], 'last_ypos': self.last_position[1],
'last_zpos': self.last_position[2], 'last_zpos': self.last_position[2],
@ -573,8 +582,7 @@ 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 = [lp - bp for lp, bp in zip(self.last_position, self.base_position)] p = self.get_current_position()
p[3] /= self.extrude_factor
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