restore maximized state on :fullscreen and when exiting video fullscreen

This commit is contained in:
Christian Helbling 2017-07-04 17:50:07 +02:00
parent 7eacea1057
commit 7ea7a2f3fd
2 changed files with 15 additions and 4 deletions

View File

@ -2171,6 +2171,10 @@ class CommandDispatcher:
window = self._tabbed_browser.window() window = self._tabbed_browser.window()
if window.isFullScreen(): if window.isFullScreen():
if window._restore_maximized:
window.showMaximized()
else:
window.showNormal() window.showNormal()
else: else:
window._restore_maximized = window.isMaximized()
window.showFullScreen() window.showFullScreen()

View File

@ -130,6 +130,8 @@ class MainWindow(QWidget):
_private: Whether the window is in private browsing mode. _private: Whether the window is in private browsing mode.
_restore_fullscreen: Whether to restore the fullscreen after leaving _restore_fullscreen: Whether to restore the fullscreen after leaving
a video fullscreen. a video fullscreen.
_restore_maximized: Whether to restore maximized window after leaving
a video fullscreen.
""" """
def __init__(self, *, private, geometry=None, parent=None): def __init__(self, *, private, geometry=None, parent=None):
@ -220,6 +222,7 @@ class MainWindow(QWidget):
objreg.get("app").new_window.emit(self) objreg.get("app").new_window.emit(self)
self._restore_fullscreen = False self._restore_fullscreen = False
self._restore_maximized = self.isMaximized()
def _init_geometry(self, geometry): def _init_geometry(self, geometry):
"""Initialize the window geometry or load it from disk.""" """Initialize the window geometry or load it from disk."""
@ -488,13 +491,17 @@ class MainWindow(QWidget):
def _on_fullscreen_requested(self, on): def _on_fullscreen_requested(self, on):
if on: if on:
self._restore_fullscreen = self.isFullScreen() self._restore_fullscreen = self.isFullScreen()
self._restore_maximized = self.isMaximized()
self.showFullScreen() self.showFullScreen()
elif not self._restore_fullscreen: elif not self._restore_fullscreen:
if self._restore_maximized:
self.showMaximized()
else:
self.showNormal() self.showNormal()
else: else:
self._restore_fullscreen = self.isFullScreen() self._restore_fullscreen = self.isFullScreen()
log.misc.debug('on: {}, restore fullscreen: {}' log.misc.debug('on: {}, restore fullscreen: {}, restore maximized: {}'
.format(on, self._restore_fullscreen)) .format(on, self._restore_fullscreen, self._restore_maximized))
@cmdutils.register(instance='main-window', scope='window') @cmdutils.register(instance='main-window', scope='window')
@pyqtSlot() @pyqtSlot()