mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
ui: Refactoring: Add deviceScale struct
This commit is contained in:
parent
635d624b77
commit
c494b53822
38
internal/ui/devicescale.go
Normal file
38
internal/ui/devicescale.go
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
// Copyright 2018 The Ebiten Authors
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package ui
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/hajimehoshi/ebiten/internal/devicescale"
|
||||||
|
)
|
||||||
|
|
||||||
|
type deviceScale struct {
|
||||||
|
val float64
|
||||||
|
frame int64
|
||||||
|
lastUpdated int64
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *deviceScale) Update() {
|
||||||
|
d.frame++
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *deviceScale) Get() float64 {
|
||||||
|
// As devicescale.DeviceScale accesses OS API, not call this too often.
|
||||||
|
if d.val == 0 || d.frame-d.lastUpdated > 30 {
|
||||||
|
d.val = devicescale.DeviceScale()
|
||||||
|
d.lastUpdated = d.frame
|
||||||
|
}
|
||||||
|
return d.val
|
||||||
|
}
|
@ -28,7 +28,6 @@ import (
|
|||||||
|
|
||||||
"github.com/go-gl/glfw/v3.2/glfw"
|
"github.com/go-gl/glfw/v3.2/glfw"
|
||||||
|
|
||||||
"github.com/hajimehoshi/ebiten/internal/devicescale"
|
|
||||||
"github.com/hajimehoshi/ebiten/internal/hooks"
|
"github.com/hajimehoshi/ebiten/internal/hooks"
|
||||||
"github.com/hajimehoshi/ebiten/internal/input"
|
"github.com/hajimehoshi/ebiten/internal/input"
|
||||||
"github.com/hajimehoshi/ebiten/internal/opengl"
|
"github.com/hajimehoshi/ebiten/internal/opengl"
|
||||||
@ -51,10 +50,8 @@ type userInterface struct {
|
|||||||
runnableInBackground bool
|
runnableInBackground bool
|
||||||
vsync bool
|
vsync bool
|
||||||
|
|
||||||
deviceScale float64
|
deviceScale deviceScale
|
||||||
frame int64
|
lastActualScale float64
|
||||||
deviceScaleUpdated int64
|
|
||||||
lastActualScale float64
|
|
||||||
|
|
||||||
initFullscreen bool
|
initFullscreen bool
|
||||||
initCursorVisible bool
|
initCursorVisible bool
|
||||||
@ -388,7 +385,7 @@ func ScreenPadding() (x0, y0, x1, y1 float64) {
|
|||||||
|
|
||||||
m := glfw.GetPrimaryMonitor()
|
m := glfw.GetPrimaryMonitor()
|
||||||
v := m.GetVideoMode()
|
v := m.GetVideoMode()
|
||||||
d := devicescale.DeviceScale()
|
d := u.deviceScale.Get()
|
||||||
|
|
||||||
mx := float64(v.Width) * d / glfwScale()
|
mx := float64(v.Width) * d / glfwScale()
|
||||||
my := float64(v.Height) * d / glfwScale()
|
my := float64(v.Height) * d / glfwScale()
|
||||||
@ -545,12 +542,7 @@ func (u *userInterface) getScale() float64 {
|
|||||||
|
|
||||||
// actualScreenScale must be called from the main thread.
|
// actualScreenScale must be called from the main thread.
|
||||||
func (u *userInterface) actualScreenScale() float64 {
|
func (u *userInterface) actualScreenScale() float64 {
|
||||||
// As devicescale.DeviceScale accesses OS API, not call this too often.
|
return u.getScale() * u.deviceScale.Get()
|
||||||
if u.deviceScale == 0 || u.frame-u.deviceScaleUpdated > 30 {
|
|
||||||
u.deviceScale = devicescale.DeviceScale()
|
|
||||||
u.deviceScaleUpdated = u.frame
|
|
||||||
}
|
|
||||||
return u.getScale() * u.deviceScale
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// pollEvents must be called from the main thread.
|
// pollEvents must be called from the main thread.
|
||||||
@ -639,7 +631,7 @@ func (u *userInterface) loop(g GraphicsContext) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
u.frame++
|
u.deviceScale.Update()
|
||||||
u.m.Lock()
|
u.m.Lock()
|
||||||
vsync := u.vsync
|
vsync := u.vsync
|
||||||
u.m.Unlock()
|
u.m.Unlock()
|
||||||
@ -688,7 +680,7 @@ func (u *userInterface) setScreenSize(width, height int, scale float64, fullscre
|
|||||||
|
|
||||||
u.width = width
|
u.width = width
|
||||||
u.windowWidth = width
|
u.windowWidth = width
|
||||||
s := scale * devicescale.DeviceScale()
|
s := scale * u.deviceScale.Get()
|
||||||
if int(float64(width)*s) < minWindowWidth {
|
if int(float64(width)*s) < minWindowWidth {
|
||||||
u.windowWidth = int(math.Ceil(minWindowWidth / s))
|
u.windowWidth = int(math.Ceil(minWindowWidth / s))
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@ import (
|
|||||||
|
|
||||||
"github.com/gopherjs/gopherwasm/js"
|
"github.com/gopherjs/gopherwasm/js"
|
||||||
|
|
||||||
"github.com/hajimehoshi/ebiten/internal/devicescale"
|
|
||||||
"github.com/hajimehoshi/ebiten/internal/hooks"
|
"github.com/hajimehoshi/ebiten/internal/hooks"
|
||||||
"github.com/hajimehoshi/ebiten/internal/input"
|
"github.com/hajimehoshi/ebiten/internal/input"
|
||||||
"github.com/hajimehoshi/ebiten/internal/opengl"
|
"github.com/hajimehoshi/ebiten/internal/opengl"
|
||||||
@ -42,10 +41,8 @@ type userInterface struct {
|
|||||||
windowFocus bool
|
windowFocus bool
|
||||||
pageVisible bool
|
pageVisible bool
|
||||||
|
|
||||||
deviceScale float64
|
deviceScale deviceScale
|
||||||
frame int64
|
lastActualScale float64
|
||||||
deviceScaleUpdated int64
|
|
||||||
lastActualScale float64
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var currentUI = &userInterface{
|
var currentUI = &userInterface{
|
||||||
@ -178,11 +175,7 @@ func (u *userInterface) actualScreenScale() float64 {
|
|||||||
// * Chrome just after restoring the lost context
|
// * Chrome just after restoring the lost context
|
||||||
// * Safari
|
// * Safari
|
||||||
// Let's use the devicePixelRatio as it is here.
|
// Let's use the devicePixelRatio as it is here.
|
||||||
if u.deviceScale == 0 || u.frame-u.deviceScaleUpdated > 30 {
|
return u.getScale() * u.deviceScale.Get()
|
||||||
u.deviceScale = devicescale.DeviceScale()
|
|
||||||
u.deviceScaleUpdated = u.frame
|
|
||||||
}
|
|
||||||
return u.getScale() * u.deviceScale
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *userInterface) updateGraphicsContext(g GraphicsContext) {
|
func (u *userInterface) updateGraphicsContext(g GraphicsContext) {
|
||||||
@ -240,7 +233,7 @@ func (u *userInterface) loop(g GraphicsContext) error {
|
|||||||
close(ch)
|
close(ch)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
u.frame++
|
u.deviceScale.Update()
|
||||||
if u.vsync {
|
if u.vsync {
|
||||||
requestAnimationFrame.Invoke(cf)
|
requestAnimationFrame.Invoke(cf)
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user