mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 12:32:05 +01:00
loop: Simplify logic
This commit is contained in:
parent
4ee0c9b482
commit
b85f5edee0
@ -80,25 +80,24 @@ func (c *runContext) updateFPS(fps float64) {
|
|||||||
c.m.Unlock()
|
c.m.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
type Runner interface {
|
func Start() error {
|
||||||
Run(width, height int, scale float64, title string) error
|
|
||||||
}
|
|
||||||
|
|
||||||
func Run(runner Runner, width, height int, scale float64, title string) (err error) {
|
|
||||||
if currentRunContext != nil {
|
if currentRunContext != nil {
|
||||||
return errors.New("loop: The game is already running")
|
return errors.New("loop: The game is already running")
|
||||||
}
|
}
|
||||||
currentRunContext = &runContext{}
|
currentRunContext = &runContext{}
|
||||||
currentRunContext.startRunning()
|
currentRunContext.startRunning()
|
||||||
defer currentRunContext.endRunning()
|
|
||||||
|
|
||||||
n := now()
|
n := now()
|
||||||
currentRunContext.lastUpdated = n
|
currentRunContext.lastUpdated = n
|
||||||
currentRunContext.lastFPSUpdated = n
|
currentRunContext.lastFPSUpdated = n
|
||||||
|
|
||||||
close(contextInitCh)
|
close(contextInitCh)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
return runner.Run(width, height, scale, title)
|
func End() {
|
||||||
|
currentRunContext.endRunning()
|
||||||
|
currentRunContext = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *runContext) updateCount(now int64) int {
|
func (c *runContext) updateCount(now int64) int {
|
||||||
|
32
run.go
32
run.go
@ -60,12 +60,8 @@ func IsRunningSlowly() bool {
|
|||||||
|
|
||||||
var theGraphicsContext atomic.Value
|
var theGraphicsContext atomic.Value
|
||||||
|
|
||||||
type runner struct {
|
func run(width, height int, scale float64, title string, g *graphicsContext) error {
|
||||||
g *graphicsContext
|
if err := ui.Run(width, height, scale, title, &updater{g}); err != nil {
|
||||||
}
|
|
||||||
|
|
||||||
func (r *runner) Run(width, height int, scale float64, title string) error {
|
|
||||||
if err := ui.Run(width, height, scale, title, &updater{r.g}); err != nil {
|
|
||||||
if _, ok := err.(*ui.RegularTermination); ok {
|
if _, ok := err.(*ui.RegularTermination); ok {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -110,13 +106,19 @@ func (u *updater) Invalidate() {
|
|||||||
func Run(f func(*Image) error, width, height int, scale float64, title string) error {
|
func Run(f func(*Image) error, width, height int, scale float64, title string) error {
|
||||||
ch := make(chan error)
|
ch := make(chan error)
|
||||||
go func() {
|
go func() {
|
||||||
|
defer close(ch)
|
||||||
|
|
||||||
g := newGraphicsContext(f)
|
g := newGraphicsContext(f)
|
||||||
theGraphicsContext.Store(g)
|
theGraphicsContext.Store(g)
|
||||||
r := &runner{g}
|
if err := loop.Start(); err != nil {
|
||||||
if err := loop.Run(r, width, height, scale, title); err != nil {
|
|
||||||
ch <- err
|
ch <- err
|
||||||
|
return
|
||||||
}
|
}
|
||||||
close(ch)
|
if err := run(width, height, scale, title, g); err != nil {
|
||||||
|
ch <- err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
loop.End()
|
||||||
}()
|
}()
|
||||||
// TODO: Use context in Go 1.7?
|
// TODO: Use context in Go 1.7?
|
||||||
if err := ui.RunMainThreadLoop(ch); err != nil {
|
if err := ui.RunMainThreadLoop(ch); err != nil {
|
||||||
@ -135,13 +137,19 @@ func Run(f func(*Image) error, width, height int, scale float64, title string) e
|
|||||||
func RunWithoutMainLoop(f func(*Image) error, width, height int, scale float64, title string) <-chan error {
|
func RunWithoutMainLoop(f func(*Image) error, width, height int, scale float64, title string) <-chan error {
|
||||||
ch := make(chan error)
|
ch := make(chan error)
|
||||||
go func() {
|
go func() {
|
||||||
|
defer close(ch)
|
||||||
|
|
||||||
g := newGraphicsContext(f)
|
g := newGraphicsContext(f)
|
||||||
theGraphicsContext.Store(g)
|
theGraphicsContext.Store(g)
|
||||||
r := &runner{g}
|
if err := loop.Start(); err != nil {
|
||||||
if err := loop.Run(r, width, height, scale, title); err != nil {
|
|
||||||
ch <- err
|
ch <- err
|
||||||
|
return
|
||||||
}
|
}
|
||||||
close(ch)
|
if err := run(width, height, scale, title, g); err != nil {
|
||||||
|
ch <- err
|
||||||
|
return
|
||||||
|
}
|
||||||
|
loop.End()
|
||||||
}()
|
}()
|
||||||
return ch
|
return ch
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user