FlatCAMDocument.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. # ##########################################################
  2. # FlatCAM: 2D Post-processing for Manufacturing #
  3. # http://flatcam.org #
  4. # Author: Juan Pablo Caram (c) #
  5. # Date: 2/5/2014 #
  6. # MIT Licence #
  7. # ##########################################################
  8. # ##########################################################
  9. # File modified by: Marius Stanciu #
  10. # ##########################################################
  11. from appEditors.AppTextEditor import AppTextEditor
  12. from appObjects.FlatCAMObj import *
  13. import gettext
  14. import appTranslation as fcTranslate
  15. import builtins
  16. fcTranslate.apply_language('strings')
  17. if '_' not in builtins.__dict__:
  18. _ = gettext.gettext
  19. class DocumentObject(FlatCAMObj):
  20. """
  21. Represents a Document object.
  22. """
  23. optionChanged = QtCore.pyqtSignal(str)
  24. ui_type = DocumentObjectUI
  25. def __init__(self, name):
  26. self.decimals = self.app.decimals
  27. log.debug("Creating a Document object...")
  28. FlatCAMObj.__init__(self, name)
  29. self.kind = "document"
  30. self.units = ''
  31. self.ser_attrs = ['options', 'kind', 'source_file']
  32. self.source_file = ''
  33. self.doc_code = ''
  34. self.font_name = None
  35. self.font_italic = None
  36. self.font_bold = None
  37. self.font_underline = None
  38. self.document_editor_tab = None
  39. self._read_only = False
  40. self.units_found = self.app.defaults['units']
  41. def set_ui(self, ui):
  42. FlatCAMObj.set_ui(self, ui)
  43. log.debug("DocumentObject.set_ui()")
  44. assert isinstance(self.ui, DocumentObjectUI), \
  45. "Expected a DocumentObjectUI, got %s" % type(self.ui)
  46. self.units = self.app.defaults['units'].upper()
  47. self.units_found = self.app.defaults['units']
  48. # Fill form fields only on object create
  49. self.to_form()
  50. # Show/Hide Advanced Options
  51. if self.app.defaults["global_app_level"] == 'b':
  52. self.ui.level.setText('<span style="color:green;"><b>%s</b></span>' % _("Basic"))
  53. else:
  54. self.ui.level.setText('<span style="color:red;"><b>%s</b></span>' % _("Advanced"))
  55. self.document_editor_tab = AppTextEditor(app=self.app)
  56. stylesheet = """
  57. QTextEdit {selection-background-color:%s;
  58. selection-color:white;
  59. }
  60. """ % self.app.defaults["document_sel_color"]
  61. self.document_editor_tab.code_editor.setStyleSheet(stylesheet)
  62. self.document_editor_tab.buttonRun.hide()
  63. self.ui.autocomplete_cb.set_value(self.app.defaults['document_autocompleter'])
  64. self.on_autocomplete_changed(state=self.app.defaults['document_autocompleter'])
  65. self.on_tab_size_change(val=self.app.defaults['document_tab_size'])
  66. flt = "FlatCAM Docs (*.FlatDoc);;All Files (*.*)"
  67. # ######################################################################
  68. # ######################## SIGNALS #####################################
  69. # ######################################################################
  70. self.document_editor_tab.buttonOpen.clicked.disconnect()
  71. self.document_editor_tab.buttonOpen.clicked.connect(lambda: self.document_editor_tab.handleOpen(filt=flt))
  72. self.document_editor_tab.buttonSave.clicked.disconnect()
  73. self.document_editor_tab.buttonSave.clicked.connect(lambda: self.document_editor_tab.handleSaveGCode(filt=flt))
  74. self.document_editor_tab.code_editor.textChanged.connect(self.on_text_changed)
  75. self.ui.font_type_cb.currentFontChanged.connect(self.font_family)
  76. self.ui.font_size_cb.activated.connect(self.font_size)
  77. self.ui.font_bold_tb.clicked.connect(self.on_bold_button)
  78. self.ui.font_italic_tb.clicked.connect(self.on_italic_button)
  79. self.ui.font_under_tb.clicked.connect(self.on_underline_button)
  80. self.ui.font_color_entry.editingFinished.connect(self.on_font_color_entry)
  81. self.ui.font_color_button.clicked.connect(self.on_font_color_button)
  82. self.ui.sel_color_entry.editingFinished.connect(self.on_selection_color_entry)
  83. self.ui.sel_color_button.clicked.connect(self.on_selection_color_button)
  84. self.ui.al_left_tb.clicked.connect(lambda: self.document_editor_tab.code_editor.setAlignment(Qt.AlignLeft))
  85. self.ui.al_center_tb.clicked.connect(lambda: self.document_editor_tab.code_editor.setAlignment(Qt.AlignCenter))
  86. self.ui.al_right_tb.clicked.connect(lambda: self.document_editor_tab.code_editor.setAlignment(Qt.AlignRight))
  87. self.ui.al_justify_tb.clicked.connect(
  88. lambda: self.document_editor_tab.code_editor.setAlignment(Qt.AlignJustify)
  89. )
  90. self.ui.autocomplete_cb.stateChanged.connect(self.on_autocomplete_changed)
  91. self.ui.tab_size_spinner.returnPressed.connect(self.on_tab_size_change)
  92. # #######################################################################
  93. self.ui.font_color_entry.set_value(self.app.defaults['document_font_color'])
  94. self.ui.font_color_button.setStyleSheet(
  95. "background-color:%s" % str(self.app.defaults['document_font_color']))
  96. self.ui.sel_color_entry.set_value(self.app.defaults['document_sel_color'])
  97. self.ui.sel_color_button.setStyleSheet(
  98. "background-color:%s" % self.app.defaults['document_sel_color'])
  99. self.ui.font_size_cb.setCurrentIndex(int(self.app.defaults['document_font_size']))
  100. # self.document_editor_tab.handleTextChanged()
  101. self.ser_attrs = ['options', 'kind', 'source_file']
  102. if Qt.mightBeRichText(self.source_file):
  103. # self.document_editor_tab.code_editor.setHtml(self.source_file)
  104. self.document_editor_tab.load_text(self.source_file, move_to_start=True, clear_text=True, as_html=True)
  105. else:
  106. # for line in self.source_file.splitlines():
  107. # self.document_editor_tab.code_editor.append(line)
  108. self.document_editor_tab.load_text(self.source_file, move_to_start=True, clear_text=True, as_html=False)
  109. self.build_ui()
  110. @property
  111. def read_only(self):
  112. return self._read_only
  113. @read_only.setter
  114. def read_only(self, val):
  115. if val:
  116. self._read_only = True
  117. else:
  118. self._read_only = False
  119. def build_ui(self):
  120. FlatCAMObj.build_ui(self)
  121. tab_here = False
  122. # try to not add too many times a tab that it is already installed
  123. for idx in range(self.app.ui.plot_tab_area.count()):
  124. if self.app.ui.plot_tab_area.widget(idx).objectName() == self.options['name']:
  125. tab_here = True
  126. break
  127. # add the tab if it is not already added
  128. if tab_here is False:
  129. self.app.ui.plot_tab_area.addTab(self.document_editor_tab, '%s' % _("Document Editor"))
  130. self.document_editor_tab.setObjectName(self.options['name'])
  131. # Switch plot_area to CNCJob tab
  132. self.app.ui.plot_tab_area.setCurrentWidget(self.document_editor_tab)
  133. def on_autocomplete_changed(self, state):
  134. if state:
  135. self.document_editor_tab.code_editor.completer_enable = True
  136. else:
  137. self.document_editor_tab.code_editor.completer_enable = False
  138. def on_tab_size_change(self, val=None):
  139. try:
  140. self.ui.tab_size_spinner.returnPressed.disconnect(self.on_tab_size_change)
  141. except TypeError:
  142. pass
  143. if val:
  144. self.ui.tab_size_spinner.set_value(val)
  145. tab_balue = int(self.ui.tab_size_spinner.get_value())
  146. self.document_editor_tab.code_editor.setTabStopWidth(tab_balue)
  147. self.app.defaults['document_tab_size'] = tab_balue
  148. self.ui.tab_size_spinner.returnPressed.connect(self.on_tab_size_change)
  149. def on_text_changed(self):
  150. self.source_file = self.document_editor_tab.code_editor.toHtml()
  151. # print(self.source_file)
  152. def font_family(self, font):
  153. # self.document_editor_tab.code_editor.selectAll()
  154. font.setPointSize(float(self.ui.font_size_cb.get_value()))
  155. self.document_editor_tab.code_editor.setCurrentFont(font)
  156. self.font_name = self.ui.font_type_cb.currentFont().family()
  157. def font_size(self):
  158. # self.document_editor_tab.code_editor.selectAll()
  159. self.document_editor_tab.code_editor.setFontPointSize(float(self.ui.font_size_cb.get_value()))
  160. def on_bold_button(self):
  161. if self.ui.font_bold_tb.isChecked():
  162. self.document_editor_tab.code_editor.setFontWeight(QtGui.QFont.Bold)
  163. self.font_bold = True
  164. else:
  165. self.document_editor_tab.code_editor.setFontWeight(QtGui.QFont.Normal)
  166. self.font_bold = False
  167. def on_italic_button(self):
  168. if self.ui.font_italic_tb.isChecked():
  169. self.document_editor_tab.code_editor.setFontItalic(True)
  170. self.font_italic = True
  171. else:
  172. self.document_editor_tab.code_editor.setFontItalic(False)
  173. self.font_italic = False
  174. def on_underline_button(self):
  175. if self.ui.font_under_tb.isChecked():
  176. self.document_editor_tab.code_editor.setFontUnderline(True)
  177. self.font_underline = True
  178. else:
  179. self.document_editor_tab.code_editor.setFontUnderline(False)
  180. self.font_underline = False
  181. # Setting font colors handlers
  182. def on_font_color_entry(self):
  183. self.app.defaults['document_font_color'] = self.ui.font_color_entry.get_value()
  184. self.ui.font_color_button.setStyleSheet("background-color:%s" % str(self.app.defaults['document_font_color']))
  185. def on_font_color_button(self):
  186. current_color = QtGui.QColor(self.app.defaults['document_font_color'])
  187. c_dialog = QtWidgets.QColorDialog()
  188. font_color = c_dialog.getColor(initial=current_color)
  189. if font_color.isValid() is False:
  190. return
  191. self.document_editor_tab.code_editor.setTextColor(font_color)
  192. self.ui.font_color_button.setStyleSheet("background-color:%s" % str(font_color.name()))
  193. new_val = str(font_color.name())
  194. self.ui.font_color_entry.set_value(new_val)
  195. self.app.defaults['document_font_color'] = new_val
  196. # Setting selection colors handlers
  197. def on_selection_color_entry(self):
  198. self.app.defaults['document_sel_color'] = self.ui.sel_color_entry.get_value()
  199. self.ui.sel_color_button.setStyleSheet("background-color:%s" % str(self.app.defaults['document_sel_color']))
  200. def on_selection_color_button(self):
  201. current_color = QtGui.QColor(self.app.defaults['document_sel_color'])
  202. c_dialog = QtWidgets.QColorDialog()
  203. sel_color = c_dialog.getColor(initial=current_color)
  204. if sel_color.isValid() is False:
  205. return
  206. p = QtGui.QPalette()
  207. p.setColor(QtGui.QPalette.Highlight, sel_color)
  208. p.setColor(QtGui.QPalette.HighlightedText, QtGui.QColor('white'))
  209. self.document_editor_tab.code_editor.setPalette(p)
  210. self.ui.sel_color_button.setStyleSheet("background-color:%s" % str(sel_color.name()))
  211. new_val = str(sel_color.name())
  212. self.ui.sel_color_entry.set_value(new_val)
  213. self.app.defaults['document_sel_color'] = new_val
  214. def mirror(self, axis, point):
  215. pass
  216. def offset(self, vect):
  217. pass
  218. def rotate(self, angle, point):
  219. pass
  220. def scale(self, xfactor, yfactor=None, point=None):
  221. pass
  222. def skew(self, angle_x, angle_y, point):
  223. pass
  224. def buffer(self, distance, join, factor=None):
  225. pass
  226. def bounds(self, flatten=False):
  227. return None, None, None, None
  228. def to_dict(self):
  229. """
  230. Returns a representation of the object as a dictionary.
  231. Attributes to include are listed in ``self.ser_attrs``.
  232. :return: A dictionary-encoded copy of the object.
  233. :rtype: dict
  234. """
  235. d = {}
  236. for attr in self.ser_attrs:
  237. d[attr] = getattr(self, attr)
  238. return d
  239. def from_dict(self, d):
  240. """
  241. Sets object's attributes from a dictionary.
  242. Attributes to include are listed in ``self.ser_attrs``.
  243. This method will look only for only and all the
  244. attributes in ``self.ser_attrs``. They must all
  245. be present. Use only for deserializing saved
  246. objects.
  247. :param d: Dictionary of attributes to set in the object.
  248. :type d: dict
  249. :return: None
  250. """
  251. for attr in self.ser_attrs:
  252. setattr(self, attr, d[attr])