From 106ff7a84b1ffb981a77e563ecede31a8820fea6 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Thu, 9 Sep 2021 11:11:56 +0900 Subject: [PATCH] internal/ui: Reduce calls of glfw.GetMonitors Updates #1803 --- internal/uidriver/glfw/ui.go | 31 +++++++++++++++++----------- internal/uidriver/glfw/ui_darwin.go | 7 +++---- internal/uidriver/glfw/ui_windows.go | 7 +++---- 3 files changed, 25 insertions(+), 20 deletions(-) diff --git a/internal/uidriver/glfw/ui.go b/internal/uidriver/glfw/ui.go index 637fb7a21..d27667dfc 100644 --- a/internal/uidriver/glfw/ui.go +++ b/internal/uidriver/glfw/ui.go @@ -160,9 +160,9 @@ func init() { panic(err) } glfw.SetMonitorCallback(func(monitor *glfw.Monitor, event glfw.PeripheralEvent) { - cacheMonitors() + updateMonitors() }) - cacheMonitors() + updateMonitors() } var glfwSystemCursors = map[driver.CursorShape]*glfw.Cursor{} @@ -208,7 +208,7 @@ func initialize() error { return nil } -type cachedMonitor struct { +type monitor struct { m *glfw.Monitor vm *glfw.VidMode // Pos of monitor in virtual coords @@ -217,18 +217,18 @@ type cachedMonitor struct { } // monitors is the monitor list cache for desktop glfw compile targets. -// populated by 'cacheMonitors' which is called on init and every +// populated by 'updateMonitors' which is called on init and every // monitor config change event. // // monitors must be manipulated on the main thread. -var monitors []*cachedMonitor +var monitors []*monitor -func cacheMonitors() { +func updateMonitors() { monitors = nil ms := glfw.GetMonitors() for _, m := range ms { x, y := m.GetPos() - monitors = append(monitors, &cachedMonitor{ + monitors = append(monitors, &monitor{ m: m, vm: m.GetVideoMode(), x: x, @@ -237,12 +237,19 @@ func cacheMonitors() { } } -// getCachedMonitor returns a monitor for the given window x/y, +func ensureMonitors() []*monitor { + if len(monitors) == 0 { + updateMonitors() + } + return monitors +} + +// getMonitorFromPosition returns a monitor for the given window x/y, // or returns nil if monitor is not found. // -// getCachedMonitor must be called on the main thread. -func getCachedMonitor(wx, wy int) *cachedMonitor { - for _, m := range monitors { +// getMonitorFromPosition must be called on the main thread. +func getMonitorFromPosition(wx, wy int) *monitor { + for _, m := range ensureMonitors() { if m.x <= wx && wx < m.x+m.vm.Width && m.y <= wy && wy < m.y+m.vm.Height { return m } @@ -1387,7 +1394,7 @@ func currentMonitor(window *glfw.Window) *glfw.Monitor { } // As the fallback, detect the monitor from the window. - if m := getCachedMonitor(window.GetPos()); m != nil { + if m := getMonitorFromPosition(window.GetPos()); m != nil { return m.m } return glfw.GetPrimaryMonitor() diff --git a/internal/uidriver/glfw/ui_darwin.go b/internal/uidriver/glfw/ui_darwin.go index bec34bc38..308f3fcc3 100644 --- a/internal/uidriver/glfw/ui_darwin.go +++ b/internal/uidriver/glfw/ui_darwin.go @@ -107,10 +107,9 @@ func currentMonitorByOS(w *glfw.Window) *glfw.Monitor { // Note: [NSApp mainWindow] is nil when it doesn't have its border. Use w here. win := w.GetCocoaWindow() C.currentMonitorPos(C.uintptr_t(win), &x, &y) - for _, m := range glfw.GetMonitors() { - mx, my := m.GetPos() - if int(x) == mx && int(y) == my { - return m + for _, m := range ensureMonitors() { + if int(x) == m.x && int(y) == m.y { + return m.m } } return nil diff --git a/internal/uidriver/glfw/ui_windows.go b/internal/uidriver/glfw/ui_windows.go index 7658461f2..bf131183e 100644 --- a/internal/uidriver/glfw/ui_windows.go +++ b/internal/uidriver/glfw/ui_windows.go @@ -171,10 +171,9 @@ func currentMonitorByOS(_ *glfw.Window) *glfw.Monitor { } x, y := int(mi.rcMonitor.left), int(mi.rcMonitor.top) - for _, m := range glfw.GetMonitors() { - mx, my := m.GetPos() - if mx == x && my == y { - return m + for _, m := range ensureMonitors() { + if m.x == x && m.y == y { + return m.m } } return nil