diff options
author | Peter Åstrand (astrand) <astrand@cendio.se> | 2018-05-07 08:14:39 +0200 |
---|---|---|
committer | Peter Åstrand (astrand) <astrand@cendio.se> | 2018-05-07 08:14:39 +0200 |
commit | abb393139dcde536e7aafc8fcfbb8eb0b713ddc2 (patch) | |
tree | 8bf6e29e6ceaf6d2104150d145ff5ae190cbfe18 | |
parent | 583fb155d44de56f376bb17d0830d27718c40e44 (diff) | |
download | tigervnc-abb393139dcde536e7aafc8fcfbb8eb0b713ddc2.tar.gz tigervnc-abb393139dcde536e7aafc8fcfbb8eb0b713ddc2.zip |
Recreate fullscreen window if screens are removed or added
-rw-r--r-- | vncviewer/DesktopWindow.cxx | 39 | ||||
-rw-r--r-- | vncviewer/DesktopWindow.h | 1 |
2 files changed, 40 insertions, 0 deletions
diff --git a/vncviewer/DesktopWindow.cxx b/vncviewer/DesktopWindow.cxx index e86e90e6..f0aae11a 100644 --- a/vncviewer/DesktopWindow.cxx +++ b/vncviewer/DesktopWindow.cxx @@ -59,6 +59,10 @@ using namespace rfb; static rfb::LogWriter vlog("DesktopWindow"); +// Global due to http://www.fltk.org/str.php?L2177 and the similar +// issue for Fl::event_dispatch. +static DesktopWindow *staticSelf = NULL; + DesktopWindow::DesktopWindow(int w, int h, const char *name, const rfb::PixelFormat& serverPF, CConn* cc_) @@ -93,6 +97,8 @@ DesktopWindow::DesktopWindow(int w, int h, const char *name, OptionsDialog::addCallback(handleOptions, this); + staticSelf = this; + // Hack. See below... Fl::event_dispatch(&fltkHandle); @@ -207,6 +213,8 @@ DesktopWindow::~DesktopWindow() delete statsGraph; + staticSelf = NULL; + // FLTK automatically deletes all child widgets, so we shouldn't touch // them ourselves here } @@ -669,12 +677,43 @@ int DesktopWindow::handle(int event) } +void DesktopWindow::reconfigureFullscreen(void *data) +{ + DesktopWindow *self = (DesktopWindow *)data; + + assert(self); + self->fullscreen_on(); +} + + int DesktopWindow::fltkHandle(int event, Fl_Window *win) { int ret; ret = Fl::handle_(event, win); + switch (event) { + case FL_SCREEN_CONFIGURATION_CHANGED: + // Screens removed or added. Recreate fullscreen window if + // necessary. On Windows, adding a second screen only works + // reliable if we are using a timer. Otherwise, the window will + // not be resized to cover the new screen. A timer makes sense + // also on other systems, to make sure that whatever desktop + // environment has a chance to deal with things before we do. + // Please note that when using FullscreenSystemKeys on macOS, the + // display configuration cannot be changed: macOS will not detect + // added or removed screens and there will be no + // FL_SCREEN_CONFIGURATION_CHANGED event. This is by design: + // "When you capture a display, you have exclusive use of the + // display. Other applications and system services are not allowed + // to use the display or change its configuration. In addition, + // they are not notified of display changes" + if (staticSelf->fullscreen_active()) { + Fl::remove_timeout(reconfigureFullscreen, staticSelf); + Fl::add_timeout(0.5, reconfigureFullscreen, staticSelf); + } + } + // This is hackish and the result of the dodgy focus handling in FLTK. // The basic problem is that FLTK's view of focus and the system's tend // to differ, and as a result we do not see all the FL_FOCUS events we diff --git a/vncviewer/DesktopWindow.h b/vncviewer/DesktopWindow.h index 6ec8e1bd..25203c9b 100644 --- a/vncviewer/DesktopWindow.h +++ b/vncviewer/DesktopWindow.h @@ -99,6 +99,7 @@ private: void handleDesktopSize(); static void handleResizeTimeout(void *data); + static void reconfigureFullscreen(void *data); void remoteResize(int width, int height); void repositionWidgets(); |