mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 04:22:05 +01:00
ui: Add function aliases *OnUnfocused for *InBackground
Now a window can be floating with SetWindowFloating, the functions that have suffix 'IsBackground' seems misleading. However, we cannot rename them due to backward compatibility. Then, let's add aliases and revisit them when updating the major version of Ebiten. Fixes #1102
This commit is contained in:
parent
56358fd0c4
commit
978ee26898
@ -163,9 +163,9 @@ func (p *Player) update() error {
|
|||||||
p.playSEIfNeeded()
|
p.playSEIfNeeded()
|
||||||
p.updateVolumeIfNeeded()
|
p.updateVolumeIfNeeded()
|
||||||
|
|
||||||
if inpututil.IsKeyJustPressed(ebiten.KeyB) {
|
if inpututil.IsKeyJustPressed(ebiten.KeyU) {
|
||||||
b := ebiten.IsRunnableInBackground()
|
b := ebiten.IsRunnableOnUnfocused()
|
||||||
ebiten.SetRunnableInBackground(!b)
|
ebiten.SetRunnableOnUnfocused(!b)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -252,7 +252,7 @@ func (p *Player) draw(screen *ebiten.Image) {
|
|||||||
Press S to toggle Play/Pause
|
Press S to toggle Play/Pause
|
||||||
Press P to play SE
|
Press P to play SE
|
||||||
Press Z or X to change volume of the music
|
Press Z or X to change volume of the music
|
||||||
Press B to switch the run-in-background state
|
Press U to switch the runnable-on-unfocused state
|
||||||
Press A to switch Ogg and MP3
|
Press A to switch Ogg and MP3
|
||||||
Current Time: %s
|
Current Time: %s
|
||||||
Current Volume: %d/128
|
Current Volume: %d/128
|
||||||
|
@ -131,7 +131,7 @@ func (g *game) Update(screen *ebiten.Image) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fullscreen := ebiten.IsFullscreen()
|
fullscreen := ebiten.IsFullscreen()
|
||||||
runnableInBackground := ebiten.IsRunnableInBackground()
|
runnableOnUnfocused := ebiten.IsRunnableOnUnfocused()
|
||||||
cursorVisible := ebiten.IsCursorVisible()
|
cursorVisible := ebiten.IsCursorVisible()
|
||||||
vsyncEnabled := ebiten.IsVsyncEnabled()
|
vsyncEnabled := ebiten.IsVsyncEnabled()
|
||||||
tps := ebiten.MaxTPS()
|
tps := ebiten.MaxTPS()
|
||||||
@ -194,8 +194,8 @@ func (g *game) Update(screen *ebiten.Image) error {
|
|||||||
if inpututil.IsKeyJustPressed(ebiten.KeyF) {
|
if inpututil.IsKeyJustPressed(ebiten.KeyF) {
|
||||||
fullscreen = !fullscreen
|
fullscreen = !fullscreen
|
||||||
}
|
}
|
||||||
if inpututil.IsKeyJustPressed(ebiten.KeyB) {
|
if inpututil.IsKeyJustPressed(ebiten.KeyU) {
|
||||||
runnableInBackground = !runnableInBackground
|
runnableOnUnfocused = !runnableOnUnfocused
|
||||||
}
|
}
|
||||||
if inpututil.IsKeyJustPressed(ebiten.KeyC) {
|
if inpututil.IsKeyJustPressed(ebiten.KeyC) {
|
||||||
cursorVisible = !cursorVisible
|
cursorVisible = !cursorVisible
|
||||||
@ -238,7 +238,7 @@ func (g *game) Update(screen *ebiten.Image) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
ebiten.SetFullscreen(fullscreen)
|
ebiten.SetFullscreen(fullscreen)
|
||||||
ebiten.SetRunnableInBackground(runnableInBackground)
|
ebiten.SetRunnableOnUnfocused(runnableOnUnfocused)
|
||||||
ebiten.SetCursorVisible(cursorVisible)
|
ebiten.SetCursorVisible(cursorVisible)
|
||||||
ebiten.SetVsyncEnabled(vsyncEnabled)
|
ebiten.SetVsyncEnabled(vsyncEnabled)
|
||||||
ebiten.SetMaxTPS(tps)
|
ebiten.SetMaxTPS(tps)
|
||||||
@ -294,7 +294,7 @@ func (g *game) Update(screen *ebiten.Image) error {
|
|||||||
msg := fmt.Sprintf(`Press arrow keys to move the window
|
msg := fmt.Sprintf(`Press arrow keys to move the window
|
||||||
Press shift + arrow keys to change the window size
|
Press shift + arrow keys to change the window size
|
||||||
%sPress F key to switch the fullscreen state (only for desktops)
|
%sPress F key to switch the fullscreen state (only for desktops)
|
||||||
Press B key to switch the run-in-background state
|
Press U key to switch the runnable-on-unfocused state
|
||||||
Press C key to switch the cursor visibility
|
Press C key to switch the cursor visibility
|
||||||
Press I key to change the window icon (only for desktops)
|
Press I key to change the window icon (only for desktops)
|
||||||
Press V key to switch vsync
|
Press V key to switch vsync
|
||||||
|
@ -38,7 +38,7 @@ type UI interface {
|
|||||||
CursorMode() CursorMode
|
CursorMode() CursorMode
|
||||||
IsFullscreen() bool
|
IsFullscreen() bool
|
||||||
IsFocused() bool
|
IsFocused() bool
|
||||||
IsRunnableInBackground() bool
|
IsRunnableOnUnfocused() bool
|
||||||
IsVsyncEnabled() bool
|
IsVsyncEnabled() bool
|
||||||
ScreenSizeInFullscreen() (int, int)
|
ScreenSizeInFullscreen() (int, int)
|
||||||
IsScreenTransparent() bool
|
IsScreenTransparent() bool
|
||||||
@ -46,7 +46,7 @@ type UI interface {
|
|||||||
|
|
||||||
SetCursorMode(mode CursorMode)
|
SetCursorMode(mode CursorMode)
|
||||||
SetFullscreen(fullscreen bool)
|
SetFullscreen(fullscreen bool)
|
||||||
SetRunnableInBackground(runnableInBackground bool)
|
SetRunnableOnUnfocused(runnableOnUnfocused bool)
|
||||||
SetVsyncEnabled(enabled bool)
|
SetVsyncEnabled(enabled bool)
|
||||||
SetScreenTransparent(transparent bool)
|
SetScreenTransparent(transparent bool)
|
||||||
|
|
||||||
|
@ -45,12 +45,12 @@ type UserInterface struct {
|
|||||||
windowWidth int
|
windowWidth int
|
||||||
windowHeight int
|
windowHeight int
|
||||||
|
|
||||||
running bool
|
running bool
|
||||||
toChangeSize bool
|
toChangeSize bool
|
||||||
origPosX int
|
origPosX int
|
||||||
origPosY int
|
origPosY int
|
||||||
runnableInBackground bool
|
runnableOnUnfocused bool
|
||||||
vsync bool
|
vsync bool
|
||||||
|
|
||||||
lastDeviceScaleFactor float64
|
lastDeviceScaleFactor float64
|
||||||
|
|
||||||
@ -253,16 +253,16 @@ func (u *UserInterface) setInitWindowDecorated(decorated bool) {
|
|||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) isRunnableInBackground() bool {
|
func (u *UserInterface) isRunnableOnUnfocused() bool {
|
||||||
u.m.RLock()
|
u.m.RLock()
|
||||||
v := u.runnableInBackground
|
v := u.runnableOnUnfocused
|
||||||
u.m.RUnlock()
|
u.m.RUnlock()
|
||||||
return v
|
return v
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) setRunnableInBackground(runnableInBackground bool) {
|
func (u *UserInterface) setRunnableOnUnfocused(runnableOnUnfocused bool) {
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
u.runnableInBackground = runnableInBackground
|
u.runnableOnUnfocused = runnableOnUnfocused
|
||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -429,12 +429,12 @@ func (u *UserInterface) IsFocused() bool {
|
|||||||
return focused
|
return focused
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetRunnableInBackground(runnableInBackground bool) {
|
func (u *UserInterface) SetRunnableOnUnfocused(runnableOnUnfocused bool) {
|
||||||
u.setRunnableInBackground(runnableInBackground)
|
u.setRunnableOnUnfocused(runnableOnUnfocused)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) IsRunnableInBackground() bool {
|
func (u *UserInterface) IsRunnableOnUnfocused() bool {
|
||||||
return u.isRunnableInBackground()
|
return u.isRunnableOnUnfocused()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetVsyncEnabled(enabled bool) {
|
func (u *UserInterface) SetVsyncEnabled(enabled bool) {
|
||||||
@ -757,7 +757,7 @@ func (u *UserInterface) update(context driver.UIContext) error {
|
|||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
defer hooks.ResumeAudio()
|
defer hooks.ResumeAudio()
|
||||||
|
|
||||||
for !u.isRunnableInBackground() && u.window.GetAttrib(glfw.Focused) == 0 {
|
for !u.isRunnableOnUnfocused() && u.window.GetAttrib(glfw.Focused) == 0 {
|
||||||
hooks.SuspendAudio()
|
hooks.SuspendAudio()
|
||||||
// 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)
|
||||||
|
@ -30,9 +30,9 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type UserInterface struct {
|
type UserInterface struct {
|
||||||
runnableInBackground bool
|
runnableOnUnfocused bool
|
||||||
vsync bool
|
vsync bool
|
||||||
running bool
|
running bool
|
||||||
|
|
||||||
sizeChanged bool
|
sizeChanged bool
|
||||||
contextLost bool
|
contextLost bool
|
||||||
@ -80,12 +80,12 @@ func (u *UserInterface) IsFocused() bool {
|
|||||||
return u.isFocused()
|
return u.isFocused()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetRunnableInBackground(runnableInBackground bool) {
|
func (u *UserInterface) SetRunnableOnUnfocused(runnableOnUnfocused bool) {
|
||||||
u.runnableInBackground = runnableInBackground
|
u.runnableOnUnfocused = runnableOnUnfocused
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) IsRunnableInBackground() bool {
|
func (u *UserInterface) IsRunnableOnUnfocused() bool {
|
||||||
return u.runnableInBackground
|
return u.runnableOnUnfocused
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetVsyncEnabled(enabled bool) {
|
func (u *UserInterface) SetVsyncEnabled(enabled bool) {
|
||||||
@ -142,7 +142,7 @@ func (u *UserInterface) updateSize() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) suspended() bool {
|
func (u *UserInterface) suspended() bool {
|
||||||
if u.runnableInBackground {
|
if u.runnableOnUnfocused {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return !u.isFocused()
|
return !u.isFocused()
|
||||||
|
@ -405,11 +405,11 @@ func (u *UserInterface) IsFocused() bool {
|
|||||||
return fg
|
return fg
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) IsRunnableInBackground() bool {
|
func (u *UserInterface) IsRunnableOnUnfocused() bool {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetRunnableInBackground(runnableInBackground bool) {
|
func (u *UserInterface) SetRunnableOnUnfocused(runnableOnUnfocused bool) {
|
||||||
// Do nothing
|
// Do nothing
|
||||||
}
|
}
|
||||||
|
|
||||||
|
32
run.go
32
run.go
@ -138,7 +138,7 @@ func IsRunningSlowly() bool {
|
|||||||
// This is not related to framerate (display's refresh rate).
|
// This is not related to framerate (display's refresh rate).
|
||||||
//
|
//
|
||||||
// f is not called when the window is in background by default.
|
// f is not called when the window is in background by default.
|
||||||
// This setting is configurable with SetRunnableInBackground.
|
// This setting is configurable with SetRunnableOnUnfocused.
|
||||||
//
|
//
|
||||||
// The given scale is ignored on fullscreen mode or gomobile-build mode.
|
// The given scale is ignored on fullscreen mode or gomobile-build mode.
|
||||||
//
|
//
|
||||||
@ -208,7 +208,7 @@ func (i *imageDumperGame) Layout(outsideWidth, outsideHeight int) (screenWidth,
|
|||||||
// This is not related to framerate (display's refresh rate).
|
// This is not related to framerate (display's refresh rate).
|
||||||
//
|
//
|
||||||
// game's Update is not called when the window is in background by default.
|
// game's Update is not called when the window is in background by default.
|
||||||
// This setting is configurable with SetRunnableInBackground.
|
// This setting is configurable with SetRunnableOnUnfocused.
|
||||||
//
|
//
|
||||||
// The given scale is ignored on fullscreen mode or gomobile-build mode.
|
// The given scale is ignored on fullscreen mode or gomobile-build mode.
|
||||||
//
|
//
|
||||||
@ -362,22 +362,27 @@ func SetFullscreen(fullscreen bool) {
|
|||||||
// IsFocused returns a boolean value indicating whether
|
// IsFocused returns a boolean value indicating whether
|
||||||
// the game is in focus or in the foreground.
|
// the game is in focus or in the foreground.
|
||||||
//
|
//
|
||||||
// IsFocused will only return true if IsRunnableInBackground is false.
|
// IsFocused will only return true if IsRunnableOnUnfocused is false.
|
||||||
//
|
//
|
||||||
// IsFocused is concurrent-safe.
|
// IsFocused is concurrent-safe.
|
||||||
func IsFocused() bool {
|
func IsFocused() bool {
|
||||||
return uiDriver().IsFocused()
|
return uiDriver().IsFocused()
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsRunnableInBackground returns a boolean value indicating whether
|
// IsRunnableOnUnfocused returns a boolean value indicating whether
|
||||||
// the game runs even in background.
|
// the game runs even in background.
|
||||||
//
|
//
|
||||||
// IsRunnableInBackground is concurrent-safe.
|
// IsRunnableOnUnfocused is concurrent-safe.
|
||||||
func IsRunnableInBackground() bool {
|
func IsRunnableOnUnfocused() bool {
|
||||||
return uiDriver().IsRunnableInBackground()
|
return uiDriver().IsRunnableOnUnfocused()
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetRunnableInBackground sets the state if the game runs even in background.
|
// IsRunnableInBackground is deprecated as of 1.11.0-alpha. Use IsRunnableOnUnfocused instead.
|
||||||
|
func IsRunnableInBackground() bool {
|
||||||
|
return IsRunnableOnUnfocused()
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetRunnableOnUnfocused sets the state if the game runs even in background.
|
||||||
//
|
//
|
||||||
// If the given value is true, the game runs in background e.g. when losing focus.
|
// If the given value is true, the game runs in background e.g. when losing focus.
|
||||||
// The initial state is false.
|
// The initial state is false.
|
||||||
@ -385,11 +390,16 @@ func IsRunnableInBackground() bool {
|
|||||||
// Known issue: On browsers, even if the state is on, the game doesn't run in background tabs.
|
// Known issue: On browsers, even if the state is on, the game doesn't run in background tabs.
|
||||||
// This is because browsers throttles background tabs not to often update.
|
// This is because browsers throttles background tabs not to often update.
|
||||||
//
|
//
|
||||||
// SetRunnableInBackground does nothing on mobiles so far.
|
// SetRunnableOnUnfocused does nothing on mobiles so far.
|
||||||
//
|
//
|
||||||
// SetRunnableInBackground is concurrent-safe.
|
// SetRunnableOnUnfocused is concurrent-safe.
|
||||||
|
func SetRunnableOnUnfocused(runnableOnUnfocused bool) {
|
||||||
|
uiDriver().SetRunnableOnUnfocused(runnableOnUnfocused)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetRunnableInBackground is deprecated as of 1.11.0-alpha. Use SetRunnableOnUnfocused instead.
|
||||||
func SetRunnableInBackground(runnableInBackground bool) {
|
func SetRunnableInBackground(runnableInBackground bool) {
|
||||||
uiDriver().SetRunnableInBackground(runnableInBackground)
|
SetRunnableOnUnfocused(runnableInBackground)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeviceScaleFactor returns a device scale factor value of the current monitor which the window belongs to.
|
// DeviceScaleFactor returns a device scale factor value of the current monitor which the window belongs to.
|
||||||
|
Loading…
Reference in New Issue
Block a user