summaryrefslogtreecommitdiff
path: root/src/main/python/utils
diff options
context:
space:
mode:
authorpravindalve2020-06-08 20:33:03 +0530
committerGitHub2020-06-08 20:33:03 +0530
commit0cf5626ed61f29249ebc92fcec6dbae5489bac8e (patch)
treece12d8e658713777e5b205fd5137aeae957bceff /src/main/python/utils
parent5c907a6e7f0c18a18094b70ba166c6bc5cdcf1ac (diff)
parentbfa6cdf2e858e4a08e7e51dbf6d6cddc8d4183b7 (diff)
downloadChemical-PFD-0cf5626ed61f29249ebc92fcec6dbae5489bac8e.tar.gz
Chemical-PFD-0cf5626ed61f29249ebc92fcec6dbae5489bac8e.tar.bz2
Chemical-PFD-0cf5626ed61f29249ebc92fcec6dbae5489bac8e.zip
Merge pull request #9 from Blakeinstein/master
Bring save logic to json instead of pickle
Diffstat (limited to 'src/main/python/utils')
-rw-r--r--src/main/python/utils/app.py3
-rw-r--r--src/main/python/utils/canvas.py45
-rw-r--r--src/main/python/utils/fileWindow.py27
3 files changed, 47 insertions, 28 deletions
diff --git a/src/main/python/utils/app.py b/src/main/python/utils/app.py
index 4540a43..4ee11c3 100644
--- a/src/main/python/utils/app.py
+++ b/src/main/python/utils/app.py
@@ -3,7 +3,10 @@ Declare fbs application so that it can be imported in other modules.
"""
from fbs_runtime.application_context.PyQt5 import ApplicationContext
+from PyQt5.QtCore import QSettings
+
app = ApplicationContext()
+settings = QSettings(QSettings.IniFormat, QSettings.UserScope ,"FOSSEE", "Chemical-PFD")
def fileImporter(file):
# Helper function to fetch files from src/main/resources
diff --git a/src/main/python/utils/canvas.py b/src/main/python/utils/canvas.py
index 2332087..dee0745 100644
--- a/src/main/python/utils/canvas.py
+++ b/src/main/python/utils/canvas.py
@@ -1,6 +1,6 @@
-import pickle
+import json
-from PyQt5.QtCore import Qt
+from PyQt5.QtCore import Qt, QPointF
from PyQt5.QtGui import QBrush, QPalette
from PyQt5.QtWidgets import (QFileDialog, QApplication, QHBoxLayout, QMenu,
QTabWidget, QWidget, QSpacerItem, QStyle)
@@ -9,13 +9,15 @@ from . import dialogs
from .graphics import customView, customScene
from .data import paperSizes, ppiList, sheetDimensionList
+import shapes
+
class canvas(QWidget):
"""
Defines the work area for a single sheet. Contains a QGraphicScene along with necessary properties
for context menu and dialogs.
"""
- def __init__(self, parent=None, size= 'A4', ppi= '72'):
+ def __init__(self, parent=None, size= 'A4', ppi= '72' , parentMdiArea = None, parentFileWindow = None):
super(canvas, self).__init__(parent)
#Store values for the canvas dimensions for ease of access, these are here just to be
@@ -27,7 +29,7 @@ class canvas(QWidget):
# when we will draw items on this, this might be changed if QGraphicScene is subclassed.
#set layout and background color
- self.painter = customScene()
+ self.painter = customScene()
self.painter.setBackgroundBrush(QBrush(Qt.white)) #set white background
self.view = customView(self.painter, self) #create a viewport for the canvas board
@@ -38,11 +40,9 @@ class canvas(QWidget):
self.setLayout(self.layout)
#set initial paper size for the scene
- self.painter.setSceneRect(0, 0, *paperSizes[self.canvasSize][self.ppi])
-
- #set pointers to necessary parents for ease of reference
- self.parentMdiArea = self.parent().parentWidget().parentWidget().parentWidget().parentWidget()
- self.parentFileWindow = self.parent().parentWidget().parentWidget()
+ self.painter.setSceneRect(0, 0, *paperSizes[self._canvasSize][self._ppi])
+ self.parentMdiArea = parentMdiArea
+ self.parentFileWindow = parentFileWindow
def resizeView(self, w, h):
#helper function to resize canvas
@@ -95,6 +95,7 @@ class canvas(QWidget):
def dimensions(self):
#returns the dimension of the current scene
return self.painter.sceneRect().width(), self.painter.sceneRect().height()
+
@property
def items(self):
# generator to filter out certain items
@@ -128,17 +129,33 @@ class canvas(QWidget):
"ppi": self._ppi,
"canvasSize": self._canvasSize,
"ObjectName": self.objectName(),
- "items": [i.__getState__() for i in self.painter.items()]
+ "symbols": [i.__getstate__() for i in self.painter.items() if isinstance(i, shapes.NodeItem)],
+ "lines": [i.__getstate__() for i in self.painter.items() if isinstance(i, shapes.Line)],
+ # "lineLabels": [i.__getstate__() for i in self.painter.items() if isinstance(i, shapes.LineLabel)],
+ # "itemLabels": [i.__getstate__() for i in self.painter.items() if isinstance(i, shapes.itemLabel)]
}
def __setstate__(self, dict):
- self.__init__()
self._ppi = dict['ppi']
self._canvasSize = dict['canvasSize']
self.setObjectName(dict['ObjectName'])
- for item in dict['items']:
- graphic = getattr(graphics, dict['_classname_'])
- graphic.__setstate__(item)
+
+ for item in dict['symbols']:
+ graphic = getattr(shapes, item['_classname_'])()
+ graphic.__setstate__(dict = item)
self.painter.addItem(graphic)
+ graphic.setPos(*item['pos'])
+
+ for item in dict['lines']:
+ line = shapes.Line(QPointF(*item['startPoint']), QPointF(*item['endPoint']))
+ line.__setstate__(dict = item)
+ self.painter.addItem(line)
+
+ self.painter.advance()
+
+ # for item in dict['lineLabels']:
+ # pass
+ # for item in dict['itemLabels']:
+ # pass
\ No newline at end of file
diff --git a/src/main/python/utils/fileWindow.py b/src/main/python/utils/fileWindow.py
index ebe509b..6ad4477 100644
--- a/src/main/python/utils/fileWindow.py
+++ b/src/main/python/utils/fileWindow.py
@@ -1,4 +1,4 @@
-import pickle
+import json
from PyQt5.QtCore import Qt, pyqtSignal, QPoint
from PyQt5.QtGui import QIcon
@@ -24,8 +24,8 @@ class fileWindow(QMdiSubWindow):
def __init__(self, parent = None, title = 'New Project', size = 'A4', ppi = '72'):
super(fileWindow, self).__init__(parent)
self._sideViewTab = None
- self.index = None
-
+ self.index = None
+
self.setSizePolicy(QSizePolicy.Fixed, QSizePolicy.Fixed)
#Uses a custom QTabWidget that houses a custom new Tab Button, used to house the seperate
# diagrams inside a file
@@ -210,19 +210,20 @@ class fileWindow(QMdiSubWindow):
self.tabber.widget(currentIndex).deleteLater()
self.tabber.removeTab(currentIndex)
- def newDiagram(self):
+ def newDiagram(self, objectName = "New"):
# helper function to add a new tab on pressing new tab button, using the add tab method on QTabWidget
- diagram = canvas(self.tabber)
- diagram.setObjectName("New")
- index = self.tabber.addTab(diagram, "New")
+ diagram = canvas(self.tabber, parentMdiArea = self.mdiArea(), parentFileWindow = self)
+ diagram.setObjectName(objectName)
+ index = self.tabber.addTab(diagram, objectName)
self.tabber.setCurrentIndex(index)
+ return diagram
def saveProject(self, name = None):
# called by dialog.saveEvent, saves the current file
name = QFileDialog.getSaveFileName(self, 'Save File', f'New Diagram', 'Process Flow Diagram (*.pfd)') if not name else name
if name[0]:
- with open(name[0],'wb') as file:
- pickle.dump(self, file)
+ with open(name[0],'w') as file:
+ json.dump(self.__getstate__(), file, indent=4)
return True
else:
return False
@@ -242,14 +243,12 @@ class fileWindow(QMdiSubWindow):
return {
"_classname_": self.__class__.__name__,
"ObjectName": self.objectName(),
- "ppi": self._ppi,
- "canvasSize": self._canvasSize,
"tabs": [i.__getstate__() for i in self.tabList]
}
def __setstate__(self, dict):
- self.__init__(title = dict['ObjectName'])
+ self.setObjectName = dict['ObjectName']
+ self.setWindowTitle = dict['ObjectName']
for i in dict['tabs']:
- diagram = canvas(self.tabber, size = dict['canvasSize'], ppi = dict['ppi'], fileWindow = self)
+ diagram = self.newDiagram(i['ObjectName'])
diagram.__setstate__(i)
- self.tabber.addTab(diagram, i['ObjectName'])