ToolProperties.py 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. from PyQt5 import QtGui, QtCore, QtWidgets
  2. from PyQt5.QtCore import Qt
  3. from FlatCAMTool import FlatCAMTool
  4. from FlatCAMObj import *
  5. import gettext
  6. import FlatCAMTranslation as fcTranslate
  7. fcTranslate.apply_language('ToolProperties')
  8. def _tr(text):
  9. try:
  10. return _(text)
  11. except:
  12. return text
  13. class Properties(FlatCAMTool):
  14. toolName = _tr("Properties")
  15. def __init__(self, app):
  16. FlatCAMTool.__init__(self, app)
  17. self.setSizePolicy(QtWidgets.QSizePolicy.Ignored, QtWidgets.QSizePolicy.Ignored)
  18. # this way I can hide/show the frame
  19. self.properties_frame = QtWidgets.QFrame()
  20. self.properties_frame.setContentsMargins(0, 0, 0, 0)
  21. self.layout.addWidget(self.properties_frame)
  22. self.properties_box = QtWidgets.QVBoxLayout()
  23. self.properties_box.setContentsMargins(0, 0, 0, 0)
  24. self.properties_frame.setLayout(self.properties_box)
  25. ## Title
  26. title_label = QtWidgets.QLabel("%s" % self.toolName)
  27. title_label.setStyleSheet("""
  28. QLabel
  29. {
  30. font-size: 16px;
  31. font-weight: bold;
  32. }
  33. """)
  34. self.properties_box.addWidget(title_label)
  35. # self.layout.setMargin(0) # PyQt4
  36. self.properties_box.setContentsMargins(0, 0, 0, 0) # PyQt5
  37. self.vlay = QtWidgets.QVBoxLayout()
  38. self.properties_box.addLayout(self.vlay)
  39. self.treeWidget = QtWidgets.QTreeWidget()
  40. self.treeWidget.setColumnCount(2)
  41. self.treeWidget.setHeaderHidden(True)
  42. self.treeWidget.header().setSectionResizeMode(QtWidgets.QHeaderView.ResizeToContents)
  43. self.treeWidget.setSizePolicy(QtWidgets.QSizePolicy.Ignored, QtWidgets.QSizePolicy.Expanding)
  44. self.vlay.addWidget(self.treeWidget)
  45. self.vlay.setStretch(0,0)
  46. def run(self, toggle=False):
  47. self.app.report_usage("ToolProperties()")
  48. if self.app.tool_tab_locked is True:
  49. return
  50. self.set_tool_ui()
  51. if toggle:
  52. # if the splitter is hidden, display it, else hide it but only if the current widget is the same
  53. if self.app.ui.splitter.sizes()[0] == 0:
  54. self.app.ui.splitter.setSizes([1, 1])
  55. else:
  56. try:
  57. if self.app.ui.tool_scroll_area.widget().objectName() == self.toolName:
  58. self.app.ui.splitter.setSizes([0, 1])
  59. except AttributeError:
  60. pass
  61. FlatCAMTool.run(self)
  62. self.properties()
  63. def install(self, icon=None, separator=None, **kwargs):
  64. FlatCAMTool.install(self, icon, separator, shortcut='P', **kwargs)
  65. def set_tool_ui(self):
  66. # this reset the TreeWidget
  67. self.treeWidget.clear()
  68. self.properties_frame.show()
  69. def properties(self):
  70. obj_list = self.app.collection.get_selected()
  71. if not obj_list:
  72. self.app.inform.emit(_tr("[ERROR_NOTCL] Properties Tool was not displayed. No object selected."))
  73. self.app.ui.notebook.setTabText(2, _tr("Tools"))
  74. self.properties_frame.hide()
  75. self.app.ui.notebook.setCurrentWidget(self.app.ui.project_tab)
  76. return
  77. for obj in obj_list:
  78. self.addItems(obj)
  79. self.app.inform.emit(_tr("[success] Object Properties are displayed."))
  80. self.app.ui.notebook.setTabText(2, _tr("Properties Tool"))
  81. def addItems(self, obj):
  82. parent = self.treeWidget.invisibleRootItem()
  83. font = QtGui.QFont()
  84. font.setBold(True)
  85. obj_type = self.addParent(parent, 'TYPE', expanded=True, color=QtGui.QColor("#000000"), font=font)
  86. obj_name = self.addParent(parent, 'NAME', expanded=True, color=QtGui.QColor("#000000"), font=font)
  87. dims = self.addParent(parent, 'Dimensions', expanded=True, color=QtGui.QColor("#000000"), font=font)
  88. units = self.addParent(parent, 'Units', expanded=True, color=QtGui.QColor("#000000"), font=font)
  89. options = self.addParent(parent, 'Options', color=QtGui.QColor("#000000"), font=font)
  90. if obj.kind.lower() == 'gerber':
  91. apertures = self.addParent(parent, 'Apertures', expanded=True, color=QtGui.QColor("#000000"), font=font)
  92. else:
  93. tools = self.addParent(parent, 'Tools', expanded=True, color=QtGui.QColor("#000000"), font=font)
  94. separator = self.addParent(parent, '')
  95. self.addChild(obj_type, ['Object Type:', ('%s' % (obj.kind.capitalize()))], True)
  96. try:
  97. self.addChild(obj_type, ['Geo Type:', ('%s' % ({False: "Single-Geo", True: "Multi-Geo"}[obj.multigeo]))], True)
  98. except Exception as e:
  99. pass
  100. self.addChild(obj_name, [obj.options['name']])
  101. # calculate physical dimensions
  102. try:
  103. xmin, ymin, xmax, ymax = obj.bounds()
  104. except Exception as e:
  105. log.debug("PropertiesTool.addItems() --> %s" % str(e))
  106. return
  107. length = abs(xmax - xmin)
  108. width = abs(ymax - ymin)
  109. self.addChild(dims, ['Length:', '%.4f %s' % (
  110. length, self.app.ui.general_defaults_form.general_app_group.units_radio.get_value().lower())], True)
  111. self.addChild(dims, ['Width:', '%.4f %s' % (
  112. width, self.app.ui.general_defaults_form.general_app_group.units_radio.get_value().lower())], True)
  113. if self.app.ui.general_defaults_form.general_app_group.units_radio.get_value().lower() == 'mm':
  114. area = (length * width) / 100
  115. self.addChild(dims, ['Box Area:', '%.4f %s' % (area, 'cm2')], True)
  116. else:
  117. area = length * width
  118. self.addChild(dims, ['Box Area:', '%.4f %s' % (area, 'in2')], True)
  119. self.addChild(units,
  120. ['FlatCAM units:',
  121. {
  122. 'in': 'Inch',
  123. 'mm': 'Metric'
  124. }
  125. [str(self.app.ui.general_defaults_form.general_app_group.units_radio.get_value().lower())]], True)
  126. for option in obj.options:
  127. if option is 'name':
  128. continue
  129. self.addChild(options, [str(option), str(obj.options[option])], True)
  130. if obj.kind.lower() == 'gerber':
  131. for ap in obj.apertures:
  132. self.addChild(apertures, [str(ap), str(obj.apertures[ap])], True)
  133. elif obj.kind.lower() == 'excellon':
  134. for tool, value in obj.tools.items():
  135. self.addChild(tools, [str(tool), str(value['C'])], True)
  136. elif obj.kind.lower() == 'geometry':
  137. for tool, value in obj.tools.items():
  138. geo_tool = self.addParent(tools, str(tool), expanded=True, color=QtGui.QColor("#000000"), font=font)
  139. for k, v in value.items():
  140. if k == 'solid_geometry':
  141. printed_value = 'Present' if v else 'None'
  142. self.addChild(geo_tool, [str(k), printed_value], True)
  143. elif k == 'data':
  144. tool_data = self.addParent(geo_tool, str(k).capitalize(),
  145. color=QtGui.QColor("#000000"), font=font)
  146. for data_k, data_v in v.items():
  147. self.addChild(tool_data, [str(data_k), str(data_v)], True)
  148. else:
  149. self.addChild(geo_tool, [str(k), str(v)], True)
  150. elif obj.kind.lower() == 'cncjob':
  151. for tool, value in obj.cnc_tools.items():
  152. geo_tool = self.addParent(tools, str(tool), expanded=True, color=QtGui.QColor("#000000"), font=font)
  153. for k, v in value.items():
  154. if k == 'solid_geometry':
  155. printed_value = 'Present' if v else 'None'
  156. self.addChild(geo_tool, [str(k), printed_value], True)
  157. elif k == 'gcode':
  158. printed_value = 'Present' if v != '' else 'None'
  159. self.addChild(geo_tool, [str(k), printed_value], True)
  160. elif k == 'gcode_parsed':
  161. printed_value = 'Present' if v else 'None'
  162. self.addChild(geo_tool, [str(k), printed_value], True)
  163. elif k == 'data':
  164. tool_data = self.addParent(geo_tool, str(k).capitalize(),
  165. color=QtGui.QColor("#000000"), font=font)
  166. for data_k, data_v in v.items():
  167. self.addChild(tool_data, [str(data_k), str(data_v)], True)
  168. else:
  169. self.addChild(geo_tool, [str(k), str(v)], True)
  170. self.addChild(separator, [''])
  171. def addParent(self, parent, title, expanded=False, color=None, font=None):
  172. item = QtWidgets.QTreeWidgetItem(parent, [title])
  173. item.setChildIndicatorPolicy(QtWidgets.QTreeWidgetItem.ShowIndicator)
  174. item.setExpanded(expanded)
  175. if color is not None:
  176. # item.setTextColor(0, color) # PyQt4
  177. item.setForeground(0, QtGui.QBrush(color))
  178. if font is not None:
  179. item.setFont(0, font)
  180. return item
  181. def addChild(self, parent, title, column1=None):
  182. item = QtWidgets.QTreeWidgetItem(parent)
  183. item.setText(0, str(title[0]))
  184. if column1 is not None:
  185. item.setText(1, str(title[1]))
  186. # end of file