mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
parent
3c1226a227
commit
ead84553a0
@ -74,6 +74,8 @@ type Input struct {
|
|||||||
mouseButtonPressed map[int]bool
|
mouseButtonPressed map[int]bool
|
||||||
cursorX int
|
cursorX int
|
||||||
cursorY int
|
cursorY int
|
||||||
|
origCursorX int
|
||||||
|
origCursorY int
|
||||||
wheelX float64
|
wheelX float64
|
||||||
wheelY float64
|
wheelY float64
|
||||||
gamepads map[driver.GamepadID]gamepad
|
gamepads map[driver.GamepadID]gamepad
|
||||||
@ -284,10 +286,6 @@ func (i *Input) mouseUp(code int) {
|
|||||||
i.mouseButtonPressed[code] = false
|
i.mouseButtonPressed[code] = false
|
||||||
}
|
}
|
||||||
|
|
||||||
func (i *Input) setMouseCursor(x, y int) {
|
|
||||||
i.cursorX, i.cursorY = x, y
|
|
||||||
}
|
|
||||||
|
|
||||||
func (i *Input) updateGamepads() {
|
func (i *Input) updateGamepads() {
|
||||||
nav := js.Global().Get("navigator")
|
nav := js.Global().Get("navigator")
|
||||||
if !nav.Truthy() {
|
if !nav.Truthy() {
|
||||||
@ -401,8 +399,22 @@ func (i *Input) updateFromEvent(e js.Value) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (i *Input) setMouseCursorFromEvent(e js.Value) {
|
func (i *Input) setMouseCursorFromEvent(e js.Value) {
|
||||||
|
if i.ui.cursorMode == driver.CursorModeCaptured {
|
||||||
|
x, y := e.Get("clientX").Int(), e.Get("clientY").Int()
|
||||||
|
i.origCursorX, i.origCursorY = x, y
|
||||||
|
dx, dy := e.Get("movementX").Int(), e.Get("movementY").Int()
|
||||||
|
i.cursorX += dx
|
||||||
|
i.cursorY += dy
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
x, y := e.Get("clientX").Int(), e.Get("clientY").Int()
|
x, y := e.Get("clientX").Int(), e.Get("clientY").Int()
|
||||||
i.setMouseCursor(x, y)
|
i.cursorX, i.cursorY = x, y
|
||||||
|
i.origCursorX, i.origCursorY = x, y
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *Input) recoverCursorPosition() {
|
||||||
|
i.cursorX, i.cursorY = i.origCursorX, i.origCursorY
|
||||||
}
|
}
|
||||||
|
|
||||||
func (in *Input) updateTouchesFromEvent(e js.Value) {
|
func (in *Input) updateTouchesFromEvent(e js.Value) {
|
||||||
|
@ -50,7 +50,8 @@ type UserInterface struct {
|
|||||||
vsync bool
|
vsync bool
|
||||||
running bool
|
running bool
|
||||||
initFocused bool
|
initFocused bool
|
||||||
cursorHidden bool
|
cursorMode driver.CursorMode
|
||||||
|
cursorPrevMode driver.CursorMode
|
||||||
cursorShape driver.CursorShape
|
cursorShape driver.CursorShape
|
||||||
|
|
||||||
sizeChanged bool
|
sizeChanged bool
|
||||||
@ -122,38 +123,34 @@ func (u *UserInterface) CursorMode() driver.CursorMode {
|
|||||||
if !canvas.Truthy() {
|
if !canvas.Truthy() {
|
||||||
return driver.CursorModeHidden
|
return driver.CursorModeHidden
|
||||||
}
|
}
|
||||||
|
return u.cursorMode
|
||||||
if u.cursorHidden {
|
|
||||||
return driver.CursorModeHidden
|
|
||||||
}
|
|
||||||
return driver.CursorModeVisible
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) SetCursorMode(mode driver.CursorMode) {
|
func (u *UserInterface) SetCursorMode(mode driver.CursorMode) {
|
||||||
if !canvas.Truthy() {
|
if !canvas.Truthy() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if u.cursorMode == mode {
|
||||||
switch mode {
|
|
||||||
case driver.CursorModeVisible:
|
|
||||||
if !u.cursorHidden {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
u.cursorHidden = false
|
|
||||||
case driver.CursorModeHidden:
|
|
||||||
if u.cursorHidden {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
u.cursorHidden = true
|
|
||||||
default:
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
// Remember the previous cursor mode in the case when the pointer lock exit by pressing ESC.
|
||||||
if u.cursorHidden {
|
u.cursorPrevMode = u.cursorMode
|
||||||
canvas.Get("style").Set("cursor", stringNone)
|
if u.cursorMode == driver.CursorModeCaptured {
|
||||||
} else {
|
document.Call("exitPointerLock")
|
||||||
canvas.Get("style").Set("cursor", driverCursorShapeToCSSCursor(u.cursorShape))
|
|
||||||
}
|
}
|
||||||
|
u.cursorMode = mode
|
||||||
|
switch mode {
|
||||||
|
case driver.CursorModeVisible:
|
||||||
|
canvas.Get("style").Set("cursor", driverCursorShapeToCSSCursor(u.cursorShape))
|
||||||
|
case driver.CursorModeHidden:
|
||||||
|
canvas.Get("style").Set("cursor", stringNone)
|
||||||
|
case driver.CursorModeCaptured:
|
||||||
|
canvas.Call("requestPointerLock")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (u *UserInterface) recoverCursorMode() {
|
||||||
|
u.SetCursorMode(u.cursorPrevMode)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *UserInterface) CursorShape() driver.CursorShape {
|
func (u *UserInterface) CursorShape() driver.CursorShape {
|
||||||
@ -170,8 +167,9 @@ func (u *UserInterface) SetCursorShape(shape driver.CursorShape) {
|
|||||||
if u.cursorShape == shape {
|
if u.cursorShape == shape {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
u.cursorShape = shape
|
u.cursorShape = shape
|
||||||
if !u.cursorHidden {
|
if u.cursorMode == driver.CursorModeVisible {
|
||||||
canvas.Get("style").Set("cursor", driverCursorShapeToCSSCursor(u.cursorShape))
|
canvas.Get("style").Set("cursor", driverCursorShapeToCSSCursor(u.cursorShape))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -380,6 +378,24 @@ func init() {
|
|||||||
canvas.Get("style").Set("outline", "none")
|
canvas.Get("style").Set("outline", "none")
|
||||||
|
|
||||||
setCanvasEventHandlers(canvas)
|
setCanvasEventHandlers(canvas)
|
||||||
|
|
||||||
|
// Pointer Lock
|
||||||
|
document.Call("addEventListener", "pointerlockchange", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
|
if document.Get("pointerLockElement").Truthy() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
// Recover the state correctly when exiting from the pointer lock.
|
||||||
|
|
||||||
|
// A user can exit the pointer lock by pressing ESC. In this case, sync the cursor mode state.
|
||||||
|
if theUI.cursorMode == driver.CursorModeCaptured {
|
||||||
|
if theUI.cursorPrevMode == driver.CursorModeCaptured {
|
||||||
|
panic("js: cursorPrevMode must not be driver.CursorModeCaptured")
|
||||||
|
}
|
||||||
|
theUI.recoverCursorMode()
|
||||||
|
}
|
||||||
|
theUI.input.recoverCursorPosition()
|
||||||
|
return nil
|
||||||
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
func setWindowEventHandlers(v js.Value) {
|
func setWindowEventHandlers(v js.Value) {
|
||||||
@ -473,7 +489,7 @@ func setCanvasEventHandlers(v js.Value) {
|
|||||||
return nil
|
return nil
|
||||||
}))
|
}))
|
||||||
|
|
||||||
// Gamepad
|
// Context menu
|
||||||
v.Call("addEventListener", "contextmenu", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
v.Call("addEventListener", "contextmenu", js.FuncOf(func(this js.Value, args []js.Value) interface{} {
|
||||||
e := args[0]
|
e := args[0]
|
||||||
e.Call("preventDefault")
|
e.Call("preventDefault")
|
||||||
|
Loading…
Reference in New Issue
Block a user