From 02a2fc2d44c3fcaf450d6b9d7785fefea32acb4a Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Wed, 3 Oct 2018 03:26:08 +0900 Subject: [PATCH] ui: Bug fix: Force to adjust window size when scale is changed Fixes #644 --- internal/ui/ui_glfw.go | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/internal/ui/ui_glfw.go b/internal/ui/ui_glfw.go index cca537512..62025f601 100644 --- a/internal/ui/ui_glfw.go +++ b/internal/ui/ui_glfw.go @@ -557,12 +557,15 @@ func (u *userInterface) updateGraphicsContext(g GraphicsContext) { // TODO: Is it possible to reduce 'runOnMainThread' calls? _ = u.runOnMainThread(func() error { actualScale = u.actualScreenScale() + if u.lastActualScale != actualScale { + u.forceSetScreenSize(u.width, u.height, u.scale, u.fullscreen(), u.vsync) + } + u.lastActualScale = actualScale - if !u.toChangeSize && u.lastActualScale == actualScale { + if !u.toChangeSize { return nil } - u.lastActualScale = actualScale u.toChangeSize = false sizeChanged = true return nil @@ -672,7 +675,12 @@ func (u *userInterface) setScreenSize(width, height int, scale float64, fullscre if u.width == width && u.height == height && u.scale == scale && u.fullscreen() == fullscreen && u.vsync == vsync { return false } + u.forceSetScreenSize(width, height, scale, fullscreen, vsync) + return true +} +// forceSetScreenSize must be called from the main thread. +func (u *userInterface) forceSetScreenSize(width, height int, scale float64, fullscreen bool, vsync bool) { // On Windows, giving a too small width doesn't call a callback (#165). // To prevent hanging up, return asap if the width is too small. // 252 is an arbitrary number and I guess this is small enough. @@ -746,5 +754,4 @@ func (u *userInterface) setScreenSize(width, height int, scale float64, fullscre } u.toChangeSize = true - return true }