Commit bcc9572b authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

vout: save previous display size regardless of the fullscreen flag

This is simpler and is also more robust. The display no longer needs to
know whether it is fullscreen or not when reporting the size.

This should fix bugs whereby leaving fullscreen forces the window to be
maximized. On the other hand, it will fail if the windowing system
automatically resize a fullscreen window (due to changing view port).
parent e9a3dca6
...@@ -410,7 +410,6 @@ struct vout_display_owner_sys_t { ...@@ -410,7 +410,6 @@ struct vout_display_owner_sys_t {
bool ch_display_size; bool ch_display_size;
int display_width; int display_width;
int display_height; int display_height;
bool display_is_fullscreen;
bool display_is_forced; bool display_is_forced;
int fit_window; int fit_window;
...@@ -707,11 +706,10 @@ static void VoutDisplayEvent(vout_display_t *vd, int event, va_list args) ...@@ -707,11 +706,10 @@ static void VoutDisplayEvent(vout_display_t *vd, int event, va_list args)
/* */ /* */
vlc_mutex_lock(&osys->lock); vlc_mutex_lock(&osys->lock);
osys->ch_display_size = true; osys->ch_display_size = true;
osys->display_width = width; osys->display_width = width;
osys->display_height = height; osys->display_height = height;
osys->display_is_fullscreen = is_fullscreen; osys->display_is_forced = false;
osys->display_is_forced = false;
vlc_mutex_unlock(&osys->lock); vlc_mutex_unlock(&osys->lock);
break; break;
...@@ -791,11 +789,10 @@ static void VoutDisplayFitWindow(vout_display_t *vd, bool default_size) ...@@ -791,11 +789,10 @@ static void VoutDisplayFitWindow(vout_display_t *vd, bool default_size)
vlc_mutex_lock(&osys->lock); vlc_mutex_lock(&osys->lock);
osys->ch_display_size = true; osys->ch_display_size = true;
osys->display_width = display_width; osys->display_width = display_width;
osys->display_height = display_height; osys->display_height = display_height;
osys->display_is_fullscreen = osys->cfg.is_fullscreen; osys->display_is_forced = true;
osys->display_is_forced = true;
vlc_mutex_unlock(&osys->lock); vlc_mutex_unlock(&osys->lock);
} }
...@@ -865,7 +862,6 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures) ...@@ -865,7 +862,6 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures)
bool ch_display_size = osys->ch_display_size; bool ch_display_size = osys->ch_display_size;
int display_width = osys->display_width; int display_width = osys->display_width;
int display_height = osys->display_height; int display_height = osys->display_height;
bool display_is_fullscreen = osys->display_is_fullscreen;
bool display_is_forced = osys->display_is_forced; bool display_is_forced = osys->display_is_forced;
osys->ch_display_size = false; osys->ch_display_size = false;
...@@ -922,8 +918,11 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures) ...@@ -922,8 +918,11 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures)
cfg.display.width = display_width; cfg.display.width = display_width;
cfg.display.height = display_height; cfg.display.height = display_height;
if (!cfg.is_fullscreen != !display_is_fullscreen || osys->width_saved = osys->cfg.display.width;
vout_display_Control(vd, VOUT_DISPLAY_CHANGE_DISPLAY_SIZE, &cfg, display_is_forced)) { osys->height_saved = osys->cfg.display.height;
if (vout_display_Control(vd, VOUT_DISPLAY_CHANGE_DISPLAY_SIZE,
&cfg, display_is_forced)) {
if (!display_is_forced) if (!display_is_forced)
msg_Err(vd, "Failed to resize display"); msg_Err(vd, "Failed to resize display");
...@@ -933,11 +932,6 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures) ...@@ -933,11 +932,6 @@ bool vout_ManageDisplay(vout_display_t *vd, bool allow_reset_pictures)
} }
osys->cfg.display.width = display_width; osys->cfg.display.width = display_width;
osys->cfg.display.height = display_height; osys->cfg.display.height = display_height;
if (!display_is_fullscreen) {
osys->width_saved = display_width;
osys->height_saved = display_height;
}
} }
/* */ /* */
if (osys->ch_display_filled) { if (osys->ch_display_filled) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment