Skip to content

Commit

Permalink
split paths on M6 and change placement to use offset
Browse files Browse the repository at this point in the history
  • Loading branch information
etrombly committed Mar 22, 2020
1 parent f1ebaa4 commit 7f76c5f
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 34 deletions.
37 changes: 19 additions & 18 deletions src/Mod/Path/PathScripts/PathCustom.py
Expand Up @@ -25,24 +25,27 @@
import FreeCADGui
import Path
from PySide import QtCore
from copy import copy


__doc__ = """Path Custom object and FreeCAD command"""

movecommands = ['G0', 'G00', 'G1', 'G01', 'G2', 'G02', 'G3', 'G03']


# Qt translation handling
def translate(context, text, disambig=None):
return QtCore.QCoreApplication.translate(context, text, disambig)


class ObjectCustom:

def __init__(self,obj):
obj.addProperty("App::PropertyStringList", "Gcode", "Path", QtCore.QT_TRANSLATE_NOOP("PathCustom", "The gcode to be inserted"))
obj.addProperty("App::PropertyLink", "ToolController", "Path", QtCore.QT_TRANSLATE_NOOP("PathCustom", "The tool controller that will be used to calculate the path"))
obj.addProperty("App::PropertyBool", "OperationPlacement", "Path", "Use operation placement")
obj.OperationPlacement = False
def __init__(self, obj):
obj.addProperty("App::PropertyStringList", "Gcode", "Path",
QtCore.QT_TRANSLATE_NOOP("PathCustom", "The gcode to be inserted"))
obj.addProperty("App::PropertyLink", "ToolController", "Path",
QtCore.QT_TRANSLATE_NOOP("PathCustom", "The tool controller that will be used to calculate the path"))
obj.addProperty("App::PropertyPlacement", "Offset", "Path",
"Placement Offset")
obj.Proxy = self

def __getstate__(self):
Expand All @@ -52,23 +55,21 @@ def __setstate__(self, state):
return None

def execute(self, obj):
commands = []
newPath = Path.Path
newpath = Path.Path()
if obj.Gcode:
for l in obj.Gcode:
newcommand=Path.Command(str(l))
if newcommand.Name in movecommands and obj.OperationPlacement:
newcommand = Path.Command(str(l))
if newcommand.Name in movecommands:
if 'X' in newcommand.Parameters:
newcommand.x += obj.Placement.Base.x
newcommand.x += obj.Offset.Base.x
if 'Y' in newcommand.Parameters:
newcommand.y += obj.Placement.Base.y
newcommand.y += obj.Offset.Base.y
if 'Z' in newcommand.Parameters:
newcommand.z += obj.Placement.Base.z
newcommand.z += obj.Offset.Base.z

commands.append(newcommand)
newPath.addCommands(commands)
newpath.insertCommand(newcommand)

obj.Path = newPath
obj.Path=newpath


class CommandPathCustom:
Expand All @@ -89,7 +90,7 @@ def Activated(self):
FreeCAD.ActiveDocument.openTransaction("Create Custom Path")
FreeCADGui.addModule("PathScripts.PathCustom")
FreeCADGui.addModule("PathScripts.PathUtils")
FreeCADGui.doCommand('obj = FreeCAD.ActiveDocument.addObject("Path::FeaturePython","Custom")')
FreeCADGui.doCommand('obj = FreeCAD.ActiveDocument.addObject("Path::FeaturePython", "Custom")')
FreeCADGui.doCommand('PathScripts.PathCustom.ObjectCustom(obj)')
FreeCADGui.doCommand('obj.ViewObject.Proxy = 0')
FreeCADGui.doCommand('PathScripts.PathUtils.addToJob(obj)')
Expand All @@ -100,4 +101,4 @@ def Activated(self):

if FreeCAD.GuiUp:
# register the FreeCAD command
FreeCADGui.addCommand('Path_Custom', CommandPathCustom())
FreeCADGui.addCommand('Path_Custom', CommandPathCustom())
13 changes: 6 additions & 7 deletions src/Mod/Path/PathScripts/post/example_pre.py
Expand Up @@ -73,13 +73,11 @@ def insert(filename, docname):
def parse(inputstring):
"parse(inputstring): returns a parsed output string"
print("preprocessing...")
print(inputstring)
PathLog.track(inputstring)
# split the input by line
lines = inputstring.split("\n")
output = ""
lastcommand = None
print(lines)
output = [] #""
lastcommand = None

for lin in lines:
# remove any leftover trailing and preceding spaces
Expand All @@ -91,7 +89,7 @@ def parse(inputstring):
# remove line numbers
lin = lin.split(" ", 1)
if len(lin) >= 1:
lin = lin[1]
lin = lin[1].strip()
else:
continue

Expand All @@ -100,7 +98,8 @@ def parse(inputstring):
continue
if lin[0].upper() in ["G", "M"]:
# found a G or M command: we store it
output += lin + "\n"
#output += lin + "\n"
output.append(lin) # + "\n"
last = lin[0].upper()
for c in lin[1:]:
if not c.isdigit():
Expand All @@ -110,7 +109,7 @@ def parse(inputstring):
lastcommand = last
elif lastcommand:
# no G or M command: we repeat the last one
output += lastcommand + " " + lin + "\n"
output.append(lastcommand + " " + lin) # + "\n"

print("done preprocessing.")
return output
Expand Down
25 changes: 16 additions & 9 deletions src/Mod/Path/PathScripts/post/gcode_pre.py
Expand Up @@ -36,6 +36,7 @@
import FreeCAD
import PathScripts.PathUtils
import PathScripts.PathLog as PathLog
import re

# LEVEL = PathLog.Level.DEBUG
LEVEL = PathLog.Level.INFO
Expand Down Expand Up @@ -64,14 +65,20 @@ def insert(filename, docname):
gfile = pythonopen(filename)
gcode = gfile.read()
gfile.close()
gcode = parse(gcode)
doc = FreeCAD.getDocument(docname)
obj = FreeCAD.ActiveDocument.addObject("Path::FeaturePython", "Custom")
PathScripts.PathCustom.ObjectCustom(obj)
obj.ViewObject.Proxy = 0
obj.Gcode = gcode
PathScripts.PathUtils.addToJob(obj)
obj.ToolController = PathScripts.PathUtils.findToolController(obj)
# split on tool changes
paths = re.split('(?=[mM]+\s?0?6)', gcode)
# if there are any tool changes combine the preamble with the default tool
if len(paths) > 1:
paths = ["\n".join(paths[0:2])] + paths[2:]
for path in paths:
gcode = parse(path)
doc = FreeCAD.getDocument(docname)
obj = FreeCAD.ActiveDocument.addObject("Path::FeaturePython", "Custom")
PathScripts.PathCustom.ObjectCustom(obj)
obj.ViewObject.Proxy = 0
obj.Gcode = gcode
PathScripts.PathUtils.addToJob(obj)
obj.ToolController = PathScripts.PathUtils.findToolController(obj)
FreeCAD.ActiveDocument.recompute()


Expand All @@ -82,7 +89,7 @@ def parse(inputstring):
# split the input by line
lines = inputstring.split("\n")
output = [] #""
lastcommand = None
lastcommand = None

for lin in lines:
# remove any leftover trailing and preceding spaces
Expand Down

0 comments on commit 7f76c5f

Please sign in to comment.