summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/python/utils/canvas.py5
-rw-r--r--src/main/python/utils/fileWindow.py41
-rw-r--r--src/main/python/utils/graphics.py19
3 files changed, 44 insertions, 21 deletions
diff --git a/src/main/python/utils/canvas.py b/src/main/python/utils/canvas.py
index 640d4cc..a4c56f3 100644
--- a/src/main/python/utils/canvas.py
+++ b/src/main/python/utils/canvas.py
@@ -6,7 +6,8 @@ from PyQt5.QtWidgets import (QFileDialog, QApplication,
QGraphicsScene, QGraphicsView, QHBoxLayout, QMenu,
QTabWidget, QWidget, QSpacerItem, QStyle)
-from . import graphics, dialogs
+from . import dialogs
+from .graphics import customView
from .sizes import paperSizes, ppiList, sheetDimensionList
class canvas(QWidget):
@@ -30,7 +31,7 @@ class canvas(QWidget):
self.painter = QGraphicsScene()
self.painter.setBackgroundBrush(QBrush(Qt.white)) #set white background
- self.view = graphics.customView(self.painter, self) #create a viewport for the canvas board
+ self.view = customView(self.painter, self) #create a viewport for the canvas board
self.layout = QHBoxLayout(self) #create the layout of the canvas, the canvas could just subclass QGView instead
self.layout.addWidget(self.view, alignment=Qt.AlignCenter)
diff --git a/src/main/python/utils/fileWindow.py b/src/main/python/utils/fileWindow.py
index 95488b0..24d6a6d 100644
--- a/src/main/python/utils/fileWindow.py
+++ b/src/main/python/utils/fileWindow.py
@@ -2,11 +2,12 @@ import pickle
from PyQt5.QtCore import Qt, pyqtSignal
from PyQt5.QtGui import QIcon
-from PyQt5.QtWidgets import (QFileDialog, QGraphicsView, QHBoxLayout,
+from PyQt5.QtWidgets import (QFileDialog, QHBoxLayout,
QMdiSubWindow, QMenu, QPushButton, QSizePolicy,
- QSplitter, QWidget)
+ QSplitter, QWidget, QStyle)
from . import dialogs
+from .graphics import customView
from .canvas import canvas
from .tabs import customTabWidget
@@ -55,11 +56,11 @@ class fileWindow(QMdiSubWindow):
def createSideViewArea(self):
#creates the side view widgets and sets them to invisible
self.splitter = QSplitter(Qt.Vertical ,self)
- self.sideView = QGraphicsView(self)
+ self.sideView = customView(parent = self)
self.sideView.setInteractive(False)
- sideViewCloseButton = QPushButton('×', self.sideView)
- sideViewCloseButton.setFlat(True)
- sideViewCloseButton.setStyleSheet("""QPushButton{
+ self.sideViewCloseButton = QPushButton('×', self.sideView)
+ self.sideViewCloseButton.setFlat(True)
+ self.sideViewCloseButton.setStyleSheet("""QPushButton{
background: rgba(214, 54, 40, 50%);
border: 1px groove white;
border-radius: 2px;
@@ -67,15 +68,15 @@ class fileWindow(QMdiSubWindow):
font-weight: Bold;
padding: 1px 2px 3px 3px;
color: rgba(255, 255, 255, 50%);
- }
- QPushButton:Hover{
- background: rgba(214, 54, 40, 90%);
- color: rgba(255, 255, 255, 90%);
- }
+ }
+ QPushButton:Hover{
+ background: rgba(214, 54, 40, 90%);
+ color: rgba(255, 255, 255, 90%);
+ }
""")
- sideViewCloseButton.setFixedSize(20, 20)
- sideViewCloseButton.move(5, 5)
- sideViewCloseButton.clicked.connect(lambda: setattr(self, 'sideViewTab', None))
+ self.sideViewCloseButton.setFixedSize(20, 20)
+ self.moveSideViewCloseButton()
+ self.sideViewCloseButton.clicked.connect(lambda: setattr(self, 'sideViewTab', None))
self.splitter.setVisible(False)
self.sideView.setVisible(False)
@@ -89,6 +90,8 @@ class fileWindow(QMdiSubWindow):
if self.sideViewTab:
width = parentRect.width()
height = parentRect.height()
+ self.moveSideViewCloseButton()
+
else:
width = min(parentRect.width(), width + 100)
height = min(parentRect.height(), height + 200)
@@ -129,6 +132,7 @@ class fileWindow(QMdiSubWindow):
self.splitter.setVisible(True)
self.sideView.setVisible(True)
self.sideView.setScene(self.tabber.currentWidget().painter)
+ self.moveSideViewCloseButton()
self.resizeHandler()
return True
else:
@@ -136,7 +140,14 @@ class fileWindow(QMdiSubWindow):
self.sideView.setVisible(False)
self.resizeHandler()
return False
-
+
+ def moveSideViewCloseButton(self):
+ x = self.sideView.width() - 5
+ print(x)
+ if self.sideView.verticalScrollBar().isVisible():
+ x -= self.style().pixelMetric(QStyle.PM_ScrollBarExtent)
+ self.sideViewCloseButton.move(x, 5)
+
@property
def sideViewTab(self):
#returns current active if sideViewTab otherwise None
diff --git a/src/main/python/utils/graphics.py b/src/main/python/utils/graphics.py
index 9e1f690..aed7eed 100644
--- a/src/main/python/utils/graphics.py
+++ b/src/main/python/utils/graphics.py
@@ -1,15 +1,26 @@
from PyQt5.QtCore import Qt
from PyQt5.QtWidgets import QGraphicsView
+
class customView(QGraphicsView):
- def __init__(self, scene, parent=None):
- super(customView, self).__init__(scene, parent)
+ def __init__(self, scene = None, parent=None):
+ if scene is not None:
+ super(customView, self).__init__(scene, parent)
+ else:
+ super(customView, self).__init__(parent)
self.zoom = 1
+ self.setDragMode(True)
def wheelEvent(self, QWheelEvent):
if Qt.ControlModifier:
- self.zoom += QWheelEvent.angleDelta().y()/2880
- self.scale(self.zoom, self.zoom)
+ temp = self.zoom
+ if QWheelEvent.source() == Qt.MouseEventNotSynthesized:
+ if self.zoom + QWheelEvent.angleDelta().y()/2880 > 0.1:
+ self.zoom += QWheelEvent.angleDelta().y()/2880
+ else:
+ if self.zoom + QWheelEvent.pixelDelta().y() > 0.1:
+ self.zoom += QWheelEvent.angleDelta().y()
+ self.scale(self.zoom / temp, self.zoom / temp)
QWheelEvent.accept()
else:
return super().wheelEvent(self, QWheelEvent) \ No newline at end of file