# HG changeset patch # User Edouard Tisserant # Date 1563174300 -7200 # Node ID ad94a928d87d61febfd5de048acb397363dc59b2 # Parent 535eb0b8bd9d32c8ddbf1d6125c5f7358a99f66f# Parent e5ce6c4a8672d596c75aa973d75bbd37b4e425ab Merged default in svghmi diff -r e5ce6c4a8672 -r ad94a928d87d svghmi/README --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/svghmi/README Mon Jul 15 09:05:00 2019 +0200 @@ -0,0 +1,1 @@ +SVG HMI diff -r e5ce6c4a8672 -r ad94a928d87d svghmi/__init__.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/svghmi/__init__.py Mon Jul 15 09:05:00 2019 +0200 @@ -0,0 +1,10 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +# This file is part of Beremiz +# Copyright (C) 2019: Edouard TISSERANT +# +# See COPYING file for copyrights details. + +from __future__ import absolute_import +from svghmi.svghmi import * diff -r e5ce6c4a8672 -r ad94a928d87d svghmi/pous.xml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/svghmi/pous.xml Mon Jul 15 09:05:00 2019 +0200 @@ -0,0 +1,55 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff -r e5ce6c4a8672 -r ad94a928d87d svghmi/svghmi.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/svghmi/svghmi.py Mon Jul 15 09:05:00 2019 +0200 @@ -0,0 +1,130 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- + +# This file is part of Beremiz +# Copyright (C) 2019: Edouard TISSERANT +# +# See COPYING file for copyrights details. + +from __future__ import absolute_import +import os +import shutil + +import wx + +import util.paths as paths +from POULibrary import POULibrary +from docutil import open_svg + + +class SVGHMILibrary(POULibrary): + def GetLibraryPath(self): + return paths.AbsNeighbourFile(__file__, "pous.xml") + + +class SVGHMI(object): + XSD = """ + + + + + + + + + + """ + + ConfNodeMethods = [ + { + "bitmap": "ImportSVG", + "name": _("Import SVG"), + "tooltip": _("Import SVG"), + "method": "_ImportSVG" + }, + { + "bitmap": "ImportSVG", # should be something different + "name": _("Inkscape"), + "tooltip": _("Edit HMI"), + "method": "_StartInkscape" + }, + ] + + def _getSVGpath(self, project_path=None): + if project_path is None: + project_path = self.CTNPath() + # define name for SVG file containing gui layout + return os.path.join(project_path, "gui.svg") + + + def OnCTNSave(self, from_project_path=None): + if from_project_path is not None: + shutil.copyfile(self._getSVGpath(from_project_path), + self._getSVGpath()) + return PythonFileCTNMixin.OnCTNSave(self, from_project_path) + + def CTNGenerate_C(self, buildpath, locations): + """ + Return C code generated by iec2c compiler + when _generate_softPLC have been called + @param locations: ignored + @return: [(C_file_name, CFLAGS),...] , LDFLAGS_TO_APPEND + """ + + # TODO : get variable list from Controller + # self.GetCTRoot().blah + # TODO deduce HMI tree + + svgfile = self._getSVGpath() + if os.path.exists(svgfile): + # TODO : call xslt transform on Inkscape's SVG to generate + # - Errors on HMI semantics + # - Target XHTML as a DOM + # - ... maybe something to have a global view of what is declared in SVG. + pass + else: + # TODO : use default svg that expose the HMI tree as-is + pass + + + res = ([], "", False) + + targetpath = os.path.join(self._getBuildPath(), "target.xhtml") + targetfile = open(targetpath, 'w') + + # TODO : DOM to string + targetfile.write("TODO") + targetfile.close() + res += (("target.js", open(targetpath, "rb")),) + + # TODO add C code to expose HMI tree variables to shared memory + # TODO generate a description of shared memory (xml or CSV) + # that can be loaded by svghmi QTWeb* app or svghmi server + + + return res + + def _ImportSVG(self): + dialog = wx.FileDialog(self.GetCTRoot().AppFrame, _("Choose a SVG file"), os.getcwd(), "", _("SVG files (*.svg)|*.svg|All files|*.*"), wx.OPEN) + if dialog.ShowModal() == wx.ID_OK: + svgpath = dialog.GetPath() + if os.path.isfile(svgpath): + shutil.copy(svgpath, self._getSVGpath()) + else: + self.GetCTRoot().logger.write_error(_("No such SVG file: %s\n") % svgpath) + dialog.Destroy() + + def _StartInkscape(self): + svgfile = self._getSVGpath() + open_inkscape = True + if not self.GetCTRoot().CheckProjectPathPerm(): + dialog = wx.MessageDialog(self.GetCTRoot().AppFrame, + _("You don't have write permissions.\nOpen Inkscape anyway ?"), + _("Open Inkscape"), + wx.YES_NO | wx.ICON_QUESTION) + open_inkscape = dialog.ShowModal() == wx.ID_YES + dialog.Destroy() + if open_inkscape: + if not os.path.isfile(svgfile): + svgfile = None + open_svg(svgfile)