mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 20:42:07 +01:00
internal/ui: refactoring: unify duplicated logics to initialize the window size and position
This commit is contained in:
parent
b95228a8a6
commit
c16bd1e249
@ -216,6 +216,12 @@ func (u *userInterfaceImpl) setInitMonitor(m *Monitor) {
|
|||||||
u.initFullscreenHeightInDIP = int(u.dipFromGLFWMonitorPixel(float64(v.Height), m))
|
u.initFullscreenHeightInDIP = int(u.dipFromGLFWMonitorPixel(float64(v.Height), m))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (u *userInterfaceImpl) getInitMonitor() *Monitor {
|
||||||
|
u.m.Lock()
|
||||||
|
defer u.m.Unlock()
|
||||||
|
return u.initMonitor
|
||||||
|
}
|
||||||
|
|
||||||
// AppendMonitors appends the current monitors to the passed in mons slice and returns it.
|
// AppendMonitors appends the current monitors to the passed in mons slice and returns it.
|
||||||
func (u *userInterfaceImpl) AppendMonitors(monitors []*Monitor) []*Monitor {
|
func (u *userInterfaceImpl) AppendMonitors(monitors []*Monitor) []*Monitor {
|
||||||
return theMonitors.append(monitors)
|
return theMonitors.append(monitors)
|
||||||
@ -772,35 +778,45 @@ func init() {
|
|||||||
|
|
||||||
// createWindow creates a GLFW window.
|
// createWindow creates a GLFW window.
|
||||||
//
|
//
|
||||||
// width and height are in GLFW pixels (not device-independent pixels).
|
|
||||||
//
|
|
||||||
// createWindow must be called from the main thread.
|
// createWindow must be called from the main thread.
|
||||||
//
|
func (u *userInterfaceImpl) createWindow() error {
|
||||||
// createWindow does not set the position or size so far.
|
|
||||||
func (u *userInterfaceImpl) createWindow(width, height int, monitor *Monitor) error {
|
|
||||||
if u.window != nil {
|
if u.window != nil {
|
||||||
panic("ui: u.window must not exist at createWindow")
|
panic("ui: u.window must not exist at createWindow")
|
||||||
}
|
}
|
||||||
|
|
||||||
// As a start, create a window with temporary size to create OpenGL context thread.
|
monitor := u.getInitMonitor()
|
||||||
|
ww, wh := u.getInitWindowSizeInDIP()
|
||||||
|
width := int(u.dipToGLFWPixel(float64(ww), monitor))
|
||||||
|
height := int(u.dipToGLFWPixel(float64(wh), monitor))
|
||||||
window, err := glfw.CreateWindow(width, height, "", nil, nil)
|
window, err := glfw.CreateWindow(width, height, "", nil, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
u.window = window
|
||||||
|
|
||||||
// Set our target monitor if provided. This is required to prevent an initial window flash on the default monitor.
|
// The position must be set before the size is set (#1982).
|
||||||
vm := monitor.videoMode
|
// setWindowSize refers the current monitor's device scale.
|
||||||
mw := u.dipFromGLFWMonitorPixel(float64(vm.Width), monitor)
|
wx, wy := u.getInitWindowPositionInDIP()
|
||||||
mh := u.dipFromGLFWMonitorPixel(float64(vm.Height), monitor)
|
// Force to put the window in the initial monitor (#1575).
|
||||||
mw = u.dipToGLFWPixel(mw, monitor)
|
if wx < 0 {
|
||||||
mh = u.dipToGLFWPixel(mh, monitor)
|
wx = 0
|
||||||
px, py := InitialWindowPosition(int(mw), int(mh), width, height)
|
}
|
||||||
window.SetPos(monitor.x+px, monitor.y+py)
|
if wy < 0 {
|
||||||
|
wy = 0
|
||||||
|
}
|
||||||
|
if max := u.initFullscreenWidthInDIP - ww; wx >= max {
|
||||||
|
wx = max
|
||||||
|
}
|
||||||
|
if max := u.initFullscreenHeightInDIP - wh; wy >= max {
|
||||||
|
wy = max
|
||||||
|
}
|
||||||
|
u.setWindowPositionInDIP(wx, wy, monitor)
|
||||||
|
|
||||||
|
// Though the size is already specified, call setWindowSizeInDIP explicitly to adjust member variables.
|
||||||
|
u.setWindowSizeInDIP(ww, wh, true)
|
||||||
|
|
||||||
initializeWindowAfterCreation(window)
|
initializeWindowAfterCreation(window)
|
||||||
|
|
||||||
u.window = window
|
|
||||||
|
|
||||||
// Even just after a window creation, FramebufferSize callback might be invoked (#1847).
|
// Even just after a window creation, FramebufferSize callback might be invoked (#1847).
|
||||||
// Ensure to consume this callback.
|
// Ensure to consume this callback.
|
||||||
u.waitForFramebufferSizeCallback(u.window, nil)
|
u.waitForFramebufferSizeCallback(u.window, nil)
|
||||||
@ -990,33 +1006,10 @@ func (u *userInterfaceImpl) initOnMainThread(options *RunOptions) error {
|
|||||||
glfw.WindowHint(glfw.Visible, glfw.True)
|
glfw.WindowHint(glfw.Visible, glfw.True)
|
||||||
}
|
}
|
||||||
|
|
||||||
ww, wh := u.getInitWindowSizeInDIP()
|
if err := u.createWindow(); err != nil {
|
||||||
initW := int(u.dipToGLFWPixel(float64(ww), u.initMonitor))
|
|
||||||
initH := int(u.dipToGLFWPixel(float64(wh), u.initMonitor))
|
|
||||||
if err := u.createWindow(initW, initH, u.initMonitor); err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// The position must be set before the size is set (#1982).
|
|
||||||
// setWindowSize refers the current monitor's device scale.
|
|
||||||
// TODO: The window position is already set at createWindow. Unify the logic.
|
|
||||||
wx, wy := u.getInitWindowPositionInDIP()
|
|
||||||
// Force to put the window in the initial monitor (#1575).
|
|
||||||
if wx < 0 {
|
|
||||||
wx = 0
|
|
||||||
}
|
|
||||||
if wy < 0 {
|
|
||||||
wy = 0
|
|
||||||
}
|
|
||||||
if max := u.initFullscreenWidthInDIP - ww; wx >= max {
|
|
||||||
wx = max
|
|
||||||
}
|
|
||||||
if max := u.initFullscreenHeightInDIP - wh; wy >= max {
|
|
||||||
wy = max
|
|
||||||
}
|
|
||||||
u.setWindowPositionInDIP(wx, wy, u.initMonitor)
|
|
||||||
u.setWindowSizeInDIP(ww, wh, true)
|
|
||||||
|
|
||||||
// Maximizing a window requires a proper size and position. Call Maximize here (#1117).
|
// Maximizing a window requires a proper size and position. Call Maximize here (#1117).
|
||||||
if u.isInitWindowMaximized() {
|
if u.isInitWindowMaximized() {
|
||||||
u.window.Maximize()
|
u.window.Maximize()
|
||||||
@ -1509,7 +1502,7 @@ func (u *userInterfaceImpl) updateVsyncOnRenderThread() {
|
|||||||
// currentMonitor must be called on the main thread.
|
// currentMonitor must be called on the main thread.
|
||||||
func (u *userInterfaceImpl) currentMonitor() *Monitor {
|
func (u *userInterfaceImpl) currentMonitor() *Monitor {
|
||||||
if u.window == nil {
|
if u.window == nil {
|
||||||
return u.initMonitor
|
return u.getInitMonitor()
|
||||||
}
|
}
|
||||||
if m := monitorFromWindow(u.window); m != nil {
|
if m := monitorFromWindow(u.window); m != nil {
|
||||||
return m
|
return m
|
||||||
|
Loading…
Reference in New Issue
Block a user