mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
ui: Use the best suitable monitor for fullscreen
This change also changes the definition of MonitorSize.
This commit is contained in:
parent
16f6aeaa4a
commit
cae9e39453
@ -233,8 +233,15 @@ func (u *userInterface) runOnMainThread(f func() error) error {
|
||||
}
|
||||
|
||||
func MonitorSize() (int, int) {
|
||||
m := glfw.GetPrimaryMonitor()
|
||||
v := m.GetVideoMode()
|
||||
var v *glfw.VidMode
|
||||
if currentUI.isRunning() {
|
||||
_ = currentUI.runOnMainThread(func() error {
|
||||
v = currentUI.currentMonitor().GetVideoMode()
|
||||
return nil
|
||||
})
|
||||
} else {
|
||||
v = glfw.GetPrimaryMonitor().GetVideoMode()
|
||||
}
|
||||
return v.Width, v.Height
|
||||
}
|
||||
|
||||
@ -493,8 +500,7 @@ func Run(width, height int, scale float64, title string, g GraphicsContext, main
|
||||
// swapping buffers.
|
||||
opengl.Init(currentUI.runOnMainThread)
|
||||
_ = u.runOnMainThread(func() error {
|
||||
m := glfw.GetPrimaryMonitor()
|
||||
v := m.GetVideoMode()
|
||||
v := u.currentMonitor().GetVideoMode()
|
||||
|
||||
// The game is in window mode (not fullscreen mode) at the first state.
|
||||
// Don't refer u.initFullscreen here to avoid some GLFW problems.
|
||||
@ -703,7 +709,7 @@ func (u *userInterface) forceSetScreenSize(width, height int, scale float64, ful
|
||||
if u.origPosX < 0 && u.origPosY < 0 {
|
||||
u.origPosX, u.origPosY = u.window.GetPos()
|
||||
}
|
||||
m := glfw.GetPrimaryMonitor()
|
||||
m := u.currentMonitor()
|
||||
v := m.GetVideoMode()
|
||||
u.window.SetMonitor(m, 0, 0, v.Width, v.Height, v.RefreshRate)
|
||||
} else {
|
||||
@ -753,3 +759,32 @@ func (u *userInterface) forceSetScreenSize(width, height int, scale float64, ful
|
||||
|
||||
u.toChangeSize = true
|
||||
}
|
||||
|
||||
// currentMonitor returns the monitor nearest from the current window.
|
||||
//
|
||||
// currentMonitor must be called on the main thread.
|
||||
func (u *userInterface) currentMonitor() *glfw.Monitor {
|
||||
w := u.window
|
||||
if m := w.GetMonitor(); m != nil {
|
||||
return m
|
||||
}
|
||||
|
||||
wx, wy := w.GetPos()
|
||||
ww, wh := w.GetSize()
|
||||
wr := image.Rect(wx, wy, wx+ww, wy+wh)
|
||||
|
||||
best := 0
|
||||
var current *glfw.Monitor
|
||||
for _, m := range glfw.GetMonitors() {
|
||||
mx, my := m.GetPos()
|
||||
v := m.GetVideoMode()
|
||||
mr := image.Rect(mx, my, mx+v.Width, my+v.Height)
|
||||
overlap := wr.Intersect(mr)
|
||||
area := overlap.Dx() * overlap.Dy()
|
||||
if area > best {
|
||||
current = m
|
||||
best = area
|
||||
}
|
||||
}
|
||||
return current
|
||||
}
|
||||
|
6
run.go
6
run.go
@ -317,6 +317,9 @@ func RunWithoutMainLoop(f func(*Image) error, width, height int, scale float64,
|
||||
}
|
||||
|
||||
// MonitorSize returns the monitor size in device-independent pixels.
|
||||
// The adopted monitor is the 'current' monitor that includes the biggest area of the window.
|
||||
// However, if the window doesn't exist, MonitorSize returns the 'primary' monitor,
|
||||
// where the taskbar exists on Windows for example.
|
||||
//
|
||||
// On browsers, MonitorSize returns the 'window' size, not 'screen' size since an Ebiten game
|
||||
// should not know the outside of the window object.
|
||||
@ -324,9 +327,6 @@ func RunWithoutMainLoop(f func(*Image) error, width, height int, scale float64,
|
||||
//
|
||||
// On mobiles, MonitorSize returns (0, 0) so far.
|
||||
//
|
||||
// Note that MonitorSize returns the 'primary' monitor size, which is the monitor
|
||||
// where taskbar is present (Windows) or menubar is present (macOS).
|
||||
//
|
||||
// If you use this for screen size with SetFullscreen(true), you can get the fullscreen mode
|
||||
// which size is well adjusted with the monitor.
|
||||
//
|
||||
|
Loading…
Reference in New Issue
Block a user