ebiten/internal/ui/input.go
2018-02-12 20:23:24 +09:00

129 lines
2.5 KiB
Go

// Copyright 2015 Hajime Hoshi
//
// 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
var currentInput = &Input{}
type Touch interface {
ID() int
Position() (x, y int)
}
func CurrentInput() *Input {
return currentInput
}
func (i *Input) CursorPosition() (x, y int) {
i.m.RLock()
defer i.m.RUnlock()
return adjustCursorPosition(i.cursorX, i.cursorY)
}
var emptyIDs = []int{}
func (i *Input) GamepadIDs() []int {
i.m.RLock()
defer i.m.RUnlock()
if len(i.gamepads) == 0 {
// Avoid creating a slice if possible.
// This is a performance optimization for browsers.
return emptyIDs
}
r := []int{}
for id, g := range i.gamepads {
if g.valid {
r = append(r, id)
}
}
return r
}
func (i *Input) GamepadAxisNum(id int) int {
i.m.RLock()
defer i.m.RUnlock()
if len(i.gamepads) <= id {
return 0
}
return i.gamepads[id].axisNum
}
func (i *Input) GamepadAxis(id int, axis int) float64 {
i.m.RLock()
defer i.m.RUnlock()
if len(i.gamepads) <= id {
return 0
}
return i.gamepads[id].axes[axis]
}
func (i *Input) GamepadButtonNum(id int) int {
i.m.RLock()
defer i.m.RUnlock()
if len(i.gamepads) <= id {
return 0
}
return i.gamepads[id].buttonNum
}
func (i *Input) IsGamepadButtonPressed(id int, button GamepadButton) bool {
i.m.RLock()
defer i.m.RUnlock()
if len(i.gamepads) <= id {
return false
}
return i.gamepads[id].buttonPressed[button]
}
var emptyTouches = []Touch{}
func (in *Input) Touches() []Touch {
in.m.RLock()
defer in.m.RUnlock()
if len(in.touches) == 0 {
// Avoid creating a slice if possible.
// This is a performance optimization for browsers.
return emptyTouches
}
t := make([]Touch, len(in.touches))
for i := 0; i < len(t); i++ {
t[i] = &in.touches[i]
}
return t
}
type gamePad struct {
valid bool
axisNum int
axes [16]float64
buttonNum int
buttonPressed [256]bool
}
type touch struct {
id int
x int
y int
}
func (t *touch) ID() int {
return t.id
}
func (t *touch) Position() (x, y int) {
return t.x, t.y
}