Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kemokemo/ebiten-virtualpad
virtualpad package for ebiten
https://github.com/kemokemo/ebiten-virtualpad
ebiten ebiten-parts go golang
Last synced: about 1 month ago
JSON representation
virtualpad package for ebiten
- Host: GitHub
- URL: https://github.com/kemokemo/ebiten-virtualpad
- Owner: kemokemo
- License: apache-2.0
- Created: 2021-09-12T02:59:07.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-11-15T13:11:56.000Z (about 2 years ago)
- Last Synced: 2024-11-06T02:14:55.841Z (3 months ago)
- Topics: ebiten, ebiten-parts, go, golang
- Language: Go
- Homepage:
- Size: 531 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Ebiten Virtual Pad
This is a package for displaying virtual directional keys and trigger buttons on the screen to handle user input.
It is intended to be used in games that use [ebiten](https://ebiten.org/).## How to use
Please check [the sample app](https://github.com/kemokemo/ebiten-virtualpad/tree/main/cmd) for more detail.
### Basic
Use the `NewDirectionalPad` and `NewTriggerButton` functions of the vpad package to generate the buttons.
```go
import (
"github.com/hajimehoshi/ebiten/v2"
"github.com/hajimehoshi/ebiten/v2/ebitenutil"
vpad "github.com/kemokemo/ebiten-virtualpad"
)const (
screenWidth = 480
screenHeight = 320
)func NewGame() *Game {
dpad := vpad.NewDirectionalPad(directional_pad, directional_button, vpad.SelectColor)
dpad.SetLocation(10, 180)// vpad.Pressing is continuously triggered while this button is being pressed.
aButton := vpad.NewTriggerButton(a_button, vpad.Pressing, vpad.SelectColor)
aButton.SetLocation(150, 190)// vpad.JustRelease is triggered when this button is released.
bButton := vpad.NewTriggerButton(b_button, vpad.JustReleased, vpad.SelectColor)
bButton.SetLocation(260, 190)// vpad.JustPress is triggered when this button is pressed.
cButton := vpad.NewTriggerButton(c_button, vpad.JustPressed, vpad.SelectColor)
cButton.SetLocation(370, 190)return &Game{dpad: dpad, aButton: aButton, bButton: bButton, cButton: cButton}
}type Game struct {
dpad vpad.DirectionalPad
aButton vpad.TriggerButton
bButton vpad.TriggerButton
cButton vpad.TriggerButton
}
```### Get direction and triggered state
Update the internal state with the `Update` function, and get the direction or trigger presence with the `GetDirection` or `IsTriggered` function.
```go
func (g *Game) Update() error {
g.dpad.Update()
g.aButton.Update()
g.bButton.Update()
g.cButton.Update()return nil
}func (g *Game) Draw(screen *ebiten.Image) {
g.dpad.Draw(screen)
d := g.dpad.GetDirection()
switch d {
case vpad.Upper:
ebitenutil.DebugPrintAt(screen, "Upper direction", 20, 20)
case vpad.Lower:
ebitenutil.DebugPrintAt(screen, "Lower direction", 20, 20)
case vpad.Left:
ebitenutil.DebugPrintAt(screen, "Left direction", 20, 20)
case vpad.Right:
ebitenutil.DebugPrintAt(screen, "Right direction", 20, 20)
}g.aButton.Draw(screen)
if g.aButton.IsTriggered() {
ebitenutil.DebugPrintAt(screen, "A button is being triggered.", 20, 50)
}g.bButton.Draw(screen)
if g.bButton.IsTriggered() {
ebitenutil.DebugPrintAt(screen, "B button is triggered.", 20, 50)
}g.cButton.Draw(screen)
if g.cButton.IsTriggered() {
ebitenutil.DebugPrintAt(screen, "C button is triggered.", 20, 50)
}
}
```### Various triggers
The following types of TriggerButtons are currently available.
| Type | Description |
|---|---|
| JustReleased | This is triggered only when just released. |
|Pressing|This is triggered while this is being pressed.|
|JustPressed|This is triggered only when just pressed.|## License
Apache-2.0 License
## Author
kemokemo