mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 18:52:44 +01:00
parent
22e64c7df0
commit
e6f2764d08
@ -63,7 +63,6 @@ type UserInterface struct {
|
|||||||
maxWindowHeightInDIP int
|
maxWindowHeightInDIP int
|
||||||
|
|
||||||
running uint32
|
running uint32
|
||||||
toChangeSize bool
|
|
||||||
origPosX int
|
origPosX int
|
||||||
origPosY int
|
origPosY int
|
||||||
runnableOnUnfocused bool
|
runnableOnUnfocused bool
|
||||||
@ -771,15 +770,10 @@ func (u *UserInterface) registerWindowSetSizeCallback() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if err := u.runOnAnotherThreadFromMainThread(func() error {
|
if err := u.runOnAnotherThreadFromMainThread(func() error {
|
||||||
// toChangeSize affects the result of updateSize (#1884).
|
|
||||||
// TODO: Remove toChangeSize to simplify the logic.
|
|
||||||
u.toChangeSize = true
|
|
||||||
|
|
||||||
// Disable Vsync temporarily. On macOS, getting a next frame can get stuck (#1740).
|
// Disable Vsync temporarily. On macOS, getting a next frame can get stuck (#1740).
|
||||||
u.Graphics().SetVsyncEnabled(false)
|
u.Graphics().SetVsyncEnabled(false)
|
||||||
|
|
||||||
var outsideWidth, outsideHeight float64
|
var outsideWidth, outsideHeight float64
|
||||||
var outsideSizeChanged bool
|
|
||||||
|
|
||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
if width != 0 || height != 0 {
|
if width != 0 || height != 0 {
|
||||||
@ -788,12 +782,10 @@ func (u *UserInterface) registerWindowSetSizeCallback() {
|
|||||||
u.setWindowSizeInDIP(w, h, u.isFullscreen())
|
u.setWindowSizeInDIP(w, h, u.isFullscreen())
|
||||||
}
|
}
|
||||||
|
|
||||||
outsideWidth, outsideHeight, outsideSizeChanged = u.updateSize()
|
outsideWidth, outsideHeight = u.updateSize()
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if outsideSizeChanged {
|
u.context.Layout(outsideWidth, outsideHeight)
|
||||||
u.context.Layout(outsideWidth, outsideHeight)
|
|
||||||
}
|
|
||||||
if err := u.context.ForceUpdateFrame(); err != nil {
|
if err := u.context.ForceUpdateFrame(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -962,15 +954,10 @@ func (u *UserInterface) init() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) updateSize() (float64, float64, bool) {
|
func (u *UserInterface) updateSize() (float64, float64) {
|
||||||
ww, wh := u.windowWidthInDIP, u.windowHeightInDIP
|
ww, wh := u.windowWidthInDIP, u.windowHeightInDIP
|
||||||
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
|
|
||||||
if !u.toChangeSize {
|
|
||||||
return 0, 0, false
|
|
||||||
}
|
|
||||||
u.toChangeSize = false
|
|
||||||
|
|
||||||
var w, h float64
|
var w, h float64
|
||||||
if u.isFullscreen() && !u.isNativeFullscreen() {
|
if u.isFullscreen() && !u.isNativeFullscreen() {
|
||||||
// On Linux, the window size is not reliable just after making the window
|
// On Linux, the window size is not reliable just after making the window
|
||||||
@ -991,7 +978,7 @@ func (u *UserInterface) updateSize() (float64, float64, bool) {
|
|||||||
h = u.dipFromGLFWPixel(float64(wh), u.currentMonitor())
|
h = u.dipFromGLFWPixel(float64(wh), u.currentMonitor())
|
||||||
}
|
}
|
||||||
|
|
||||||
return w, h, true
|
return w, h
|
||||||
}
|
}
|
||||||
|
|
||||||
// setFPSMode must be called from the main thread.
|
// setFPSMode must be called from the main thread.
|
||||||
@ -1008,13 +995,13 @@ func (u *UserInterface) setFPSMode(fpsMode driver.FPSMode) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update must be called from the main thread.
|
// update must be called from the main thread.
|
||||||
func (u *UserInterface) update() (float64, float64, bool, error) {
|
func (u *UserInterface) update() (float64, float64, error) {
|
||||||
if u.err != nil {
|
if u.err != nil {
|
||||||
return 0, 0, false, u.err
|
return 0, 0, u.err
|
||||||
}
|
}
|
||||||
|
|
||||||
if u.window.ShouldClose() {
|
if u.window.ShouldClose() {
|
||||||
return 0, 0, false, driver.RegularTermination
|
return 0, 0, driver.RegularTermination
|
||||||
}
|
}
|
||||||
|
|
||||||
if u.isInitFullscreen() {
|
if u.isInitFullscreen() {
|
||||||
@ -1036,7 +1023,7 @@ func (u *UserInterface) update() (float64, float64, bool, error) {
|
|||||||
// Also, when toggling to fullscreen, vsync state might be reset unexpectedly (#1787).
|
// Also, when toggling to fullscreen, vsync state might be reset unexpectedly (#1787).
|
||||||
u.updateVsync()
|
u.updateVsync()
|
||||||
|
|
||||||
outsideWidth, outsideHeight, outsideSizeChanged := u.updateSize()
|
outsideWidth, outsideHeight := u.updateSize()
|
||||||
|
|
||||||
if u.fpsMode != driver.FPSModeVsyncOffMinimum {
|
if u.fpsMode != driver.FPSModeVsyncOffMinimum {
|
||||||
// TODO: Updating the input can be skipped when clock.Update returns 0 (#1367).
|
// TODO: Updating the input can be skipped when clock.Update returns 0 (#1367).
|
||||||
@ -1048,17 +1035,17 @@ func (u *UserInterface) update() (float64, float64, bool, error) {
|
|||||||
|
|
||||||
for !u.isRunnableOnUnfocused() && u.window.GetAttrib(glfw.Focused) == 0 && !u.window.ShouldClose() {
|
for !u.isRunnableOnUnfocused() && u.window.GetAttrib(glfw.Focused) == 0 && !u.window.ShouldClose() {
|
||||||
if err := hooks.SuspendAudio(); err != nil {
|
if err := hooks.SuspendAudio(); err != nil {
|
||||||
return 0, 0, false, err
|
return 0, 0, err
|
||||||
}
|
}
|
||||||
// Wait for an arbitrary period to avoid busy loop.
|
// Wait for an arbitrary period to avoid busy loop.
|
||||||
time.Sleep(time.Second / 60)
|
time.Sleep(time.Second / 60)
|
||||||
glfw.PollEvents()
|
glfw.PollEvents()
|
||||||
}
|
}
|
||||||
if err := hooks.ResumeAudio(); err != nil {
|
if err := hooks.ResumeAudio(); err != nil {
|
||||||
return 0, 0, false, err
|
return 0, 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return outsideWidth, outsideHeight, outsideSizeChanged, nil
|
return outsideWidth, outsideHeight, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) loop() error {
|
func (u *UserInterface) loop() error {
|
||||||
@ -1086,17 +1073,14 @@ func (u *UserInterface) loop() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var outsideWidth, outsideHeight float64
|
var outsideWidth, outsideHeight float64
|
||||||
var outsideSizeChanged bool
|
|
||||||
if err := u.t.Call(func() error {
|
if err := u.t.Call(func() error {
|
||||||
var err error
|
var err error
|
||||||
outsideWidth, outsideHeight, outsideSizeChanged, err = u.update()
|
outsideWidth, outsideHeight, err = u.update()
|
||||||
return err
|
return err
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if outsideSizeChanged {
|
u.context.Layout(outsideWidth, outsideHeight)
|
||||||
u.context.Layout(outsideWidth, outsideHeight)
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := u.context.UpdateFrame(); err != nil {
|
if err := u.context.UpdateFrame(); err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1260,8 +1244,6 @@ func (u *UserInterface) setWindowSizeInDIP(width, height int, fullscreen bool) {
|
|||||||
u.windowWidthInDIP = width
|
u.windowWidthInDIP = width
|
||||||
u.windowHeightInDIP = height
|
u.windowHeightInDIP = height
|
||||||
|
|
||||||
u.toChangeSize = true
|
|
||||||
|
|
||||||
if windowRecreated {
|
if windowRecreated {
|
||||||
if g, ok := u.Graphics().(interface{ SetWindow(uintptr) }); ok {
|
if g, ok := u.Graphics().(interface{ SetWindow(uintptr) }); ok {
|
||||||
g.SetWindow(u.nativeWindow())
|
g.SetWindow(u.nativeWindow())
|
||||||
@ -1453,14 +1435,11 @@ func (u *UserInterface) IsScreenTransparent() bool {
|
|||||||
func (u *UserInterface) ResetForFrame() {
|
func (u *UserInterface) ResetForFrame() {
|
||||||
// The offscreens must be updated every frame (#490).
|
// The offscreens must be updated every frame (#490).
|
||||||
var w, h float64
|
var w, h float64
|
||||||
var changed bool
|
|
||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
w, h, changed = u.updateSize()
|
w, h = u.updateSize()
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if changed {
|
u.context.Layout(w, h)
|
||||||
u.context.Layout(w, h)
|
|
||||||
}
|
|
||||||
u.input.resetForFrame()
|
u.input.resetForFrame()
|
||||||
|
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
|
Loading…
Reference in New Issue
Block a user