- more accurate path smoothing - fix for missing helix lead-in in some cases - fix for cleaning of helix center point - increased max allowed step-over to 75%
229 lines
10 KiB
Python
229 lines
10 KiB
Python
# /**************************************************************************
|
|
# * Copyright (c) Kresimir Tusek (kresimir.tusek@gmail.com) 2018 *
|
|
# * This file is part of the FreeCAD CAx development system. *
|
|
# * *
|
|
# * This library is free software; you can redistribute it and/or *
|
|
# * modify it under the terms of the GNU Library General Public *
|
|
# * License as published by the Free Software Foundation; either *
|
|
# * version 2 of the License, or (at your option) any later version. *
|
|
# * *
|
|
# * This library is distributed in the hope that it will be useful, *
|
|
# * but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
|
# * GNU Library General Public License for more details. *
|
|
# * *
|
|
# * You should have received a copy of the GNU Library General Public *
|
|
# * License along with this library; see the file COPYING.LIB. If not, *
|
|
# * write to the Free Software Foundation, Inc., 59 Temple Place, *
|
|
# * Suite 330, Boston, MA 02111-1307, USA *
|
|
# * *
|
|
# ***************************************************************************/
|
|
|
|
import FreeCAD
|
|
import FreeCADGui
|
|
import PathScripts.PathLog as PathLog
|
|
import PathScripts.PathGui as PathGui
|
|
import PathScripts.PathOpGui as PathOpGui
|
|
from PySide import QtCore, QtGui
|
|
import PathScripts.PathAdaptive as PathAdaptive
|
|
|
|
class TaskPanelOpPage(PathOpGui.TaskPanelPage):
|
|
def initPage(self, obj):
|
|
self.setTitle("Adaptive path operation")
|
|
|
|
def getForm(self):
|
|
form = QtGui.QWidget()
|
|
layout = QtGui.QVBoxLayout()
|
|
|
|
#tool controller
|
|
hlayout = QtGui.QHBoxLayout()
|
|
form.ToolController = QtGui.QComboBox()
|
|
form.ToolControllerLabel=QtGui.QLabel("Tool Controller")
|
|
hlayout.addWidget(form.ToolControllerLabel)
|
|
hlayout.addWidget(form.ToolController)
|
|
layout.addLayout(hlayout)
|
|
|
|
#cut region
|
|
formLayout = QtGui.QFormLayout()
|
|
form.Side = QtGui.QComboBox()
|
|
form.Side.addItem("Inside")
|
|
form.Side.addItem("Outside")
|
|
form.Side.setToolTip("Cut inside or outside of the selected shapes")
|
|
formLayout.addRow(QtGui.QLabel("Cut Region"),form.Side)
|
|
|
|
#operation type
|
|
form.OperationType = QtGui.QComboBox()
|
|
form.OperationType.addItem("Clearing")
|
|
form.OperationType.addItem("Profiling")
|
|
form.OperationType.setToolTip("Type of adaptive operation")
|
|
formLayout.addRow(QtGui.QLabel("Operation Type"),form.OperationType)
|
|
|
|
#step over
|
|
form.StepOver = QtGui.QSpinBox()
|
|
form.StepOver.setMinimum(15)
|
|
form.StepOver.setMaximum(75)
|
|
form.StepOver.setSingleStep(1)
|
|
form.StepOver.setValue(25)
|
|
form.StepOver.setToolTip("Optimal value for tool stepover")
|
|
formLayout.addRow(QtGui.QLabel("Step Over Percent"),form.StepOver)
|
|
|
|
#tolerance
|
|
form.Tolerance = QtGui.QSlider(QtCore.Qt.Horizontal)
|
|
form.Tolerance.setMinimum(5)
|
|
form.Tolerance.setMaximum(15)
|
|
form.Tolerance.setTickInterval(1)
|
|
form.Tolerance.setValue(10)
|
|
form.Tolerance.setTickPosition(QtGui.QSlider.TicksBelow)
|
|
form.Tolerance.setToolTip("Influences calculation performance vs stability and accuracy.")
|
|
formLayout.addRow(QtGui.QLabel("Accuracy vs Performance"),form.Tolerance)
|
|
|
|
#helix angle
|
|
form.HelixAngle = QtGui.QDoubleSpinBox()
|
|
form.HelixAngle.setMinimum(0.1)
|
|
form.HelixAngle.setMaximum(90)
|
|
form.HelixAngle.setSingleStep(0.1)
|
|
form.HelixAngle.setValue(5)
|
|
form.HelixAngle.setToolTip("Angle of the helix ramp entry")
|
|
formLayout.addRow(QtGui.QLabel("Helix Ramp Angle"),form.HelixAngle)
|
|
|
|
#helix diam. limit
|
|
form.HelixDiameterLimit = QtGui.QDoubleSpinBox()
|
|
form.HelixDiameterLimit.setMinimum(0.0)
|
|
form.HelixDiameterLimit.setMaximum(90)
|
|
form.HelixDiameterLimit.setSingleStep(0.1)
|
|
form.HelixDiameterLimit.setValue(0)
|
|
form.HelixDiameterLimit.setToolTip("If >0 it limits the helix ramp diameter\notherwise the 75 percent of tool diameter is used as helix diameter")
|
|
formLayout.addRow(QtGui.QLabel("Helix Max Diameter"),form.HelixDiameterLimit)
|
|
|
|
#lift distance
|
|
form.LiftDistance = QtGui.QDoubleSpinBox()
|
|
form.LiftDistance.setMinimum(0.0)
|
|
form.LiftDistance.setMaximum(1000)
|
|
form.LiftDistance.setSingleStep(0.1)
|
|
form.LiftDistance.setValue(1.0)
|
|
form.LiftDistance.setToolTip("How much to lift the tool up during the rapid linking moves over cleared regions.\nIf linking path is not clear tool is raised to clearence height.")
|
|
formLayout.addRow(QtGui.QLabel("Lift Distance"),form.LiftDistance)
|
|
|
|
#KeepToolDownRatio
|
|
form.KeepToolDownRatio = QtGui.QDoubleSpinBox()
|
|
form.KeepToolDownRatio.setMinimum(1.0)
|
|
form.KeepToolDownRatio.setMaximum(10)
|
|
form.KeepToolDownRatio.setSingleStep(1)
|
|
form.KeepToolDownRatio.setValue(3.0)
|
|
form.KeepToolDownRatio.setToolTip("Max length of keep-tool-down linking path compared to direct distance between points.\nIf exceeded link will be done by raising the tool to clearence height.")
|
|
formLayout.addRow(QtGui.QLabel("Keep Tool Down Ratio"),form.KeepToolDownRatio)
|
|
|
|
#stock to leave
|
|
form.StockToLeave = QtGui.QDoubleSpinBox()
|
|
form.StockToLeave.setMinimum(0.0)
|
|
form.StockToLeave.setMaximum(1000)
|
|
form.StockToLeave.setSingleStep(0.1)
|
|
form.StockToLeave.setValue(0)
|
|
form.StockToLeave.setToolTip("How much material to leave (i.e. for finishing operation)")
|
|
formLayout.addRow(QtGui.QLabel("Stock to Leave"),form.StockToLeave)
|
|
|
|
# #process holes
|
|
# form.ProcessHoles = QtGui.QCheckBox()
|
|
# form.ProcessHoles.setChecked(True)
|
|
# formLayout.addRow(QtGui.QLabel("Process Holes"),form.ProcessHoles)
|
|
|
|
#Force inside out
|
|
form.ForceInsideOut = QtGui.QCheckBox()
|
|
form.ForceInsideOut.setChecked(True)
|
|
formLayout.addRow(QtGui.QLabel("Force Clearing Inside-Out"),form.ForceInsideOut)
|
|
|
|
layout.addLayout(formLayout)
|
|
|
|
#stop button
|
|
form.StopButton=QtGui.QPushButton("Stop")
|
|
form.StopButton.setCheckable(True)
|
|
layout.addWidget(form.StopButton)
|
|
|
|
form.setLayout(layout)
|
|
return form
|
|
|
|
def getSignalsForUpdate(self, obj):
|
|
'''getSignalsForUpdate(obj) ... return list of signals for updating obj'''
|
|
signals = []
|
|
#signals.append(self.form.button.clicked)
|
|
signals.append(self.form.Side.currentIndexChanged)
|
|
signals.append(self.form.OperationType.currentIndexChanged)
|
|
signals.append(self.form.ToolController.currentIndexChanged)
|
|
signals.append(self.form.StepOver.valueChanged)
|
|
signals.append(self.form.Tolerance.valueChanged)
|
|
signals.append(self.form.HelixAngle.valueChanged)
|
|
signals.append(self.form.HelixDiameterLimit.valueChanged)
|
|
signals.append(self.form.LiftDistance.valueChanged)
|
|
signals.append(self.form.KeepToolDownRatio.valueChanged)
|
|
signals.append(self.form.StockToLeave.valueChanged)
|
|
|
|
# signals.append(self.form.ProcessHoles.stateChanged)
|
|
signals.append(self.form.ForceInsideOut.stateChanged)
|
|
signals.append(self.form.StopButton.toggled)
|
|
return signals
|
|
|
|
def setFields(self, obj):
|
|
self.selectInComboBox(obj.Side, self.form.Side)
|
|
self.selectInComboBox(obj.OperationType, self.form.OperationType)
|
|
self.form.StepOver.setValue(obj.StepOver)
|
|
self.form.Tolerance.setValue(int(obj.Tolerance*100))
|
|
self.form.HelixAngle.setValue(obj.HelixAngle)
|
|
self.form.HelixDiameterLimit.setValue(obj.HelixDiameterLimit)
|
|
self.form.LiftDistance.setValue(obj.LiftDistance)
|
|
if hasattr(obj, 'KeepToolDownRatio'):
|
|
self.form.KeepToolDownRatio.setValue(obj.KeepToolDownRatio)
|
|
|
|
if hasattr(obj, 'StockToLeave'):
|
|
self.form.StockToLeave.setValue(obj.StockToLeave)
|
|
|
|
# self.form.ProcessHoles.setChecked(obj.ProcessHoles)
|
|
self.form.ForceInsideOut.setChecked(obj.ForceInsideOut)
|
|
self.setupToolController(obj, self.form.ToolController)
|
|
self.form.StopButton.setChecked(obj.Stopped)
|
|
obj.setEditorMode('AdaptiveInputState', 2) #hide this property
|
|
obj.setEditorMode('AdaptiveOutputState', 2) #hide this property
|
|
obj.setEditorMode('StopProcessing', 2) # hide this property
|
|
obj.setEditorMode('Stopped', 2) # hide this property
|
|
|
|
def getFields(self, obj):
|
|
if obj.Side != str(self.form.Side.currentText()):
|
|
obj.Side = str(self.form.Side.currentText())
|
|
|
|
if obj.OperationType != str(self.form.OperationType.currentText()):
|
|
obj.OperationType = str(self.form.OperationType.currentText())
|
|
|
|
obj.StepOver = self.form.StepOver.value()
|
|
obj.Tolerance = 1.0*self.form.Tolerance.value()/100.0
|
|
obj.HelixAngle = self.form.HelixAngle.value()
|
|
obj.HelixDiameterLimit = self.form.HelixDiameterLimit.value()
|
|
obj.LiftDistance = self.form.LiftDistance.value()
|
|
|
|
if hasattr(obj, 'KeepToolDownRatio'):
|
|
obj.KeepToolDownRatio = self.form.KeepToolDownRatio.value()
|
|
|
|
if hasattr(obj, 'StockToLeave'):
|
|
obj.StockToLeave = self.form.StockToLeave.value()
|
|
|
|
# obj.ProcessHoles = self.form.ProcessHoles.isChecked()
|
|
obj.ForceInsideOut = self.form.ForceInsideOut.isChecked()
|
|
obj.Stopped = self.form.StopButton.isChecked()
|
|
if(obj.Stopped):
|
|
self.form.StopButton.setChecked(False) #reset the button
|
|
obj.StopProcessing=True
|
|
|
|
self.updateToolController(obj, self.form.ToolController)
|
|
obj.setEditorMode('AdaptiveInputState', 2) #hide this property
|
|
obj.setEditorMode('AdaptiveOutputState', 2) #hide this property
|
|
obj.setEditorMode('StopProcessing', 2) # hide this property
|
|
obj.setEditorMode('Stopped', 2) # hide this property
|
|
|
|
|
|
|
|
|
|
Command = PathOpGui.SetupOperation('Adaptive',
|
|
PathAdaptive.Create,
|
|
TaskPanelOpPage,
|
|
'Path-Adaptive',
|
|
QtCore.QT_TRANSLATE_NOOP("PathAdaptive", "Adaptive"),
|
|
QtCore.QT_TRANSLATE_NOOP("PathPocket", "Adaptive clearing and profiling"))
|