examples/keyboard: Refactoring: Use ebiten.Key to get the rect

This commit is contained in:
Hajime Hoshi 2018-04-14 04:48:07 +09:00
parent 9fb25693a3
commit bf304e6ac8
3 changed files with 145 additions and 124 deletions

View File

@ -80,6 +80,68 @@ var keyboardKeys = [][]string{
{"Left", "Down", "Right"}, {"Left", "Down", "Right"},
} }
func keyDisplayNameToKey(name string) ebiten.Key {
switch name {
case "Esc":
return ebiten.KeyEscape
case "Tab":
return ebiten.KeyTab
case "Ctrl":
return ebiten.KeyControl
case "Shift":
return ebiten.KeyShift
case "Alt":
return ebiten.KeyAlt
case "Space":
return ebiten.KeySpace
case "Up":
return ebiten.KeyUp
case "Left":
return ebiten.KeyLeft
case "Down":
return ebiten.KeyDown
case "Right":
return ebiten.KeyRight
case "BS":
return ebiten.KeyBackspace
case "Enter":
return ebiten.KeyEnter
case "-":
return ebiten.KeyMinus
case "=":
return ebiten.KeyEqual
case "\\":
return ebiten.KeyBackslash
case "`":
return ebiten.KeyGraveAccent
case "[":
return ebiten.KeyLeftBracket
case "]":
return ebiten.KeyRightBracket
case ";":
return ebiten.KeySemicolon
case "'":
return ebiten.KeyApostrophe
case ",":
return ebiten.KeyComma
case ".":
return ebiten.KeyPeriod
case "/":
return ebiten.KeySlash
}
if len(name) != 1 {
panic("not reached: unknown key " + name)
}
c := name[0]
if '0' <= c && c <= '9' {
return ebiten.Key0 + ebiten.Key(c-'0')
}
if 'A' <= c && c <= 'Z' {
return ebiten.KeyA + ebiten.Key(c-'A')
}
panic("not reached: unknown key " + name)
}
func drawKey(t *ebiten.Image, name string, x, y, width int) { func drawKey(t *ebiten.Image, name string, x, y, width int) {
const height = 16 const height = 16
width-- width--
@ -129,14 +191,14 @@ func drawKey(t *ebiten.Image, name string, x, y, width int) {
t.DrawImage(img, op) t.DrawImage(img, op)
} }
func outputKeyboardImage() (map[string]image.Rectangle, error) { func outputKeyboardImage() (map[ebiten.Key]image.Rectangle, error) {
keyMap := map[string]image.Rectangle{} keyMap := map[ebiten.Key]image.Rectangle{}
img, _ := ebiten.NewImage(320, 240, ebiten.FilterDefault) img, _ := ebiten.NewImage(320, 240, ebiten.FilterDefault)
x, y := 0, 0 x, y := 0, 0
for j, line := range keyboardKeys { for j, line := range keyboardKeys {
x = 0 x = 0
const height = 18 const height = 18
for i, key := range line { for i, keyDisplayName := range line {
width := 16 width := 16
switch j { switch j {
default: default:
@ -164,9 +226,10 @@ func outputKeyboardImage() (map[string]image.Rectangle, error) {
case 6, 7: case 6, 7:
width = 16 * 3 width = 16 * 3
} }
if key != "" { if keyDisplayName != "" {
drawKey(img, key, x, y, width) drawKey(img, keyDisplayName, x, y, width)
if key != " " { if keyDisplayName != " " {
key := keyDisplayNameToKey(keyDisplayName)
keyMap[key] = image.Rect(x, y, x+width, y+height) keyMap[key] = image.Rect(x, y, x+width, y+height)
} }
} }
@ -206,20 +269,22 @@ package keyboard
import ( import (
"image" "image"
"github.com/hajimehoshi/ebiten"
) )
var keyboardKeyRects = map[string]image.Rectangle{} var keyboardKeyRects = map[ebiten.Key]image.Rectangle{}
func init() { func init() {
{{range $key, $rect := .KeyRectsMap}} keyboardKeyRects[{{printf "%q" $key}}] = image.Rect({{$rect.Min.X}}, {{$rect.Min.Y}}, {{$rect.Max.X}}, {{$rect.Max.Y}}) {{range $key, $rect := .KeyRectsMap}} keyboardKeyRects[ebiten.Key{{$key}}] = image.Rect({{$rect.Min.X}}, {{$rect.Min.Y}}, {{$rect.Max.X}}, {{$rect.Max.Y}})
{{end}}} {{end}}}
func KeyRect(name string) (image.Rectangle, bool) { func KeyRect(key ebiten.Key) (image.Rectangle, bool) {
r, ok := keyboardKeyRects[name] r, ok := keyboardKeyRects[key]
return r, ok return r, ok
}` }`
func outputKeyRectsGo(k map[string]image.Rectangle) error { func outputKeyRectsGo(k map[ebiten.Key]image.Rectangle) error {
license, err := internal.LicenseComment() license, err := internal.LicenseComment()
if err != nil { if err != nil {
return err return err
@ -245,7 +310,7 @@ func outputKeyRectsGo(k map[string]image.Rectangle) error {
var regularTermination = errors.New("regular termination") var regularTermination = errors.New("regular termination")
func main() { func main() {
var rects map[string]image.Rectangle var rects map[ebiten.Key]image.Rectangle
if err := ebiten.Run(func(_ *ebiten.Image) error { if err := ebiten.Run(func(_ *ebiten.Image) error {
var err error var err error
rects, err = outputKeyboardImage() rects, err = outputKeyboardImage()

View File

@ -18,73 +18,75 @@ package keyboard
import ( import (
"image" "image"
"github.com/hajimehoshi/ebiten"
) )
var keyboardKeyRects = map[string]image.Rectangle{} var keyboardKeyRects = map[ebiten.Key]image.Rectangle{}
func init() { func init() {
keyboardKeyRects["'"] = image.Rect(208, 36, 224, 54) keyboardKeyRects[ebiten.Key0] = image.Rect(176, 0, 192, 18)
keyboardKeyRects[","] = image.Rect(168, 54, 184, 72) keyboardKeyRects[ebiten.Key1] = image.Rect(32, 0, 48, 18)
keyboardKeyRects["-"] = image.Rect(192, 0, 208, 18) keyboardKeyRects[ebiten.Key2] = image.Rect(48, 0, 64, 18)
keyboardKeyRects["."] = image.Rect(184, 54, 200, 72) keyboardKeyRects[ebiten.Key3] = image.Rect(64, 0, 80, 18)
keyboardKeyRects["/"] = image.Rect(200, 54, 216, 72) keyboardKeyRects[ebiten.Key4] = image.Rect(80, 0, 96, 18)
keyboardKeyRects["0"] = image.Rect(176, 0, 192, 18) keyboardKeyRects[ebiten.Key5] = image.Rect(96, 0, 112, 18)
keyboardKeyRects["1"] = image.Rect(32, 0, 48, 18) keyboardKeyRects[ebiten.Key6] = image.Rect(112, 0, 128, 18)
keyboardKeyRects["2"] = image.Rect(48, 0, 64, 18) keyboardKeyRects[ebiten.Key7] = image.Rect(128, 0, 144, 18)
keyboardKeyRects["3"] = image.Rect(64, 0, 80, 18) keyboardKeyRects[ebiten.Key8] = image.Rect(144, 0, 160, 18)
keyboardKeyRects["4"] = image.Rect(80, 0, 96, 18) keyboardKeyRects[ebiten.Key9] = image.Rect(160, 0, 176, 18)
keyboardKeyRects["5"] = image.Rect(96, 0, 112, 18) keyboardKeyRects[ebiten.KeyA] = image.Rect(48, 36, 64, 54)
keyboardKeyRects["6"] = image.Rect(112, 0, 128, 18) keyboardKeyRects[ebiten.KeyB] = image.Rect(120, 54, 136, 72)
keyboardKeyRects["7"] = image.Rect(128, 0, 144, 18) keyboardKeyRects[ebiten.KeyC] = image.Rect(88, 54, 104, 72)
keyboardKeyRects["8"] = image.Rect(144, 0, 160, 18) keyboardKeyRects[ebiten.KeyD] = image.Rect(80, 36, 96, 54)
keyboardKeyRects["9"] = image.Rect(160, 0, 176, 18) keyboardKeyRects[ebiten.KeyE] = image.Rect(72, 18, 88, 36)
keyboardKeyRects[";"] = image.Rect(192, 36, 208, 54) keyboardKeyRects[ebiten.KeyF] = image.Rect(96, 36, 112, 54)
keyboardKeyRects["="] = image.Rect(208, 0, 224, 18) keyboardKeyRects[ebiten.KeyG] = image.Rect(112, 36, 128, 54)
keyboardKeyRects["A"] = image.Rect(48, 36, 64, 54) keyboardKeyRects[ebiten.KeyH] = image.Rect(128, 36, 144, 54)
keyboardKeyRects["Alt"] = image.Rect(64, 72, 96, 90) keyboardKeyRects[ebiten.KeyI] = image.Rect(152, 18, 168, 36)
keyboardKeyRects["B"] = image.Rect(120, 54, 136, 72) keyboardKeyRects[ebiten.KeyJ] = image.Rect(144, 36, 160, 54)
keyboardKeyRects["BS"] = image.Rect(232, 18, 272, 36) keyboardKeyRects[ebiten.KeyK] = image.Rect(160, 36, 176, 54)
keyboardKeyRects["C"] = image.Rect(88, 54, 104, 72) keyboardKeyRects[ebiten.KeyL] = image.Rect(176, 36, 192, 54)
keyboardKeyRects["Ctrl"] = image.Rect(0, 36, 48, 54) keyboardKeyRects[ebiten.KeyM] = image.Rect(152, 54, 168, 72)
keyboardKeyRects["D"] = image.Rect(80, 36, 96, 54) keyboardKeyRects[ebiten.KeyN] = image.Rect(136, 54, 152, 72)
keyboardKeyRects["Down"] = image.Rect(48, 126, 96, 144) keyboardKeyRects[ebiten.KeyO] = image.Rect(168, 18, 184, 36)
keyboardKeyRects["E"] = image.Rect(72, 18, 88, 36) keyboardKeyRects[ebiten.KeyP] = image.Rect(184, 18, 200, 36)
keyboardKeyRects["Enter"] = image.Rect(224, 36, 272, 54) keyboardKeyRects[ebiten.KeyQ] = image.Rect(40, 18, 56, 36)
keyboardKeyRects["Esc"] = image.Rect(0, 0, 32, 18) keyboardKeyRects[ebiten.KeyR] = image.Rect(88, 18, 104, 36)
keyboardKeyRects["F"] = image.Rect(96, 36, 112, 54) keyboardKeyRects[ebiten.KeyS] = image.Rect(64, 36, 80, 54)
keyboardKeyRects["G"] = image.Rect(112, 36, 128, 54) keyboardKeyRects[ebiten.KeyT] = image.Rect(104, 18, 120, 36)
keyboardKeyRects["H"] = image.Rect(128, 36, 144, 54) keyboardKeyRects[ebiten.KeyU] = image.Rect(136, 18, 152, 36)
keyboardKeyRects["I"] = image.Rect(152, 18, 168, 36) keyboardKeyRects[ebiten.KeyV] = image.Rect(104, 54, 120, 72)
keyboardKeyRects["J"] = image.Rect(144, 36, 160, 54) keyboardKeyRects[ebiten.KeyW] = image.Rect(56, 18, 72, 36)
keyboardKeyRects["K"] = image.Rect(160, 36, 176, 54) keyboardKeyRects[ebiten.KeyX] = image.Rect(72, 54, 88, 72)
keyboardKeyRects["L"] = image.Rect(176, 36, 192, 54) keyboardKeyRects[ebiten.KeyY] = image.Rect(120, 18, 136, 36)
keyboardKeyRects["Left"] = image.Rect(0, 126, 48, 144) keyboardKeyRects[ebiten.KeyZ] = image.Rect(56, 54, 72, 72)
keyboardKeyRects["M"] = image.Rect(152, 54, 168, 72) keyboardKeyRects[ebiten.KeyAlt] = image.Rect(64, 72, 96, 90)
keyboardKeyRects["N"] = image.Rect(136, 54, 152, 72) keyboardKeyRects[ebiten.KeyApostrophe] = image.Rect(208, 36, 224, 54)
keyboardKeyRects["O"] = image.Rect(168, 18, 184, 36) keyboardKeyRects[ebiten.KeyBackslash] = image.Rect(224, 0, 240, 18)
keyboardKeyRects["P"] = image.Rect(184, 18, 200, 36) keyboardKeyRects[ebiten.KeyBackspace] = image.Rect(232, 18, 272, 36)
keyboardKeyRects["Q"] = image.Rect(40, 18, 56, 36) keyboardKeyRects[ebiten.KeyComma] = image.Rect(168, 54, 184, 72)
keyboardKeyRects["R"] = image.Rect(88, 18, 104, 36) keyboardKeyRects[ebiten.KeyControl] = image.Rect(0, 36, 48, 54)
keyboardKeyRects["Right"] = image.Rect(96, 126, 144, 144) keyboardKeyRects[ebiten.KeyDown] = image.Rect(48, 126, 96, 144)
keyboardKeyRects["S"] = image.Rect(64, 36, 80, 54) keyboardKeyRects[ebiten.KeyEnter] = image.Rect(224, 36, 272, 54)
keyboardKeyRects["Shift"] = image.Rect(0, 54, 56, 72) keyboardKeyRects[ebiten.KeyEqual] = image.Rect(208, 0, 224, 18)
keyboardKeyRects["Space"] = image.Rect(96, 72, 176, 90) keyboardKeyRects[ebiten.KeyEscape] = image.Rect(0, 0, 32, 18)
keyboardKeyRects["T"] = image.Rect(104, 18, 120, 36) keyboardKeyRects[ebiten.KeyGraveAccent] = image.Rect(240, 0, 256, 18)
keyboardKeyRects["Tab"] = image.Rect(0, 18, 40, 36) keyboardKeyRects[ebiten.KeyLeft] = image.Rect(0, 126, 48, 144)
keyboardKeyRects["U"] = image.Rect(136, 18, 152, 36) keyboardKeyRects[ebiten.KeyLeftBracket] = image.Rect(200, 18, 216, 36)
keyboardKeyRects["Up"] = image.Rect(48, 108, 96, 126) keyboardKeyRects[ebiten.KeyMinus] = image.Rect(192, 0, 208, 18)
keyboardKeyRects["V"] = image.Rect(104, 54, 120, 72) keyboardKeyRects[ebiten.KeyPeriod] = image.Rect(184, 54, 200, 72)
keyboardKeyRects["W"] = image.Rect(56, 18, 72, 36) keyboardKeyRects[ebiten.KeyRight] = image.Rect(96, 126, 144, 144)
keyboardKeyRects["X"] = image.Rect(72, 54, 88, 72) keyboardKeyRects[ebiten.KeyRightBracket] = image.Rect(216, 18, 232, 36)
keyboardKeyRects["Y"] = image.Rect(120, 18, 136, 36) keyboardKeyRects[ebiten.KeySemicolon] = image.Rect(192, 36, 208, 54)
keyboardKeyRects["Z"] = image.Rect(56, 54, 72, 72) keyboardKeyRects[ebiten.KeyShift] = image.Rect(0, 54, 56, 72)
keyboardKeyRects["["] = image.Rect(200, 18, 216, 36) keyboardKeyRects[ebiten.KeySlash] = image.Rect(200, 54, 216, 72)
keyboardKeyRects["\\"] = image.Rect(224, 0, 240, 18) keyboardKeyRects[ebiten.KeySpace] = image.Rect(96, 72, 176, 90)
keyboardKeyRects["]"] = image.Rect(216, 18, 232, 36) keyboardKeyRects[ebiten.KeyTab] = image.Rect(0, 18, 40, 36)
keyboardKeyRects["`"] = image.Rect(240, 0, 256, 18) keyboardKeyRects[ebiten.KeyUp] = image.Rect(48, 108, 96, 126)
} }
func KeyRect(name string) (image.Rectangle, bool) { func KeyRect(key ebiten.Key) (image.Rectangle, bool) {
r, ok := keyboardKeyRects[name] r, ok := keyboardKeyRects[key]
return r, ok return r, ok
} }

View File

@ -21,7 +21,6 @@ import (
"image" "image"
_ "image/png" _ "image/png"
"log" "log"
"strconv"
"github.com/hajimehoshi/ebiten" "github.com/hajimehoshi/ebiten"
"github.com/hajimehoshi/ebiten/examples/keyboard/keyboard" "github.com/hajimehoshi/ebiten/examples/keyboard/keyboard"
@ -44,57 +43,12 @@ func init() {
keyboardImage, _ = ebiten.NewImageFromImage(img, ebiten.FilterDefault) keyboardImage, _ = ebiten.NewImageFromImage(img, ebiten.FilterDefault)
} }
var keyNames = map[ebiten.Key]string{
ebiten.KeyBackspace: "BS",
ebiten.KeyComma: ",",
ebiten.KeyEnter: "Enter",
ebiten.KeyEscape: "Esc",
ebiten.KeyPeriod: ".",
ebiten.KeySpace: "Space",
ebiten.KeyTab: "Tab",
ebiten.KeyMinus: "-",
ebiten.KeyEqual: "=",
ebiten.KeyBackslash: "\\",
ebiten.KeyGraveAccent: "`",
ebiten.KeyLeftBracket: "[",
ebiten.KeyRightBracket: "]",
ebiten.KeySemicolon: ";",
ebiten.KeyApostrophe: "'",
ebiten.KeySlash: "/",
// Arrows
ebiten.KeyDown: "Down",
ebiten.KeyLeft: "Left",
ebiten.KeyRight: "Right",
ebiten.KeyUp: "Up",
// Mods
ebiten.KeyShift: "Shift",
ebiten.KeyControl: "Ctrl",
ebiten.KeyAlt: "Alt",
}
func update(screen *ebiten.Image) error { func update(screen *ebiten.Image) error {
// Collect pressed keys' names. // Collect pressed keys' names.
pressed := []string{} pressed := []ebiten.Key{}
for i := 0; i <= 9; i++ { for k := ebiten.Key(0); k <= ebiten.KeyMax; k++ {
if ebiten.IsKeyPressed(ebiten.Key(i) + ebiten.Key0) { if ebiten.IsKeyPressed(k) {
pressed = append(pressed, string(i+'0')) pressed = append(pressed, k)
}
}
for c := 'A'; c <= 'Z'; c++ {
if ebiten.IsKeyPressed(ebiten.KeyA + ebiten.Key(c-'A')) {
pressed = append(pressed, string(c))
}
}
for i := 1; i <= 12; i++ {
if ebiten.IsKeyPressed(ebiten.KeyF1 + ebiten.Key(i-1)) {
pressed = append(pressed, "F"+strconv.Itoa(i))
}
}
for key, name := range keyNames {
if ebiten.IsKeyPressed(key) {
pressed = append(pressed, name)
} }
} }