driver: Remove UI.AdjustPosition

This commit is contained in:
Hajime Hoshi 2019-04-07 19:27:30 +09:00
parent 26c32d36b5
commit 0aa3135082
8 changed files with 26 additions and 12 deletions

View File

@ -48,7 +48,7 @@ func IsKeyPressed(key Key) bool {
// //
// CursorPosition is concurrent-safe. // CursorPosition is concurrent-safe.
func CursorPosition() (x, y int) { func CursorPosition() (x, y int) {
return uiDriver().AdjustPosition(uiDriver().Input().CursorPosition()) return uiDriver().Input().CursorPosition()
} }
// Wheel returns the x and y offset of the mouse wheel or touchpad scroll. // Wheel returns the x and y offset of the mouse wheel or touchpad scroll.
@ -144,7 +144,7 @@ func TouchPosition(id int) (int, int) {
return 0, 0 return 0, 0
} }
return uiDriver().AdjustPosition(uiDriver().Input().TouchPosition(id)) return uiDriver().Input().TouchPosition(id)
} }
// Touch is deprecated as of 1.7.0. Use TouchPosition instead. // Touch is deprecated as of 1.7.0. Use TouchPosition instead.

View File

@ -30,7 +30,6 @@ type GraphicsContext interface {
var RegularTermination = errors.New("regular termination") var RegularTermination = errors.New("regular termination")
type UI interface { type UI interface {
AdjustPosition(x, y int) (int, int)
DeviceScaleFactor() float64 DeviceScaleFactor() float64
IsCursorVisible() bool IsCursorVisible() bool
IsFullscreen() bool IsFullscreen() bool

View File

@ -46,6 +46,7 @@ type Input struct {
gamepads [16]gamePad gamepads [16]gamePad
touches map[int]pos // This is not updated until GLFW 3.3 is available (#417) touches map[int]pos // This is not updated until GLFW 3.3 is available (#417)
runeBuffer []rune runeBuffer []rune
ui *UserInterface
m sync.RWMutex m sync.RWMutex
} }
@ -57,7 +58,7 @@ type pos struct {
func (i *Input) CursorPosition() (x, y int) { func (i *Input) CursorPosition() (x, y int) {
i.m.RLock() i.m.RLock()
defer i.m.RUnlock() defer i.m.RUnlock()
return i.cursorX, i.cursorY return i.ui.adjustPosition(i.cursorX, i.cursorY)
} }
func (i *Input) GamepadIDs() []int { func (i *Input) GamepadIDs() []int {
@ -132,7 +133,7 @@ func (i *Input) TouchPosition(id int) (x, y int) {
for tid, pos := range i.touches { for tid, pos := range i.touches {
if id == tid { if id == tid {
return pos.X, pos.Y return i.ui.adjustPosition(pos.X, pos.Y)
} }
} }
return 0, 0 return 0, 0

View File

@ -86,6 +86,10 @@ var (
} }
) )
func init() {
theUI.input.ui = theUI
}
func Get() *UserInterface { func Get() *UserInterface {
return theUI return theUI
} }
@ -442,7 +446,7 @@ func (u *UserInterface) ScreenPadding() (x0, y0, x1, y1 float64) {
return ox, oy, (mx - sx) - ox, (my - sy) - oy return ox, oy, (mx - sx) - ox, (my - sy) - oy
} }
func (u *UserInterface) AdjustPosition(x, y int) (int, int) { func (u *UserInterface) adjustPosition(x, y int) (int, int) {
if !u.isRunning() { if !u.isRunning() {
return x, y return x, y
} }

View File

@ -48,10 +48,11 @@ type Input struct {
gamepads [16]gamePad gamepads [16]gamePad
touches map[int]pos touches map[int]pos
runeBuffer []rune runeBuffer []rune
ui *UserInterface
} }
func (i *Input) CursorPosition() (x, y int) { func (i *Input) CursorPosition() (x, y int) {
return i.cursorX, i.cursorY return i.ui.adjustPosition(i.cursorX, i.cursorY)
} }
func (i *Input) GamepadIDs() []int { func (i *Input) GamepadIDs() []int {
@ -110,7 +111,7 @@ func (i *Input) TouchIDs() []int {
func (i *Input) TouchPosition(id int) (x, y int) { func (i *Input) TouchPosition(id int) (x, y int) {
for tid, pos := range i.touches { for tid, pos := range i.touches {
if id == tid { if id == tid {
return pos.X, pos.Y return i.ui.adjustPosition(pos.X, pos.Y)
} }
} }
return 0, 0 return 0, 0

View File

@ -56,6 +56,10 @@ var theUI = &UserInterface{
vsync: true, vsync: true,
} }
func init() {
theUI.input.ui = theUI
}
func Get() *UserInterface { func Get() *UserInterface {
return theUI return theUI
} }
@ -111,7 +115,7 @@ func (u *UserInterface) ScreenPadding() (x0, y0, x1, y1 float64) {
return 0, 0, 0, 0 return 0, 0, 0, 0
} }
func (u *UserInterface) AdjustPosition(x, y int) (int, int) { func (u *UserInterface) adjustPosition(x, y int) (int, int) {
rect := canvas.Call("getBoundingClientRect") rect := canvas.Call("getBoundingClientRect")
x -= rect.Get("left").Int() x -= rect.Get("left").Int()
y -= rect.Get("top").Int() y -= rect.Get("top").Int()

View File

@ -31,13 +31,14 @@ type Input struct {
cursorX int cursorX int
cursorY int cursorY int
touches map[int]pos touches map[int]pos
ui *UserInterface
m sync.RWMutex m sync.RWMutex
} }
func (i *Input) CursorPosition() (x, y int) { func (i *Input) CursorPosition() (x, y int) {
i.m.RLock() i.m.RLock()
defer i.m.RUnlock() defer i.m.RUnlock()
return i.cursorX, i.cursorY return i.ui.adjustPosition(i.cursorX, i.cursorY)
} }
func (i *Input) GamepadIDs() []int { func (i *Input) GamepadIDs() []int {
@ -81,7 +82,7 @@ func (i *Input) TouchPosition(id int) (x, y int) {
for tid, pos := range i.touches { for tid, pos := range i.touches {
if id == tid { if id == tid {
return pos.X, pos.Y return i.ui.adjustPosition(pos.X, pos.Y)
} }
} }
return 0, 0 return 0, 0

View File

@ -43,6 +43,10 @@ var (
theUI = &UserInterface{} theUI = &UserInterface{}
) )
func init() {
theUI.input.ui = theUI
}
func Get() *UserInterface { func Get() *UserInterface {
return theUI return theUI
} }
@ -332,7 +336,7 @@ func (u *UserInterface) screenPaddingImpl() (x0, y0, x1, y1 float64) {
return ox, oy, ox, oy return ox, oy, ox, oy
} }
func (u *UserInterface) AdjustPosition(x, y int) (int, int) { func (u *UserInterface) adjustPosition(x, y int) (int, int) {
u.m.Lock() u.m.Lock()
ox, oy, _, _ := u.screenPaddingImpl() ox, oy, _, _ := u.screenPaddingImpl()
s := u.scaleImpl() s := u.scaleImpl()