Merge pull request #1707 from pijyoi/pyqt61_compat
add PyQt6 6.1 forwards compatibility
This commit is contained in:
commit
bb90ef1ec9
@ -376,6 +376,15 @@ if QT_LIB == PYQT6:
|
|||||||
QtCore.QEvent.type = new_method
|
QtCore.QEvent.type = new_method
|
||||||
del new_method
|
del new_method
|
||||||
|
|
||||||
|
# PyQt6 6.1 renames some enums and flags to be in line with the other bindings.
|
||||||
|
# "Alignment" and "Orientations" are PyQt6 6.0 and are used in the generated
|
||||||
|
# ui files. Pending a regeneration of the template files, which would mean a
|
||||||
|
# drop in support for PyQt6 6.0, provide the old names for PyQt6 6.1.
|
||||||
|
# This is strictly a temporary private shim. Do not depend on it in your code.
|
||||||
|
if hasattr(QtCore.Qt, 'AlignmentFlag') and not hasattr(QtCore.Qt, 'Alignment'):
|
||||||
|
QtCore.Qt.Alignment = QtCore.Qt.AlignmentFlag
|
||||||
|
if hasattr(QtCore.Qt, 'Orientation') and not hasattr(QtCore.Qt, 'Orientations'):
|
||||||
|
QtCore.Qt.Orientations = QtCore.Qt.Orientation
|
||||||
|
|
||||||
# USE_XXX variables are deprecated
|
# USE_XXX variables are deprecated
|
||||||
USE_PYSIDE = QT_LIB == PYSIDE
|
USE_PYSIDE = QT_LIB == PYSIDE
|
||||||
|
@ -826,10 +826,17 @@ class ROI(GraphicsObject):
|
|||||||
"""
|
"""
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def movePoint(self, handle, pos, modifiers=QtCore.Qt.KeyboardModifiers(0), finish=True, coords='parent'):
|
def movePoint(self, handle, pos, modifiers=None, finish=True, coords='parent'):
|
||||||
## called by Handles when they are moved.
|
## called by Handles when they are moved.
|
||||||
## pos is the new position of the handle in scene coords, as requested by the handle.
|
## pos is the new position of the handle in scene coords, as requested by the handle.
|
||||||
|
if modifiers is None:
|
||||||
|
try:
|
||||||
|
# this works for PyQt6 6.1 and other bindings
|
||||||
|
modifiers = QtCore.Qt.KeyboardModifier.NoModifier
|
||||||
|
except AttributeError:
|
||||||
|
# this works for PyQt6 6.0 and other bindings
|
||||||
|
modifiers = QtCore.Qt.KeyboardModifiers(0)
|
||||||
|
|
||||||
newState = self.stateCopy()
|
newState = self.stateCopy()
|
||||||
index = self.indexOfHandle(handle)
|
index = self.indexOfHandle(handle)
|
||||||
h = self.handles[index]
|
h = self.handles[index]
|
||||||
@ -1454,7 +1461,14 @@ class Handle(UIGraphicsItem):
|
|||||||
self.currentPen = self.hoverPen
|
self.currentPen = self.hoverPen
|
||||||
self.movePoint(pos, ev.modifiers(), finish=False)
|
self.movePoint(pos, ev.modifiers(), finish=False)
|
||||||
|
|
||||||
def movePoint(self, pos, modifiers=QtCore.Qt.KeyboardModifiers(0), finish=True):
|
def movePoint(self, pos, modifiers=None, finish=True):
|
||||||
|
if modifiers is None:
|
||||||
|
try:
|
||||||
|
# this works for PyQt6 6.1 and other bindings
|
||||||
|
modifiers = QtCore.Qt.KeyboardModifier.NoModifier
|
||||||
|
except AttributeError:
|
||||||
|
# this works for PyQt6 6.0 and other bindings
|
||||||
|
modifiers = QtCore.Qt.KeyboardModifiers(0)
|
||||||
for r in self.rois:
|
for r in self.rois:
|
||||||
if not r.checkPointMove(self, pos, modifiers):
|
if not r.checkPointMove(self, pos, modifiers):
|
||||||
return
|
return
|
||||||
|
@ -259,9 +259,10 @@ class Renderer(GraphicsView):
|
|||||||
|
|
||||||
def deserialize_wheel_event(self, wheel_event):
|
def deserialize_wheel_event(self, wheel_event):
|
||||||
pos, gpos, pixelDelta, angleDelta, btns, mods, phase, inverted = wheel_event
|
pos, gpos, pixelDelta, angleDelta, btns, mods, phase, inverted = wheel_event
|
||||||
btns = QtCore.Qt.MouseButtons(btns)
|
if QT_LIB != 'PyQt6':
|
||||||
mods = QtCore.Qt.KeyboardModifiers(mods)
|
btns = QtCore.Qt.MouseButtons(btns)
|
||||||
phase = QtCore.Qt.ScrollPhase(phase)
|
mods = QtCore.Qt.KeyboardModifiers(mods)
|
||||||
|
phase = QtCore.Qt.ScrollPhase(phase)
|
||||||
return QtGui.QWheelEvent(pos, gpos, pixelDelta, angleDelta, btns, mods, phase, inverted)
|
return QtGui.QWheelEvent(pos, gpos, pixelDelta, angleDelta, btns, mods, phase, inverted)
|
||||||
|
|
||||||
def mousePressEvent(self, mouse_event):
|
def mousePressEvent(self, mouse_event):
|
||||||
|
Loading…
Reference in New Issue
Block a user