Use WrapperLayout instead of PseudoLayout
This commit is contained in:
parent
cee88cd7ca
commit
e0213e7447
@ -54,16 +54,11 @@ class WebEngineView(QWebEngineView):
|
||||
self.setPage(page)
|
||||
|
||||
sip.delete(self.layout())
|
||||
self._layout = miscwidgets.PseudoLayout(self)
|
||||
self._layout = miscwidgets.WrapperLayout(self)
|
||||
|
||||
def shutdown(self):
|
||||
self.page().shutdown()
|
||||
|
||||
def resizeEvent(self, _event):
|
||||
proxy = self.focusProxy()
|
||||
if proxy:
|
||||
proxy.setGeometry(self.rect())
|
||||
|
||||
def createWindow(self, wintype):
|
||||
"""Called by Qt when a page wants to create a new window.
|
||||
|
||||
|
@ -240,8 +240,13 @@ class WrapperLayout(QLayout):
|
||||
super().__init__(parent)
|
||||
self._widget = None
|
||||
|
||||
def addItem(self, _widget):
|
||||
raise utils.Unreachable
|
||||
def addItem(self, item):
|
||||
assert self.parent() is not None
|
||||
self.wrap(self.parent(), item.widget())
|
||||
|
||||
def removeItem(self, item):
|
||||
assert item.widget() == self._widget
|
||||
self.unwrap()
|
||||
|
||||
def sizeHint(self):
|
||||
return self._widget.sizeHint()
|
||||
@ -253,6 +258,7 @@ class WrapperLayout(QLayout):
|
||||
raise utils.Unreachable
|
||||
|
||||
def setGeometry(self, rect):
|
||||
if self._widget is not None:
|
||||
self._widget.setGeometry(rect)
|
||||
|
||||
def wrap(self, container, widget):
|
||||
@ -264,22 +270,7 @@ class WrapperLayout(QLayout):
|
||||
def unwrap(self):
|
||||
self._widget.setParent(None)
|
||||
self._widget.deleteLater()
|
||||
|
||||
|
||||
class PseudoLayout(QLayout):
|
||||
|
||||
def addItem(self, item):
|
||||
assert self.parent() is not None
|
||||
item.widget().setParent(self.parent())
|
||||
|
||||
def removeItem(self, item):
|
||||
item.widget().setParent(None)
|
||||
|
||||
def count(self):
|
||||
return 0
|
||||
|
||||
def itemAt(self, _pos):
|
||||
return None
|
||||
self._widget = None
|
||||
|
||||
|
||||
class FullscreenNotification(QLabel):
|
||||
|
Loading…
Reference in New Issue
Block a user