mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2024-12-25 03:08:54 +01:00
Revert "ui: Bug fix: SetVsyncEnabled before Run didn't work on macOS"
This reverts commit 042b30a516
.
This commit is contained in:
parent
7956e0ebbc
commit
c76ce28065
@ -233,11 +233,10 @@ type Driver struct {
|
|||||||
src *Image
|
src *Image
|
||||||
dst *Image
|
dst *Image
|
||||||
|
|
||||||
vsync bool
|
|
||||||
maxImageSize int
|
maxImageSize int
|
||||||
}
|
}
|
||||||
|
|
||||||
var theDriver = Driver{vsync: true}
|
var theDriver Driver
|
||||||
|
|
||||||
func Get() *Driver {
|
func Get() *Driver {
|
||||||
return &theDriver
|
return &theDriver
|
||||||
@ -396,7 +395,7 @@ func (d *Driver) Reset() error {
|
|||||||
// MTLPixelFormatBGRA10_XR_sRGB.
|
// MTLPixelFormatBGRA10_XR_sRGB.
|
||||||
d.ml.SetPixelFormat(mtl.PixelFormatBGRA8UNorm)
|
d.ml.SetPixelFormat(mtl.PixelFormatBGRA8UNorm)
|
||||||
d.ml.SetMaximumDrawableCount(3)
|
d.ml.SetMaximumDrawableCount(3)
|
||||||
d.ml.SetDisplaySyncEnabled(d.vsync)
|
d.ml.SetDisplaySyncEnabled(true)
|
||||||
|
|
||||||
replaces := map[string]string{
|
replaces := map[string]string{
|
||||||
"{{.FilterNearest}}": fmt.Sprintf("%d", graphics.FilterNearest),
|
"{{.FilterNearest}}": fmt.Sprintf("%d", graphics.FilterNearest),
|
||||||
@ -571,11 +570,7 @@ func (d *Driver) ResetSource() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (d *Driver) SetVsyncEnabled(enabled bool) {
|
func (d *Driver) SetVsyncEnabled(enabled bool) {
|
||||||
mainthread.Run(func() error {
|
|
||||||
d.ml.SetDisplaySyncEnabled(enabled)
|
d.ml.SetDisplaySyncEnabled(enabled)
|
||||||
d.vsync = enabled
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *Driver) VDirection() graphicsdriver.VDirection {
|
func (d *Driver) VDirection() graphicsdriver.VDirection {
|
||||||
|
@ -14,39 +14,16 @@
|
|||||||
|
|
||||||
package mainthread
|
package mainthread
|
||||||
|
|
||||||
import (
|
var funcs = make(chan func())
|
||||||
"runtime"
|
|
||||||
"sync"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
funcs chan func()
|
|
||||||
running bool
|
|
||||||
|
|
||||||
m sync.Mutex
|
|
||||||
)
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
runtime.LockOSThread()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Loop starts the main-thread loop.
|
// Loop starts the main-thread loop.
|
||||||
//
|
//
|
||||||
// Loop must be called on the main thread.
|
// Loop must be called on the main thread.
|
||||||
func Loop(ch <-chan error) error {
|
func Loop(ch <-chan error) error {
|
||||||
m.Lock()
|
|
||||||
funcs = make(chan func())
|
|
||||||
m.Unlock()
|
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case f := <-funcs:
|
case f := <-funcs:
|
||||||
m.Lock()
|
|
||||||
running = true
|
|
||||||
m.Unlock()
|
|
||||||
f()
|
f()
|
||||||
m.Lock()
|
|
||||||
running = false
|
|
||||||
m.Unlock()
|
|
||||||
case err := <-ch:
|
case err := <-ch:
|
||||||
// ch returns a value not only when an error occur but also it is closed.
|
// ch returns a value not only when an error occur but also it is closed.
|
||||||
return err
|
return err
|
||||||
@ -55,19 +32,7 @@ func Loop(ch <-chan error) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Run calls f on the main thread.
|
// Run calls f on the main thread.
|
||||||
//
|
|
||||||
// Run can be called even before Loop is called.
|
|
||||||
//
|
|
||||||
// Run can be called recursively: Run can be called from the function that are called via Run.
|
|
||||||
func Run(f func() error) error {
|
func Run(f func() error) error {
|
||||||
// Even if funcs is nil, Run is called from the main thread (e.g. init)
|
|
||||||
m.Lock()
|
|
||||||
now := funcs == nil || running
|
|
||||||
m.Unlock()
|
|
||||||
if now {
|
|
||||||
return f()
|
|
||||||
}
|
|
||||||
|
|
||||||
ch := make(chan struct{})
|
ch := make(chan struct{})
|
||||||
var err error
|
var err error
|
||||||
funcs <- func() {
|
funcs <- func() {
|
||||||
|
@ -76,6 +76,7 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
runtime.LockOSThread()
|
||||||
hideConsoleWindowOnWindows()
|
hideConsoleWindowOnWindows()
|
||||||
if err := initialize(); err != nil {
|
if err := initialize(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
Loading…
Reference in New Issue
Block a user