mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
internal/uidriver/glfw: Refactring: Rename InDP -> InDIP
This change also renames some functions and variables.
This commit is contained in:
parent
da6b75bc6d
commit
4580f9fa16
@ -306,8 +306,8 @@ func (i *Input) update(window *glfw.Window, context driver.UIContext) {
|
|||||||
// TODO: This is tricky. Rename the function?
|
// TODO: This is tricky. Rename the function?
|
||||||
m := i.ui.currentMonitor()
|
m := i.ui.currentMonitor()
|
||||||
s := i.ui.deviceScaleFactor(m)
|
s := i.ui.deviceScaleFactor(m)
|
||||||
cx = i.ui.fromGLFWPixel(cx, m)
|
cx = i.ui.dipFromGLFWPixel(cx, m)
|
||||||
cy = i.ui.fromGLFWPixel(cy, m)
|
cy = i.ui.dipFromGLFWPixel(cy, m)
|
||||||
cx, cy = context.AdjustPosition(cx, cy, s)
|
cx, cy = context.AdjustPosition(cx, cy, s)
|
||||||
|
|
||||||
// AdjustPosition can return NaN at the initialization.
|
// AdjustPosition can return NaN at the initialization.
|
||||||
|
@ -53,16 +53,16 @@ type UserInterface struct {
|
|||||||
title string
|
title string
|
||||||
window *glfw.Window
|
window *glfw.Window
|
||||||
|
|
||||||
// windowWidthInDP and windowHeightInDP represents a window size.
|
// windowWidthInDIP and windowHeightInDIP represents a window size.
|
||||||
// The units are device-independent pixels.
|
// The units are device-independent pixels.
|
||||||
windowWidthInDP int
|
windowWidthInDIP int
|
||||||
windowHeightInDP int
|
windowHeightInDIP int
|
||||||
|
|
||||||
// The units are device-independent pixels.
|
// The units are device-independent pixels.
|
||||||
minWindowWidthInDP int
|
minWindowWidthInDIP int
|
||||||
minWindowHeightInDP int
|
minWindowHeightInDIP int
|
||||||
maxWindowWidthInDP int
|
maxWindowWidthInDIP int
|
||||||
maxWindowHeightInDP int
|
maxWindowHeightInDIP int
|
||||||
|
|
||||||
running uint32
|
running uint32
|
||||||
toChangeSize bool
|
toChangeSize bool
|
||||||
@ -85,24 +85,24 @@ type UserInterface struct {
|
|||||||
|
|
||||||
// These values are not changed after initialized.
|
// These values are not changed after initialized.
|
||||||
// TODO: the fullscreen size should be updated when the initial window position is changed?
|
// TODO: the fullscreen size should be updated when the initial window position is changed?
|
||||||
initMonitor *glfw.Monitor
|
initMonitor *glfw.Monitor
|
||||||
initFullscreenWidthInDP int
|
initFullscreenWidthInDIP int
|
||||||
initFullscreenHeightInDP int
|
initFullscreenHeightInDIP int
|
||||||
|
|
||||||
initTitle string
|
initTitle string
|
||||||
initFPSMode driver.FPSMode
|
initFPSMode driver.FPSMode
|
||||||
initFullscreen bool
|
initFullscreen bool
|
||||||
initCursorMode driver.CursorMode
|
initCursorMode driver.CursorMode
|
||||||
initWindowDecorated bool
|
initWindowDecorated bool
|
||||||
initWindowResizable bool
|
initWindowResizable bool
|
||||||
initWindowPositionXInDP int
|
initWindowPositionXInDIP int
|
||||||
initWindowPositionYInDP int
|
initWindowPositionYInDIP int
|
||||||
initWindowWidthInDP int
|
initWindowWidthInDIP int
|
||||||
initWindowHeightInDP int
|
initWindowHeightInDIP int
|
||||||
initWindowFloating bool
|
initWindowFloating bool
|
||||||
initWindowMaximized bool
|
initWindowMaximized bool
|
||||||
initScreenTransparent bool
|
initScreenTransparent bool
|
||||||
initFocused bool
|
initFocused bool
|
||||||
|
|
||||||
fpsModeInited bool
|
fpsModeInited bool
|
||||||
|
|
||||||
@ -126,22 +126,22 @@ const (
|
|||||||
|
|
||||||
var (
|
var (
|
||||||
theUI = &UserInterface{
|
theUI = &UserInterface{
|
||||||
runnableOnUnfocused: true,
|
runnableOnUnfocused: true,
|
||||||
minWindowWidthInDP: glfw.DontCare,
|
minWindowWidthInDIP: glfw.DontCare,
|
||||||
minWindowHeightInDP: glfw.DontCare,
|
minWindowHeightInDIP: glfw.DontCare,
|
||||||
maxWindowWidthInDP: glfw.DontCare,
|
maxWindowWidthInDIP: glfw.DontCare,
|
||||||
maxWindowHeightInDP: glfw.DontCare,
|
maxWindowHeightInDIP: glfw.DontCare,
|
||||||
origPosX: invalidPos,
|
origPosX: invalidPos,
|
||||||
origPosY: invalidPos,
|
origPosY: invalidPos,
|
||||||
initFPSMode: driver.FPSModeVsyncOn,
|
initFPSMode: driver.FPSModeVsyncOn,
|
||||||
initCursorMode: driver.CursorModeVisible,
|
initCursorMode: driver.CursorModeVisible,
|
||||||
initWindowDecorated: true,
|
initWindowDecorated: true,
|
||||||
initWindowPositionXInDP: invalidPos,
|
initWindowPositionXInDIP: invalidPos,
|
||||||
initWindowPositionYInDP: invalidPos,
|
initWindowPositionYInDIP: invalidPos,
|
||||||
initWindowWidthInDP: 640,
|
initWindowWidthInDIP: 640,
|
||||||
initWindowHeightInDP: 480,
|
initWindowHeightInDIP: 480,
|
||||||
initFocused: true,
|
initFocused: true,
|
||||||
fpsMode: driver.FPSModeVsyncOn,
|
fpsMode: driver.FPSModeVsyncOn,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -190,8 +190,8 @@ func initialize() error {
|
|||||||
m := initialMonitor(w)
|
m := initialMonitor(w)
|
||||||
theUI.initMonitor = m
|
theUI.initMonitor = m
|
||||||
v := m.GetVideoMode()
|
v := m.GetVideoMode()
|
||||||
theUI.initFullscreenWidthInDP = int(theUI.fromGLFWMonitorPixel(float64(v.Width), m))
|
theUI.initFullscreenWidthInDIP = int(theUI.dipFromGLFWMonitorPixel(float64(v.Width), m))
|
||||||
theUI.initFullscreenHeightInDP = int(theUI.fromGLFWMonitorPixel(float64(v.Height), m))
|
theUI.initFullscreenHeightInDIP = int(theUI.dipFromGLFWMonitorPixel(float64(v.Height), m))
|
||||||
|
|
||||||
// Create system cursors. These cursors are destroyed at glfw.Terminate().
|
// Create system cursors. These cursors are destroyed at glfw.Terminate().
|
||||||
glfwSystemCursors[driver.CursorShapeDefault] = nil
|
glfwSystemCursors[driver.CursorShapeDefault] = nil
|
||||||
@ -269,22 +269,22 @@ func (u *UserInterface) setRunning(running bool) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) getWindowSizeLimitsInDP() (minw, minh, maxw, maxh int) {
|
func (u *UserInterface) getWindowSizeLimitsInDIP() (minw, minh, maxw, maxh int) {
|
||||||
u.m.RLock()
|
u.m.RLock()
|
||||||
defer u.m.RUnlock()
|
defer u.m.RUnlock()
|
||||||
return u.minWindowWidthInDP, u.minWindowHeightInDP, u.maxWindowWidthInDP, u.maxWindowHeightInDP
|
return u.minWindowWidthInDIP, u.minWindowHeightInDIP, u.maxWindowWidthInDIP, u.maxWindowHeightInDIP
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) setWindowSizeLimitsInDP(minw, minh, maxw, maxh int) bool {
|
func (u *UserInterface) setWindowSizeLimitsInDIP(minw, minh, maxw, maxh int) bool {
|
||||||
u.m.RLock()
|
u.m.RLock()
|
||||||
defer u.m.RUnlock()
|
defer u.m.RUnlock()
|
||||||
if u.minWindowWidthInDP == minw && u.minWindowHeightInDP == minh && u.maxWindowWidthInDP == maxw && u.maxWindowHeightInDP == maxh {
|
if u.minWindowWidthInDIP == minw && u.minWindowHeightInDIP == minh && u.maxWindowWidthInDIP == maxw && u.maxWindowHeightInDIP == maxh {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
u.minWindowWidthInDP = minw
|
u.minWindowWidthInDIP = minw
|
||||||
u.minWindowHeightInDP = minh
|
u.minWindowHeightInDIP = minh
|
||||||
u.maxWindowWidthInDP = maxw
|
u.maxWindowWidthInDIP = maxw
|
||||||
u.maxWindowHeightInDP = maxh
|
u.maxWindowHeightInDIP = maxh
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -414,33 +414,33 @@ func (u *UserInterface) setIconImages(iconImages []image.Image) {
|
|||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) getInitWindowPosition() (int, int) {
|
func (u *UserInterface) getInitWindowPositionInDIP() (int, int) {
|
||||||
u.m.RLock()
|
u.m.RLock()
|
||||||
defer u.m.RUnlock()
|
defer u.m.RUnlock()
|
||||||
if u.initWindowPositionXInDP != invalidPos && u.initWindowPositionYInDP != invalidPos {
|
if u.initWindowPositionXInDIP != invalidPos && u.initWindowPositionYInDIP != invalidPos {
|
||||||
return u.initWindowPositionXInDP, u.initWindowPositionYInDP
|
return u.initWindowPositionXInDIP, u.initWindowPositionYInDIP
|
||||||
}
|
}
|
||||||
return invalidPos, invalidPos
|
return invalidPos, invalidPos
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) setInitWindowPosition(x, y int) {
|
func (u *UserInterface) setInitWindowPositionInDIP(x, y int) {
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
defer u.m.Unlock()
|
defer u.m.Unlock()
|
||||||
|
|
||||||
u.initWindowPositionXInDP = x
|
u.initWindowPositionXInDIP = x
|
||||||
u.initWindowPositionYInDP = y
|
u.initWindowPositionYInDIP = y
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) getInitWindowSizeInDP() (int, int) {
|
func (u *UserInterface) getInitWindowSizeInDIP() (int, int) {
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
w, h := u.initWindowWidthInDP, u.initWindowHeightInDP
|
w, h := u.initWindowWidthInDIP, u.initWindowHeightInDIP
|
||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
return w, h
|
return w, h
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) setInitWindowSize(width, height int) {
|
func (u *UserInterface) setInitWindowSizeInDIP(width, height int) {
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
u.initWindowWidthInDP, u.initWindowHeightInDP = width, height
|
u.initWindowWidthInDIP, u.initWindowHeightInDIP = width, height
|
||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -505,15 +505,15 @@ func (u *UserInterface) setInitFocused(focused bool) {
|
|||||||
|
|
||||||
func (u *UserInterface) ScreenSizeInFullscreen() (int, int) {
|
func (u *UserInterface) ScreenSizeInFullscreen() (int, int) {
|
||||||
if !u.isRunning() {
|
if !u.isRunning() {
|
||||||
return u.initFullscreenWidthInDP, u.initFullscreenHeightInDP
|
return u.initFullscreenWidthInDIP, u.initFullscreenHeightInDIP
|
||||||
}
|
}
|
||||||
|
|
||||||
var w, h int
|
var w, h int
|
||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
m := u.currentMonitor()
|
m := u.currentMonitor()
|
||||||
v := m.GetVideoMode()
|
v := m.GetVideoMode()
|
||||||
w = int(u.fromGLFWMonitorPixel(float64(v.Width), m))
|
w = int(u.dipFromGLFWMonitorPixel(float64(v.Width), m))
|
||||||
h = int(u.fromGLFWMonitorPixel(float64(v.Height), m))
|
h = int(u.dipFromGLFWMonitorPixel(float64(v.Height), m))
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
return w, h
|
return w, h
|
||||||
@ -555,8 +555,8 @@ func (u *UserInterface) SetFullscreen(fullscreen bool) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
w, h := u.windowWidthInDP, u.windowHeightInDP
|
w, h := u.windowWidthInDIP, u.windowHeightInDIP
|
||||||
u.setWindowSizeInDP(w, h, fullscreen)
|
u.setWindowSizeInDIP(w, h, fullscreen)
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -771,9 +771,9 @@ func (u *UserInterface) registerWindowSetSizeCallback() {
|
|||||||
|
|
||||||
_ = u.t.Call(func() error {
|
_ = u.t.Call(func() error {
|
||||||
if width != 0 || height != 0 {
|
if width != 0 || height != 0 {
|
||||||
w := int(u.fromGLFWPixel(float64(width), u.currentMonitor()))
|
w := int(u.dipFromGLFWPixel(float64(width), u.currentMonitor()))
|
||||||
h := int(u.fromGLFWPixel(float64(height), u.currentMonitor()))
|
h := int(u.dipFromGLFWPixel(float64(height), u.currentMonitor()))
|
||||||
u.setWindowSizeInDP(w, h, u.isFullscreen())
|
u.setWindowSizeInDIP(w, h, u.isFullscreen())
|
||||||
}
|
}
|
||||||
|
|
||||||
outsideWidth, outsideHeight, outsideSizeChanged = u.updateSize()
|
outsideWidth, outsideHeight, outsideSizeChanged = u.updateSize()
|
||||||
@ -871,14 +871,14 @@ func (u *UserInterface) init() error {
|
|||||||
u.setSizeCallbackEnabled = true
|
u.setSizeCallbackEnabled = true
|
||||||
|
|
||||||
setSize := func() {
|
setSize := func() {
|
||||||
ww, wh := u.getInitWindowSizeInDP()
|
ww, wh := u.getInitWindowSizeInDIP()
|
||||||
u.setWindowSizeInDP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the window size and the window position in this order on Linux or other UNIX using X (#1118),
|
// Set the window size and the window position in this order on Linux or other UNIX using X (#1118),
|
||||||
// but this should be inverted on Windows. This is very tricky, but there is no obvious way to solve
|
// but this should be inverted on Windows. This is very tricky, but there is no obvious way to solve
|
||||||
// this. This doesn't matter on macOS.
|
// this. This doesn't matter on macOS.
|
||||||
wx, wy := u.getInitWindowPosition()
|
wx, wy := u.getInitWindowPositionInDIP()
|
||||||
if runtime.GOOS == "windows" {
|
if runtime.GOOS == "windows" {
|
||||||
u.setWindowPosition(wx, wy, u.initMonitor)
|
u.setWindowPosition(wx, wy, u.initMonitor)
|
||||||
setSize()
|
setSize()
|
||||||
@ -906,8 +906,8 @@ func (u *UserInterface) init() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) updateSize() (float64, float64, bool) {
|
func (u *UserInterface) updateSize() (float64, float64, bool) {
|
||||||
ww, wh := u.windowWidthInDP, u.windowHeightInDP
|
ww, wh := u.windowWidthInDIP, u.windowHeightInDIP
|
||||||
u.setWindowSizeInDP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
|
|
||||||
if !u.toChangeSize {
|
if !u.toChangeSize {
|
||||||
return 0, 0, false
|
return 0, 0, false
|
||||||
@ -923,15 +923,15 @@ func (u *UserInterface) updateSize() (float64, float64, bool) {
|
|||||||
m := u.currentMonitor()
|
m := u.currentMonitor()
|
||||||
v := m.GetVideoMode()
|
v := m.GetVideoMode()
|
||||||
ww, wh := v.Width, v.Height
|
ww, wh := v.Width, v.Height
|
||||||
w = u.fromGLFWMonitorPixel(float64(ww), m)
|
w = u.dipFromGLFWMonitorPixel(float64(ww), m)
|
||||||
h = u.fromGLFWMonitorPixel(float64(wh), m)
|
h = u.dipFromGLFWMonitorPixel(float64(wh), m)
|
||||||
} else {
|
} else {
|
||||||
// Instead of u.windowWidthInDP and u.windowHeightInDP, use the actual window size
|
// Instead of u.windowWidthInDIP and u.windowHeightInDIP, use the actual window size
|
||||||
// here. On Windows, the specified size at SetSize and the actual window size might
|
// here. On Windows, the specified size at SetSize and the actual window size might
|
||||||
// not match (#1163).
|
// not match (#1163).
|
||||||
ww, wh := u.window.GetSize()
|
ww, wh := u.window.GetSize()
|
||||||
w = u.fromGLFWPixel(float64(ww), u.currentMonitor())
|
w = u.dipFromGLFWPixel(float64(ww), u.currentMonitor())
|
||||||
h = u.fromGLFWPixel(float64(wh), u.currentMonitor())
|
h = u.dipFromGLFWPixel(float64(wh), u.currentMonitor())
|
||||||
}
|
}
|
||||||
|
|
||||||
return w, h, true
|
return w, h, true
|
||||||
@ -962,9 +962,9 @@ func (u *UserInterface) update() (float64, float64, bool, error) {
|
|||||||
|
|
||||||
if u.isInitFullscreen() {
|
if u.isInitFullscreen() {
|
||||||
w, h := u.window.GetSize()
|
w, h := u.window.GetSize()
|
||||||
ww := int(u.fromGLFWPixel(float64(w), u.currentMonitor()))
|
ww := int(u.dipFromGLFWPixel(float64(w), u.currentMonitor()))
|
||||||
wh := int(u.fromGLFWPixel(float64(h), u.currentMonitor()))
|
wh := int(u.dipFromGLFWPixel(float64(h), u.currentMonitor()))
|
||||||
u.setWindowSizeInDP(ww, wh, true)
|
u.setWindowSizeInDIP(ww, wh, true)
|
||||||
u.setInitFullscreen(false)
|
u.setInitFullscreen(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1117,34 +1117,34 @@ func (u *UserInterface) swapBuffers() {
|
|||||||
// updateWindowSizeLimits must be called from the main thread.
|
// updateWindowSizeLimits must be called from the main thread.
|
||||||
func (u *UserInterface) updateWindowSizeLimits() {
|
func (u *UserInterface) updateWindowSizeLimits() {
|
||||||
m := u.currentMonitor()
|
m := u.currentMonitor()
|
||||||
minw, minh, maxw, maxh := u.getWindowSizeLimitsInDP()
|
minw, minh, maxw, maxh := u.getWindowSizeLimitsInDIP()
|
||||||
if minw < 0 {
|
if minw < 0 {
|
||||||
minw = glfw.DontCare
|
minw = glfw.DontCare
|
||||||
} else {
|
} else {
|
||||||
minw = int(u.toGLFWPixel(float64(minw), m))
|
minw = int(u.dipToGLFWPixel(float64(minw), m))
|
||||||
}
|
}
|
||||||
if minh < 0 {
|
if minh < 0 {
|
||||||
minh = glfw.DontCare
|
minh = glfw.DontCare
|
||||||
} else {
|
} else {
|
||||||
minh = int(u.toGLFWPixel(float64(minh), m))
|
minh = int(u.dipToGLFWPixel(float64(minh), m))
|
||||||
}
|
}
|
||||||
if maxw < 0 {
|
if maxw < 0 {
|
||||||
maxw = glfw.DontCare
|
maxw = glfw.DontCare
|
||||||
} else {
|
} else {
|
||||||
maxw = int(u.toGLFWPixel(float64(maxw), m))
|
maxw = int(u.dipToGLFWPixel(float64(maxw), m))
|
||||||
}
|
}
|
||||||
if maxh < 0 {
|
if maxh < 0 {
|
||||||
maxh = glfw.DontCare
|
maxh = glfw.DontCare
|
||||||
} else {
|
} else {
|
||||||
maxh = int(u.toGLFWPixel(float64(maxh), m))
|
maxh = int(u.dipToGLFWPixel(float64(maxh), m))
|
||||||
}
|
}
|
||||||
u.window.SetSizeLimits(minw, minh, maxw, maxh)
|
u.window.SetSizeLimits(minw, minh, maxw, maxh)
|
||||||
}
|
}
|
||||||
|
|
||||||
// adjustWindowSizeBasedOnSizeLimitsInDP adjust the size based on the window size limits.
|
// adjustWindowSizeBasedOnSizeLimitsInDIP adjust the size based on the window size limits.
|
||||||
// width and height are in device-independent pixels.
|
// width and height are in device-independent pixels.
|
||||||
func (u *UserInterface) adjustWindowSizeBasedOnSizeLimitsInDP(width, height int) (int, int) {
|
func (u *UserInterface) adjustWindowSizeBasedOnSizeLimitsInDIP(width, height int) (int, int) {
|
||||||
minw, minh, maxw, maxh := u.getWindowSizeLimitsInDP()
|
minw, minh, maxw, maxh := u.getWindowSizeLimitsInDIP()
|
||||||
if minw >= 0 && width < minw {
|
if minw >= 0 && width < minw {
|
||||||
width = minw
|
width = minw
|
||||||
}
|
}
|
||||||
@ -1161,13 +1161,13 @@ func (u *UserInterface) adjustWindowSizeBasedOnSizeLimitsInDP(width, height int)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// setWindowSize must be called from the main thread.
|
// setWindowSize must be called from the main thread.
|
||||||
func (u *UserInterface) setWindowSizeInDP(width, height int, fullscreen bool) {
|
func (u *UserInterface) setWindowSizeInDIP(width, height int, fullscreen bool) {
|
||||||
width, height = u.adjustWindowSizeBasedOnSizeLimitsInDP(width, height)
|
width, height = u.adjustWindowSizeBasedOnSizeLimitsInDIP(width, height)
|
||||||
|
|
||||||
u.Graphics().SetFullscreen(fullscreen)
|
u.Graphics().SetFullscreen(fullscreen)
|
||||||
|
|
||||||
scale := u.deviceScaleFactor(u.currentMonitor())
|
scale := u.deviceScaleFactor(u.currentMonitor())
|
||||||
if u.windowWidthInDP == width && u.windowHeightInDP == height && u.isFullscreen() == fullscreen && u.lastDeviceScaleFactor == scale {
|
if u.windowWidthInDIP == width && u.windowHeightInDIP == height && u.isFullscreen() == fullscreen && u.lastDeviceScaleFactor == scale {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1195,13 +1195,13 @@ func (u *UserInterface) setWindowSizeInDP(width, height int, fullscreen bool) {
|
|||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
windowRecreated := u.setWindowSizeInDPImpl(width, height, fullscreen)
|
windowRecreated := u.setWindowSizeInDIPImpl(width, height, fullscreen)
|
||||||
|
|
||||||
u.adjustViewSize()
|
u.adjustViewSize()
|
||||||
|
|
||||||
// As width might be updated, update windowWidth/Height here.
|
// As width might be updated, update windowWidth/Height here.
|
||||||
u.windowWidthInDP = width
|
u.windowWidthInDIP = width
|
||||||
u.windowHeightInDP = height
|
u.windowHeightInDIP = height
|
||||||
|
|
||||||
u.toChangeSize = true
|
u.toChangeSize = true
|
||||||
|
|
||||||
@ -1212,7 +1212,7 @@ func (u *UserInterface) setWindowSizeInDP(width, height int, fullscreen bool) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) setWindowSizeInDPImpl(width, height int, fullscreen bool) bool {
|
func (u *UserInterface) setWindowSizeInDIPImpl(width, height int, fullscreen bool) bool {
|
||||||
var windowRecreated bool
|
var windowRecreated bool
|
||||||
|
|
||||||
if fullscreen {
|
if fullscreen {
|
||||||
@ -1253,8 +1253,8 @@ func (u *UserInterface) setWindowSizeInDPImpl(width, height int, fullscreen bool
|
|||||||
// When OpenGL is used, swapping buffer is enough to solve the image-lag
|
// When OpenGL is used, swapping buffer is enough to solve the image-lag
|
||||||
// issue (#1004). Rather, recreating window destroys GPU resources.
|
// issue (#1004). Rather, recreating window destroys GPU resources.
|
||||||
// TODO: This might not work when vsync is disabled.
|
// TODO: This might not work when vsync is disabled.
|
||||||
ww := int(u.toGLFWPixel(float64(width), u.currentMonitor()))
|
ww := int(u.dipToGLFWPixel(float64(width), u.currentMonitor()))
|
||||||
wh := int(u.toGLFWPixel(float64(height), u.currentMonitor()))
|
wh := int(u.dipToGLFWPixel(float64(height), u.currentMonitor()))
|
||||||
u.window.SetMonitor(nil, 0, 0, ww, wh, 0)
|
u.window.SetMonitor(nil, 0, 0, ww, wh, 0)
|
||||||
glfw.PollEvents()
|
glfw.PollEvents()
|
||||||
u.swapBuffers()
|
u.swapBuffers()
|
||||||
@ -1290,8 +1290,8 @@ func (u *UserInterface) setWindowSizeInDPImpl(width, height int, fullscreen bool
|
|||||||
// Set the window size after the position. The order matters.
|
// Set the window size after the position. The order matters.
|
||||||
// In the opposite order, the window size might not be correct when going back from fullscreen with multi monitors.
|
// In the opposite order, the window size might not be correct when going back from fullscreen with multi monitors.
|
||||||
oldW, oldH := u.window.GetSize()
|
oldW, oldH := u.window.GetSize()
|
||||||
newW := int(u.toGLFWPixel(float64(width), u.currentMonitor()))
|
newW := int(u.dipToGLFWPixel(float64(width), u.currentMonitor()))
|
||||||
newH := int(u.toGLFWPixel(float64(height), u.currentMonitor()))
|
newH := int(u.dipToGLFWPixel(float64(height), u.currentMonitor()))
|
||||||
if oldW != newW || oldH != newH {
|
if oldW != newW || oldH != newH {
|
||||||
u.framebufferSizeCallbackCh = make(chan struct{}, 1)
|
u.framebufferSizeCallbackCh = make(chan struct{}, 1)
|
||||||
if u.framebufferSizeCallback == 0 {
|
if u.framebufferSizeCallback == 0 {
|
||||||
@ -1461,7 +1461,7 @@ func (u *UserInterface) SetInitFocused(focused bool) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) monitorPosition() (int, int) {
|
func (u *UserInterface) monitorPosition() (int, int) {
|
||||||
// TODO: fromGLFWMonitorPixel might be required.
|
// TODO: dipFromGLFWMonitorPixel might be required.
|
||||||
return u.currentMonitor().GetPos()
|
return u.currentMonitor().GetPos()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1502,9 +1502,9 @@ func (u *UserInterface) maximizeWindow() {
|
|||||||
// Do not call setWindowSize in the fullscreen mode since setWindowSize requires the window size
|
// Do not call setWindowSize in the fullscreen mode since setWindowSize requires the window size
|
||||||
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
||||||
w, h := u.window.GetSize()
|
w, h := u.window.GetSize()
|
||||||
ww := int(u.fromGLFWPixel(float64(w), u.currentMonitor()))
|
ww := int(u.dipFromGLFWPixel(float64(w), u.currentMonitor()))
|
||||||
wh := int(u.fromGLFWPixel(float64(h), u.currentMonitor()))
|
wh := int(u.dipFromGLFWPixel(float64(h), u.currentMonitor()))
|
||||||
u.setWindowSizeInDP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1555,9 +1555,9 @@ func (u *UserInterface) restoreWindow() {
|
|||||||
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
||||||
if !u.isFullscreen() {
|
if !u.isFullscreen() {
|
||||||
w, h := u.window.GetSize()
|
w, h := u.window.GetSize()
|
||||||
ww := int(u.fromGLFWPixel(float64(w), u.currentMonitor()))
|
ww := int(u.dipFromGLFWPixel(float64(w), u.currentMonitor()))
|
||||||
wh := int(u.fromGLFWPixel(float64(h), u.currentMonitor()))
|
wh := int(u.dipFromGLFWPixel(float64(h), u.currentMonitor()))
|
||||||
u.setWindowSizeInDP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1612,6 +1612,10 @@ func (u *UserInterface) setWindowResizable(resizable bool) {
|
|||||||
u.window.SetAttrib(glfw.Resizable, v)
|
u.window.SetAttrib(glfw.Resizable, v)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// setWindowPosition sets the window position.
|
||||||
|
//
|
||||||
|
// x and y are the position in device-independent pixels.
|
||||||
|
//
|
||||||
// setWindowPosition must be called from the main thread.
|
// setWindowPosition must be called from the main thread.
|
||||||
func (u *UserInterface) setWindowPosition(x, y int, monitor *glfw.Monitor) {
|
func (u *UserInterface) setWindowPosition(x, y int, monitor *glfw.Monitor) {
|
||||||
if u.setSizeCallbackEnabled {
|
if u.setSizeCallbackEnabled {
|
||||||
@ -1622,8 +1626,8 @@ func (u *UserInterface) setWindowPosition(x, y int, monitor *glfw.Monitor) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
mx, my := monitor.GetPos()
|
mx, my := monitor.GetPos()
|
||||||
xf := u.toGLFWPixel(float64(x), monitor)
|
xf := u.dipToGLFWPixel(float64(x), monitor)
|
||||||
yf := u.toGLFWPixel(float64(y), monitor)
|
yf := u.dipToGLFWPixel(float64(y), monitor)
|
||||||
if x, y := u.adjustWindowPosition(mx+int(xf), my+int(yf)); u.isFullscreen() {
|
if x, y := u.adjustWindowPosition(mx+int(xf), my+int(yf)); u.isFullscreen() {
|
||||||
u.setOrigPos(x, y)
|
u.setOrigPos(x, y)
|
||||||
} else {
|
} else {
|
||||||
@ -1639,9 +1643,9 @@ func (u *UserInterface) setWindowPosition(x, y int, monitor *glfw.Monitor) {
|
|||||||
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
// before the fullscreen, while window.GetSize() returns the desktop screen size in the fullscreen mode.
|
||||||
if !u.isFullscreen() && runtime.GOOS == "darwin" {
|
if !u.isFullscreen() && runtime.GOOS == "darwin" {
|
||||||
w, h := u.window.GetSize()
|
w, h := u.window.GetSize()
|
||||||
ww := int(u.fromGLFWPixel(float64(w), u.currentMonitor()))
|
ww := int(u.dipFromGLFWPixel(float64(w), u.currentMonitor()))
|
||||||
wh := int(u.fromGLFWPixel(float64(h), u.currentMonitor()))
|
wh := int(u.dipFromGLFWPixel(float64(h), u.currentMonitor()))
|
||||||
u.setWindowSizeInDP(ww, wh, u.isFullscreen())
|
u.setWindowSizeInDIP(ww, wh, u.isFullscreen())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,14 +121,14 @@ import (
|
|||||||
// clearVideoModeScaleCache must be called from the main thread.
|
// clearVideoModeScaleCache must be called from the main thread.
|
||||||
func clearVideoModeScaleCache() {}
|
func clearVideoModeScaleCache() {}
|
||||||
|
|
||||||
// fromGLFWMonitorPixel must be called from the main thread.
|
// dipFromGLFWMonitorPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
// videoModeScale is always 1 on macOS.
|
// videoModeScale is always 1 on macOS.
|
||||||
return x
|
return x
|
||||||
}
|
}
|
||||||
|
|
||||||
// fromGLFWPixel must be called from the main thread.
|
// dipFromGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
// NOTE: On macOS, GLFW exposes the device independent coordinate system.
|
// NOTE: On macOS, GLFW exposes the device independent coordinate system.
|
||||||
// Thus, the conversion functions are unnecessary,
|
// Thus, the conversion functions are unnecessary,
|
||||||
// however we still need the deviceScaleFactor internally
|
// however we still need the deviceScaleFactor internally
|
||||||
@ -136,8 +136,8 @@ func (u *UserInterface) fromGLFWPixel(x float64, monitor *glfw.Monitor) float64
|
|||||||
return x
|
return x
|
||||||
}
|
}
|
||||||
|
|
||||||
// toGLFWPixel must be called from the main thread.
|
// dipToGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) toGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipToGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x
|
return x
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,18 +116,18 @@ func videoModeScaleUncached(m *glfw.Monitor) float64 {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
// fromGLFWMonitorPixel must be called from the main thread.
|
// dipFromGLFWMonitorPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x / (videoModeScale(monitor) * u.deviceScaleFactor(monitor))
|
return x / (videoModeScale(monitor) * u.deviceScaleFactor(monitor))
|
||||||
}
|
}
|
||||||
|
|
||||||
// fromGLFWPixel must be called from the main thread.
|
// dipFromGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x / u.deviceScaleFactor(monitor)
|
return x / u.deviceScaleFactor(monitor)
|
||||||
}
|
}
|
||||||
|
|
||||||
// toGLFWPixel must be called from the main thread.
|
// dipToGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) toGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipToGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x * u.deviceScaleFactor(monitor)
|
return x * u.deviceScaleFactor(monitor)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,18 +93,18 @@ func getMonitorInfoW(hMonitor uintptr, lpmi *monitorInfo) error {
|
|||||||
// clearVideoModeScaleCache must be called from the main thread.
|
// clearVideoModeScaleCache must be called from the main thread.
|
||||||
func clearVideoModeScaleCache() {}
|
func clearVideoModeScaleCache() {}
|
||||||
|
|
||||||
// fromGLFWMonitorPixel must be called from the main thread.
|
// dipFromGLFWMonitorPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWMonitorPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x / u.deviceScaleFactor(monitor)
|
return x / u.deviceScaleFactor(monitor)
|
||||||
}
|
}
|
||||||
|
|
||||||
// fromGLFWPixel must be called from the main thread.
|
// dipFromGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) fromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipFromGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x / u.deviceScaleFactor(monitor)
|
return x / u.deviceScaleFactor(monitor)
|
||||||
}
|
}
|
||||||
|
|
||||||
// toGLFWPixel must be called from the main thread.
|
// dipToGLFWPixel must be called from the main thread.
|
||||||
func (u *UserInterface) toGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
func (u *UserInterface) dipToGLFWPixel(x float64, monitor *glfw.Monitor) float64 {
|
||||||
return x * u.deviceScaleFactor(monitor)
|
return x * u.deviceScaleFactor(monitor)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,8 +185,8 @@ func (w *window) Position() (int, int) {
|
|||||||
mx, my := m.GetPos()
|
mx, my := m.GetPos()
|
||||||
wx -= mx
|
wx -= mx
|
||||||
wy -= my
|
wy -= my
|
||||||
xf := w.ui.fromGLFWPixel(float64(wx), m)
|
xf := w.ui.dipFromGLFWPixel(float64(wx), m)
|
||||||
yf := w.ui.fromGLFWPixel(float64(wy), m)
|
yf := w.ui.dipFromGLFWPixel(float64(wy), m)
|
||||||
x, y = int(xf), int(yf)
|
x, y = int(xf), int(yf)
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
@ -195,7 +195,7 @@ func (w *window) Position() (int, int) {
|
|||||||
|
|
||||||
func (w *window) SetPosition(x, y int) {
|
func (w *window) SetPosition(x, y int) {
|
||||||
if !w.ui.isRunning() {
|
if !w.ui.isRunning() {
|
||||||
w.ui.setInitWindowPosition(x, y)
|
w.ui.setInitWindowPositionInDIP(x, y)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
_ = w.ui.t.Call(func() error {
|
_ = w.ui.t.Call(func() error {
|
||||||
@ -206,13 +206,13 @@ func (w *window) SetPosition(x, y int) {
|
|||||||
|
|
||||||
func (w *window) Size() (int, int) {
|
func (w *window) Size() (int, int) {
|
||||||
if !w.ui.isRunning() {
|
if !w.ui.isRunning() {
|
||||||
ww, wh := w.ui.getInitWindowSizeInDP()
|
ww, wh := w.ui.getInitWindowSizeInDIP()
|
||||||
return w.ui.adjustWindowSizeBasedOnSizeLimitsInDP(ww, wh)
|
return w.ui.adjustWindowSizeBasedOnSizeLimitsInDIP(ww, wh)
|
||||||
}
|
}
|
||||||
ww, wh := 0, 0
|
ww, wh := 0, 0
|
||||||
_ = w.ui.t.Call(func() error {
|
_ = w.ui.t.Call(func() error {
|
||||||
ww = w.ui.windowWidthInDP
|
ww = w.ui.windowWidthInDIP
|
||||||
wh = w.ui.windowHeightInDP
|
wh = w.ui.windowHeightInDIP
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
return ww, wh
|
return ww, wh
|
||||||
@ -220,7 +220,7 @@ func (w *window) Size() (int, int) {
|
|||||||
|
|
||||||
func (w *window) SetSize(width, height int) {
|
func (w *window) SetSize(width, height int) {
|
||||||
if !w.ui.isRunning() {
|
if !w.ui.isRunning() {
|
||||||
w.ui.setInitWindowSize(width, height)
|
w.ui.setInitWindowSizeInDIP(width, height)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
_ = w.ui.t.Call(func() error {
|
_ = w.ui.t.Call(func() error {
|
||||||
@ -230,17 +230,17 @@ func (w *window) SetSize(width, height int) {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
w.ui.setWindowSizeInDP(width, height, w.ui.isFullscreen())
|
w.ui.setWindowSizeInDIP(width, height, w.ui.isFullscreen())
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *window) SizeLimits() (minw, minh, maxw, maxh int) {
|
func (w *window) SizeLimits() (minw, minh, maxw, maxh int) {
|
||||||
return w.ui.getWindowSizeLimitsInDP()
|
return w.ui.getWindowSizeLimitsInDIP()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *window) SetSizeLimits(minw, minh, maxw, maxh int) {
|
func (w *window) SetSizeLimits(minw, minh, maxw, maxh int) {
|
||||||
if !w.ui.setWindowSizeLimitsInDP(minw, minh, maxw, maxh) {
|
if !w.ui.setWindowSizeLimitsInDIP(minw, minh, maxw, maxh) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !w.ui.isRunning() {
|
if !w.ui.isRunning() {
|
||||||
|
Loading…
Reference in New Issue
Block a user