|
@@ -1,155 +1,97 @@
|
|
|
-from PyQt5 import QtWidgets
|
|
|
|
|
-from PyQt5.QtCore import QSettings
|
|
|
|
|
|
|
+from flatcamGUI.preferences.OptionUI import *
|
|
|
|
|
+from flatcamGUI.preferences.OptionsGroupUI import OptionsGroupUI2
|
|
|
|
|
|
|
|
-from flatcamGUI.GUIElements import FCDoubleSpinner, FCEntry, FloatEntry, RadioSet, FCCheckBox
|
|
|
|
|
-from flatcamGUI.preferences.OptionsGroupUI import OptionsGroupUI
|
|
|
|
|
import gettext
|
|
import gettext
|
|
|
import FlatCAMTranslation as fcTranslate
|
|
import FlatCAMTranslation as fcTranslate
|
|
|
import builtins
|
|
import builtins
|
|
|
-
|
|
|
|
|
fcTranslate.apply_language('strings')
|
|
fcTranslate.apply_language('strings')
|
|
|
if '_' not in builtins.__dict__:
|
|
if '_' not in builtins.__dict__:
|
|
|
_ = gettext.gettext
|
|
_ = gettext.gettext
|
|
|
|
|
|
|
|
-settings = QSettings("Open Source", "FlatCAM")
|
|
|
|
|
-if settings.contains("machinist"):
|
|
|
|
|
- machinist_setting = settings.value('machinist', type=int)
|
|
|
|
|
-else:
|
|
|
|
|
- machinist_setting = 0
|
|
|
|
|
-
|
|
|
|
|
|
|
|
|
|
-class ExcellonAdvOptPrefGroupUI(OptionsGroupUI):
|
|
|
|
|
|
|
+class ExcellonAdvOptPrefGroupUI(OptionsGroupUI2):
|
|
|
|
|
|
|
|
- def __init__(self, decimals=4, parent=None):
|
|
|
|
|
- # OptionsGroupUI.__init__(self, "Excellon Advanced Options", parent=parent)
|
|
|
|
|
- super(ExcellonAdvOptPrefGroupUI, self).__init__(self, parent=parent)
|
|
|
|
|
-
|
|
|
|
|
- self.setTitle(str(_("Excellon Adv. Options")))
|
|
|
|
|
|
|
+ def __init__(self, decimals=4, **kwargs):
|
|
|
self.decimals = decimals
|
|
self.decimals = decimals
|
|
|
|
|
+ super().__init__(**kwargs)
|
|
|
|
|
+ self.setTitle(str(_("Excellon Adv. Options")))
|
|
|
|
|
|
|
|
- # #######################
|
|
|
|
|
- # ## ADVANCED OPTIONS ###
|
|
|
|
|
- # #######################
|
|
|
|
|
-
|
|
|
|
|
- self.exc_label = QtWidgets.QLabel('<b>%s:</b>' % _('Advanced Options'))
|
|
|
|
|
- self.exc_label.setToolTip(
|
|
|
|
|
- _("A list of Excellon advanced parameters.\n"
|
|
|
|
|
- "Those parameters are available only for\n"
|
|
|
|
|
- "Advanced App. Level.")
|
|
|
|
|
- )
|
|
|
|
|
- self.layout.addWidget(self.exc_label)
|
|
|
|
|
-
|
|
|
|
|
- grid1 = QtWidgets.QGridLayout()
|
|
|
|
|
- self.layout.addLayout(grid1)
|
|
|
|
|
-
|
|
|
|
|
- # Offset Z
|
|
|
|
|
- offsetlabel = QtWidgets.QLabel('%s:' % _('Offset Z'))
|
|
|
|
|
- offsetlabel.setToolTip(
|
|
|
|
|
- _("Some drill bits (the larger ones) need to drill deeper\n"
|
|
|
|
|
- "to create the desired exit hole diameter due of the tip shape.\n"
|
|
|
|
|
- "The value here can compensate the Cut Z parameter."))
|
|
|
|
|
- self.offset_entry = FCDoubleSpinner()
|
|
|
|
|
- self.offset_entry.set_precision(self.decimals)
|
|
|
|
|
- self.offset_entry.set_range(-999.9999, 999.9999)
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(offsetlabel, 0, 0)
|
|
|
|
|
- grid1.addWidget(self.offset_entry, 0, 1)
|
|
|
|
|
-
|
|
|
|
|
- # ToolChange X,Y
|
|
|
|
|
- toolchange_xy_label = QtWidgets.QLabel('%s:' % _('Toolchange X,Y'))
|
|
|
|
|
- toolchange_xy_label.setToolTip(
|
|
|
|
|
- _("Toolchange X,Y position.")
|
|
|
|
|
- )
|
|
|
|
|
- self.toolchangexy_entry = FCEntry()
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(toolchange_xy_label, 1, 0)
|
|
|
|
|
- grid1.addWidget(self.toolchangexy_entry, 1, 1)
|
|
|
|
|
-
|
|
|
|
|
- # Start Z
|
|
|
|
|
- startzlabel = QtWidgets.QLabel('%s:' % _('Start Z'))
|
|
|
|
|
- startzlabel.setToolTip(
|
|
|
|
|
- _("Height of the tool just after start.\n"
|
|
|
|
|
- "Delete the value if you don't need this feature.")
|
|
|
|
|
- )
|
|
|
|
|
- self.estartz_entry = FloatEntry()
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(startzlabel, 2, 0)
|
|
|
|
|
- grid1.addWidget(self.estartz_entry, 2, 1)
|
|
|
|
|
-
|
|
|
|
|
- # Feedrate Rapids
|
|
|
|
|
- fr_rapid_label = QtWidgets.QLabel('%s:' % _('Feedrate Rapids'))
|
|
|
|
|
- fr_rapid_label.setToolTip(
|
|
|
|
|
- _("Tool speed while drilling\n"
|
|
|
|
|
- "(in units per minute).\n"
|
|
|
|
|
- "This is for the rapid move G00.\n"
|
|
|
|
|
- "It is useful only for Marlin,\n"
|
|
|
|
|
- "ignore for any other cases.")
|
|
|
|
|
- )
|
|
|
|
|
- self.feedrate_rapid_entry = FCDoubleSpinner()
|
|
|
|
|
- self.feedrate_rapid_entry.set_precision(self.decimals)
|
|
|
|
|
- self.feedrate_rapid_entry.set_range(0, 99999.9999)
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(fr_rapid_label, 3, 0)
|
|
|
|
|
- grid1.addWidget(self.feedrate_rapid_entry, 3, 1)
|
|
|
|
|
-
|
|
|
|
|
- # Probe depth
|
|
|
|
|
- self.pdepth_label = QtWidgets.QLabel('%s:' % _("Probe Z depth"))
|
|
|
|
|
- self.pdepth_label.setToolTip(
|
|
|
|
|
- _("The maximum depth that the probe is allowed\n"
|
|
|
|
|
- "to probe. Negative value, in current units.")
|
|
|
|
|
- )
|
|
|
|
|
- self.pdepth_entry = FCDoubleSpinner()
|
|
|
|
|
- self.pdepth_entry.set_precision(self.decimals)
|
|
|
|
|
- self.pdepth_entry.set_range(-99999.9999, 0.0000)
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(self.pdepth_label, 4, 0)
|
|
|
|
|
- grid1.addWidget(self.pdepth_entry, 4, 1)
|
|
|
|
|
-
|
|
|
|
|
- # Probe feedrate
|
|
|
|
|
- self.feedrate_probe_label = QtWidgets.QLabel('%s:' % _("Feedrate Probe"))
|
|
|
|
|
- self.feedrate_probe_label.setToolTip(
|
|
|
|
|
- _("The feedrate used while the probe is probing.")
|
|
|
|
|
- )
|
|
|
|
|
- self.feedrate_probe_entry = FCDoubleSpinner()
|
|
|
|
|
- self.feedrate_probe_entry.set_precision(self.decimals)
|
|
|
|
|
- self.feedrate_probe_entry.set_range(0, 99999.9999)
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(self.feedrate_probe_label, 5, 0)
|
|
|
|
|
- grid1.addWidget(self.feedrate_probe_entry, 5, 1)
|
|
|
|
|
-
|
|
|
|
|
- # Spindle direction
|
|
|
|
|
- spindle_dir_label = QtWidgets.QLabel('%s:' % _('Spindle direction'))
|
|
|
|
|
- spindle_dir_label.setToolTip(
|
|
|
|
|
- _("This sets the direction that the spindle is rotating.\n"
|
|
|
|
|
- "It can be either:\n"
|
|
|
|
|
- "- CW = clockwise or\n"
|
|
|
|
|
- "- CCW = counter clockwise")
|
|
|
|
|
- )
|
|
|
|
|
-
|
|
|
|
|
- self.spindledir_radio = RadioSet([{'label': _('CW'), 'value': 'CW'},
|
|
|
|
|
- {'label': _('CCW'), 'value': 'CCW'}])
|
|
|
|
|
- grid1.addWidget(spindle_dir_label, 6, 0)
|
|
|
|
|
- grid1.addWidget(self.spindledir_radio, 6, 1)
|
|
|
|
|
-
|
|
|
|
|
- self.fplunge_cb = FCCheckBox('%s' % _('Fast Plunge'))
|
|
|
|
|
- self.fplunge_cb.setToolTip(
|
|
|
|
|
- _("By checking this, the vertical move from\n"
|
|
|
|
|
- "Z_Toolchange to Z_move is done with G0,\n"
|
|
|
|
|
- "meaning the fastest speed available.\n"
|
|
|
|
|
- "WARNING: the move is done at Toolchange X,Y coords.")
|
|
|
|
|
- )
|
|
|
|
|
- grid1.addWidget(self.fplunge_cb, 7, 0, 1, 2)
|
|
|
|
|
-
|
|
|
|
|
- self.fretract_cb = FCCheckBox('%s' % _('Fast Retract'))
|
|
|
|
|
- self.fretract_cb.setToolTip(
|
|
|
|
|
- _("Exit hole strategy.\n"
|
|
|
|
|
- " - When uncheked, while exiting the drilled hole the drill bit\n"
|
|
|
|
|
- "will travel slow, with set feedrate (G1), up to zero depth and then\n"
|
|
|
|
|
- "travel as fast as possible (G0) to the Z Move (travel height).\n"
|
|
|
|
|
- " - When checked the travel from Z cut (cut depth) to Z_move\n"
|
|
|
|
|
- "(travel height) is done as fast as possible (G0) in one move.")
|
|
|
|
|
- )
|
|
|
|
|
-
|
|
|
|
|
- grid1.addWidget(self.fretract_cb, 8, 0, 1, 2)
|
|
|
|
|
-
|
|
|
|
|
- self.layout.addStretch()
|
|
|
|
|
|
|
+ def build_options(self) -> [OptionUI]:
|
|
|
|
|
+ return [
|
|
|
|
|
+ HeadingOptionUI(
|
|
|
|
|
+ label_text="Advanced Options",
|
|
|
|
|
+ label_tooltip="A list of Excellon advanced parameters.\n"
|
|
|
|
|
+ "Those parameters are available only for\n"
|
|
|
|
|
+ "Advanced App. Level."
|
|
|
|
|
+ ),
|
|
|
|
|
+ DoubleSpinnerOptionUI(
|
|
|
|
|
+ option="excellon_offset",
|
|
|
|
|
+ label_text="Offset Z",
|
|
|
|
|
+ label_tooltip="Some drill bits (the larger ones) need to drill deeper\n"
|
|
|
|
|
+ "to create the desired exit hole diameter due of the tip shape.\n"
|
|
|
|
|
+ "The value here can compensate the Cut Z parameter.",
|
|
|
|
|
+ min_value=-999.9999, max_value=999.9999, step=0.1, decimals=self.decimals
|
|
|
|
|
+ ),
|
|
|
|
|
+ LineEntryOptionUI(
|
|
|
|
|
+ option="excellon_toolchangexy",
|
|
|
|
|
+ label_text="Toolchange X,Y",
|
|
|
|
|
+ label_tooltip="Toolchange X,Y position."
|
|
|
|
|
+ ),
|
|
|
|
|
+ FloatEntryOptionUI(
|
|
|
|
|
+ option="excellon_startz",
|
|
|
|
|
+ label_text="Start Z",
|
|
|
|
|
+ label_tooltip="Height of the tool just after start.\n"
|
|
|
|
|
+ "Delete the value if you don't need this feature."
|
|
|
|
|
+ ),
|
|
|
|
|
+ DoubleSpinnerOptionUI(
|
|
|
|
|
+ option="excellon_feedrate_rapid",
|
|
|
|
|
+ label_text="Feedrate Rapids",
|
|
|
|
|
+ label_tooltip="Tool speed while drilling\n"
|
|
|
|
|
+ "(in units per minute).\n"
|
|
|
|
|
+ "This is for the rapid move G00.\n"
|
|
|
|
|
+ "It is useful only for Marlin,\n"
|
|
|
|
|
+ "ignore for any other cases.",
|
|
|
|
|
+ min_value=0.0001, max_value=99999.9999, step=50, decimals=self.decimals
|
|
|
|
|
+ ),
|
|
|
|
|
+ DoubleSpinnerOptionUI(
|
|
|
|
|
+ option="excellon_z_pdepth",
|
|
|
|
|
+ label_text="Probe Z depth",
|
|
|
|
|
+ label_tooltip="The maximum depth that the probe is allowed\n"
|
|
|
|
|
+ "to probe. Negative value, in current units.",
|
|
|
|
|
+ min_value=-99999.9999, max_value=0.0, step=0.1, decimals=self.decimals
|
|
|
|
|
+ ),
|
|
|
|
|
+ DoubleSpinnerOptionUI(
|
|
|
|
|
+ option="excellon_feedrate_probe",
|
|
|
|
|
+ label_text="Feedrate Probe",
|
|
|
|
|
+ label_tooltip="The feedrate used while the probe is probing.",
|
|
|
|
|
+ min_value=0.0001, max_value=99999.9999, step=0.1, decimals=self.decimals
|
|
|
|
|
+ ),
|
|
|
|
|
+ RadioSetOptionUI(
|
|
|
|
|
+ option="excellon_spindledir",
|
|
|
|
|
+ label_text="Spindle direction",
|
|
|
|
|
+ label_tooltip="This sets the direction that the spindle is rotating.\n"
|
|
|
|
|
+ "It can be either:\n"
|
|
|
|
|
+ "- CW = clockwise or\n"
|
|
|
|
|
+ "- CCW = counter clockwise",
|
|
|
|
|
+ choices=[{'label': _('CW'), 'value': 'CW'},
|
|
|
|
|
+ {'label': _('CCW'), 'value': 'CCW'}]
|
|
|
|
|
+ ),
|
|
|
|
|
+ CheckboxOptionUI(
|
|
|
|
|
+ option="excellon_f_plunge",
|
|
|
|
|
+ label_text="Fast Plunge",
|
|
|
|
|
+ label_tooltip="By checking this, the vertical move from\n"
|
|
|
|
|
+ "Z_Toolchange to Z_move is done with G0,\n"
|
|
|
|
|
+ "meaning the fastest speed available.\n"
|
|
|
|
|
+ "WARNING: the move is done at Toolchange X,Y coords."
|
|
|
|
|
+ ),
|
|
|
|
|
+ CheckboxOptionUI(
|
|
|
|
|
+ option="excellon_f_retract",
|
|
|
|
|
+ label_text="Fast Retract",
|
|
|
|
|
+ label_tooltip="Exit hole strategy.\n"
|
|
|
|
|
+ " - When uncheked, while exiting the drilled hole the drill bit\n"
|
|
|
|
|
+ "will travel slow, with set feedrate (G1), up to zero depth and then\n"
|
|
|
|
|
+ "travel as fast as possible (G0) to the Z Move (travel height).\n"
|
|
|
|
|
+ " - When checked the travel from Z cut (cut depth) to Z_move\n"
|
|
|
|
|
+ "(travel height) is done as fast as possible (G0) in one move."
|
|
|
|
|
+ )
|
|
|
|
|
+ ]
|