mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 04:22:05 +01:00
uidriver/js: Bug fix: context must not be accessed before loop
This commit is contained in:
parent
4907cee128
commit
30c185f254
@ -222,7 +222,7 @@ func (u *UserInterface) update() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) loop(context driver.UIContext) <-chan error {
|
func (u *UserInterface) loop(context driver.UIContext) <-chan error {
|
||||||
u.context = context
|
u.init(context)
|
||||||
|
|
||||||
ch := make(chan error)
|
ch := make(chan error)
|
||||||
var cf js.Func
|
var cf js.Func
|
||||||
@ -253,6 +253,37 @@ func (u *UserInterface) loop(context driver.UIContext) <-chan error {
|
|||||||
return ch
|
return ch
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (u *UserInterface) init(context driver.UIContext) {
|
||||||
|
u.context = context
|
||||||
|
window.Call("addEventListener", "focus", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
|
u.windowFocus = true
|
||||||
|
if u.suspended() {
|
||||||
|
u.context.SuspendAudio()
|
||||||
|
} else {
|
||||||
|
u.context.ResumeAudio()
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}))
|
||||||
|
window.Call("addEventListener", "blur", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
|
u.windowFocus = false
|
||||||
|
if u.suspended() {
|
||||||
|
u.context.SuspendAudio()
|
||||||
|
} else {
|
||||||
|
u.context.ResumeAudio()
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}))
|
||||||
|
document.Call("addEventListener", "visibilitychange", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
|
u.pageVisible = !document.Get("hidden").Bool()
|
||||||
|
if u.suspended() {
|
||||||
|
u.context.SuspendAudio()
|
||||||
|
} else {
|
||||||
|
u.context.ResumeAudio()
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}))
|
||||||
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
if document.Get("body") == js.Null() {
|
if document.Get("body") == js.Null() {
|
||||||
ch := make(chan struct{})
|
ch := make(chan struct{})
|
||||||
@ -263,33 +294,6 @@ func init() {
|
|||||||
<-ch
|
<-ch
|
||||||
}
|
}
|
||||||
|
|
||||||
window.Call("addEventListener", "focus", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
|
||||||
theUI.windowFocus = true
|
|
||||||
if theUI.suspended() {
|
|
||||||
theUI.context.SuspendAudio()
|
|
||||||
} else {
|
|
||||||
theUI.context.ResumeAudio()
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}))
|
|
||||||
window.Call("addEventListener", "blur", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
|
||||||
theUI.windowFocus = false
|
|
||||||
if theUI.suspended() {
|
|
||||||
theUI.context.SuspendAudio()
|
|
||||||
} else {
|
|
||||||
theUI.context.ResumeAudio()
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}))
|
|
||||||
document.Call("addEventListener", "visibilitychange", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
|
||||||
theUI.pageVisible = !document.Get("hidden").Bool()
|
|
||||||
if theUI.suspended() {
|
|
||||||
theUI.context.SuspendAudio()
|
|
||||||
} else {
|
|
||||||
theUI.context.ResumeAudio()
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}))
|
|
||||||
window.Call("addEventListener", "resize", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
window.Call("addEventListener", "resize", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
theUI.updateScreenSize()
|
theUI.updateScreenSize()
|
||||||
return nil
|
return nil
|
||||||
|
Loading…
Reference in New Issue
Block a user