- disabled the context menu in tools table on Paint Tool in case that the painting method is single.
- added protection when trying to do Intersection in Geometry Editor without having selected Geometry items.
This commit is contained in:
parent
970b260333
commit
32aa37d793
|
@ -613,6 +613,7 @@ class FCCircle(FCShapeTool):
|
||||||
radius = distance(p1, p2)
|
radius = distance(p1, p2)
|
||||||
self.geometry = DrawToolShape(Point(p1).buffer(radius, int(self.steps_per_circ / 4)))
|
self.geometry = DrawToolShape(Point(p1).buffer(radius, int(self.steps_per_circ / 4)))
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Adding Circle completed.")
|
||||||
|
|
||||||
|
|
||||||
class FCArc(FCShapeTool):
|
class FCArc(FCShapeTool):
|
||||||
|
@ -794,6 +795,7 @@ class FCArc(FCShapeTool):
|
||||||
self.geometry = DrawToolShape(LineString(arc(center, radius, startangle, stopangle,
|
self.geometry = DrawToolShape(LineString(arc(center, radius, startangle, stopangle,
|
||||||
self.direction, self.steps_per_circ)))
|
self.direction, self.steps_per_circ)))
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Arc completed.")
|
||||||
|
|
||||||
|
|
||||||
class FCRectangle(FCShapeTool):
|
class FCRectangle(FCShapeTool):
|
||||||
|
@ -831,6 +833,7 @@ class FCRectangle(FCShapeTool):
|
||||||
# self.geometry = LinearRing([p1, (p2[0], p1[1]), p2, (p1[0], p2[1])])
|
# self.geometry = LinearRing([p1, (p2[0], p1[1]), p2, (p1[0], p2[1])])
|
||||||
self.geometry = DrawToolShape(Polygon([p1, (p2[0], p1[1]), p2, (p1[0], p2[1])]))
|
self.geometry = DrawToolShape(Polygon([p1, (p2[0], p1[1]), p2, (p1[0], p2[1])]))
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Rectangle completed.")
|
||||||
|
|
||||||
|
|
||||||
class FCPolygon(FCShapeTool):
|
class FCPolygon(FCShapeTool):
|
||||||
|
@ -869,6 +872,7 @@ class FCPolygon(FCShapeTool):
|
||||||
self.geometry = DrawToolShape(Polygon(self.points))
|
self.geometry = DrawToolShape(Polygon(self.points))
|
||||||
self.draw_app.in_action = False
|
self.draw_app.in_action = False
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Polygon completed.")
|
||||||
|
|
||||||
def on_key(self, key):
|
def on_key(self, key):
|
||||||
if key == 'backspace':
|
if key == 'backspace':
|
||||||
|
@ -885,6 +889,7 @@ class FCPath(FCPolygon):
|
||||||
self.geometry = DrawToolShape(LineString(self.points))
|
self.geometry = DrawToolShape(LineString(self.points))
|
||||||
self.draw_app.in_action = False
|
self.draw_app.in_action = False
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Path completed.")
|
||||||
|
|
||||||
def utility_geometry(self, data=None):
|
def utility_geometry(self, data=None):
|
||||||
if len(self.points) > 0:
|
if len(self.points) > 0:
|
||||||
|
@ -1174,6 +1179,7 @@ class FCMove(FCShapeTool):
|
||||||
# self.draw_app.set_selected(g)
|
# self.draw_app.set_selected(g)
|
||||||
|
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Geometry(s) Move completed.")
|
||||||
|
|
||||||
def utility_geometry(self, data=None):
|
def utility_geometry(self, data=None):
|
||||||
"""
|
"""
|
||||||
|
@ -1209,6 +1215,7 @@ class FCCopy(FCMove):
|
||||||
self.geometry = [DrawToolShape(affinity.translate(geom.geo, xoff=dx, yoff=dy))
|
self.geometry = [DrawToolShape(affinity.translate(geom.geo, xoff=dx, yoff=dy))
|
||||||
for geom in self.draw_app.get_selected()]
|
for geom in self.draw_app.get_selected()]
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Geometry(s) Copy completed.")
|
||||||
|
|
||||||
|
|
||||||
class FCText(FCShapeTool):
|
class FCText(FCShapeTool):
|
||||||
|
@ -1242,6 +1249,7 @@ class FCText(FCShapeTool):
|
||||||
self.text_gui.text_path = []
|
self.text_gui.text_path = []
|
||||||
self.text_gui.hide_tool()
|
self.text_gui.hide_tool()
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Adding Text completed.")
|
||||||
|
|
||||||
def utility_geometry(self, data=None):
|
def utility_geometry(self, data=None):
|
||||||
"""
|
"""
|
||||||
|
@ -1282,6 +1290,7 @@ class FCBuffer(FCShapeTool):
|
||||||
self.draw_app.buffer(buffer_distance, join_style)
|
self.draw_app.buffer(buffer_distance, join_style)
|
||||||
self.app.ui.notebook.setTabText(2, "Tools")
|
self.app.ui.notebook.setTabText(2, "Tools")
|
||||||
self.disactivate()
|
self.disactivate()
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Buffer Tool completed.")
|
||||||
|
|
||||||
def on_buffer_int(self):
|
def on_buffer_int(self):
|
||||||
buffer_distance = self.buff_tool.buffer_distance_entry.get_value()
|
buffer_distance = self.buff_tool.buffer_distance_entry.get_value()
|
||||||
|
@ -1291,6 +1300,7 @@ class FCBuffer(FCShapeTool):
|
||||||
self.draw_app.buffer_int(buffer_distance, join_style)
|
self.draw_app.buffer_int(buffer_distance, join_style)
|
||||||
self.app.ui.notebook.setTabText(2, "Tools")
|
self.app.ui.notebook.setTabText(2, "Tools")
|
||||||
self.disactivate()
|
self.disactivate()
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Buffer Int Tool completed.")
|
||||||
|
|
||||||
def on_buffer_ext(self):
|
def on_buffer_ext(self):
|
||||||
buffer_distance = self.buff_tool.buffer_distance_entry.get_value()
|
buffer_distance = self.buff_tool.buffer_distance_entry.get_value()
|
||||||
|
@ -1300,6 +1310,7 @@ class FCBuffer(FCShapeTool):
|
||||||
self.draw_app.buffer_ext(buffer_distance, join_style)
|
self.draw_app.buffer_ext(buffer_distance, join_style)
|
||||||
self.app.ui.notebook.setTabText(2, "Tools")
|
self.app.ui.notebook.setTabText(2, "Tools")
|
||||||
self.disactivate()
|
self.disactivate()
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Buffer Ext Tool completed.")
|
||||||
|
|
||||||
def activate(self):
|
def activate(self):
|
||||||
self.buff_tool.buffer_button.clicked.disconnect()
|
self.buff_tool.buffer_button.clicked.disconnect()
|
||||||
|
@ -1361,6 +1372,7 @@ class FCRotate(FCShapeTool):
|
||||||
# Delete old
|
# Delete old
|
||||||
self.draw_app.delete_selected()
|
self.draw_app.delete_selected()
|
||||||
self.complete = True
|
self.complete = True
|
||||||
|
self.draw_app.app.inform.emit("[success]Done. Geometry rotate completed.")
|
||||||
|
|
||||||
# MS: automatically select the Select Tool after finishing the action but is not working yet :(
|
# MS: automatically select the Select Tool after finishing the action but is not working yet :(
|
||||||
#self.draw_app.select_tool("select")
|
#self.draw_app.select_tool("select")
|
||||||
|
@ -2006,7 +2018,8 @@ class FlatCAMGeoEditor(QtCore.QObject):
|
||||||
try:
|
try:
|
||||||
self.options[option] = float(entry.text())
|
self.options[option] = float(entry.text())
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
log.debug(str(e))
|
log.debug("FlatCAMGeoEditor.__init__().entry2option() --> %s" % str(e))
|
||||||
|
return
|
||||||
|
|
||||||
self.app.ui.grid_gap_x_entry.setValidator(QtGui.QDoubleValidator())
|
self.app.ui.grid_gap_x_entry.setValidator(QtGui.QDoubleValidator())
|
||||||
self.app.ui.grid_gap_x_entry.textChanged.connect(
|
self.app.ui.grid_gap_x_entry.textChanged.connect(
|
||||||
|
@ -3020,7 +3033,13 @@ class FlatCAMGeoEditor(QtCore.QObject):
|
||||||
|
|
||||||
shapes = self.get_selected()
|
shapes = self.get_selected()
|
||||||
|
|
||||||
|
try:
|
||||||
results = shapes[0].geo
|
results = shapes[0].geo
|
||||||
|
except Exception as e:
|
||||||
|
log.debug("FlatCAMGeoEditor.intersection() --> %s" % str(e))
|
||||||
|
self.app.inform.emit("[warning_notcl]A selection of at least 2 geo items is required to do Intersection.")
|
||||||
|
self.select_tool('select')
|
||||||
|
return
|
||||||
|
|
||||||
for shape in shapes[1:]:
|
for shape in shapes[1:]:
|
||||||
results = results.intersection(shape.geo)
|
results = results.intersection(shape.geo)
|
||||||
|
|
|
@ -14,6 +14,8 @@ CAD program, and create G-Code for Isolation routing.
|
||||||
- fixed issue in Tool Calculators when a float value was entered starting only with the dot.
|
- fixed issue in Tool Calculators when a float value was entered starting only with the dot.
|
||||||
- added protection for entering incorrect values in Offset and Scale fields for Gerber and Geometry objects (in Selected Tab)
|
- added protection for entering incorrect values in Offset and Scale fields for Gerber and Geometry objects (in Selected Tab)
|
||||||
- added more shortcut keys in the Geometry Editor and in Excellon Editor; activated also the zoom (fit, in, out) shortcut keys ('1' , '2', '3') for the editors
|
- added more shortcut keys in the Geometry Editor and in Excellon Editor; activated also the zoom (fit, in, out) shortcut keys ('1' , '2', '3') for the editors
|
||||||
|
- disabled the context menu in tools table on Paint Tool in case that the painting method is single.
|
||||||
|
- added protection when trying to do Intersection in Geometry Editor without having selected Geometry items.
|
||||||
|
|
||||||
28.01.2018
|
28.01.2018
|
||||||
|
|
||||||
|
|
|
@ -312,11 +312,13 @@ class ToolPaint(FlatCAMTool, Gerber):
|
||||||
self.addtool_entry.setDisabled(True)
|
self.addtool_entry.setDisabled(True)
|
||||||
self.addtool_btn.setDisabled(True)
|
self.addtool_btn.setDisabled(True)
|
||||||
self.deltool_btn.setDisabled(True)
|
self.deltool_btn.setDisabled(True)
|
||||||
|
self.tools_table.setContextMenuPolicy(Qt.NoContextMenu)
|
||||||
else:
|
else:
|
||||||
self.rest_cb.setDisabled(False)
|
self.rest_cb.setDisabled(False)
|
||||||
self.addtool_entry.setDisabled(False)
|
self.addtool_entry.setDisabled(False)
|
||||||
self.addtool_btn.setDisabled(False)
|
self.addtool_btn.setDisabled(False)
|
||||||
self.deltool_btn.setDisabled(False)
|
self.deltool_btn.setDisabled(False)
|
||||||
|
self.tools_table.setContextMenuPolicy(Qt.ActionsContextMenu)
|
||||||
|
|
||||||
def set_ui(self):
|
def set_ui(self):
|
||||||
## Init the GUI interface
|
## Init the GUI interface
|
||||||
|
@ -383,6 +385,10 @@ class ToolPaint(FlatCAMTool, Gerber):
|
||||||
# through this, we add a initial row / tool in the tool_table
|
# through this, we add a initial row / tool in the tool_table
|
||||||
self.on_tool_add(self.app.defaults["tools_painttooldia"], muted=True)
|
self.on_tool_add(self.app.defaults["tools_painttooldia"], muted=True)
|
||||||
|
|
||||||
|
# if the Paint Method is "Single" disable the tool table context menu
|
||||||
|
if self.default_data["selectmethod"] == "single":
|
||||||
|
self.tools_table.setContextMenuPolicy(Qt.NoContextMenu)
|
||||||
|
|
||||||
def build_ui(self):
|
def build_ui(self):
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
Loading…
Reference in New Issue