mirror of
https://git.sr.ht/~eliasnaur/gio
synced 2026-07-04 08:55:35 +00:00
io/key: switch Event.Name to be a string and add function keys
Function keys don't have a natural rune representation so switch Event.Name to be a string to fit "F1"-"F12". Fixes gio#59 Signed-off-by: Elias Naur <mail@eliasnaur.com>
This commit is contained in:
@@ -353,8 +353,8 @@ func runInJVM(f func(env *C.JNIEnv)) {
|
||||
f(env)
|
||||
}
|
||||
|
||||
func convertKeyCode(code C.jint) (rune, bool) {
|
||||
var n rune
|
||||
func convertKeyCode(code C.jint) (string, bool) {
|
||||
var n string
|
||||
switch code {
|
||||
case C.AKEYCODE_DPAD_UP:
|
||||
n = key.NameUpArrow
|
||||
@@ -369,7 +369,7 @@ func convertKeyCode(code C.jint) (rune, bool) {
|
||||
case C.AKEYCODE_DEL:
|
||||
n = key.NameDeleteBackward
|
||||
default:
|
||||
return 0, false
|
||||
return "", false
|
||||
}
|
||||
return n, true
|
||||
}
|
||||
|
||||
@@ -205,7 +205,7 @@ func (w *window) SetAnimating(anim bool) {
|
||||
C.gio_setAnimating(w.view, animi)
|
||||
}
|
||||
|
||||
func (w *window) onKeyCommand(name rune) {
|
||||
func (w *window) onKeyCommand(name string) {
|
||||
w.w.Event(key.Event{
|
||||
Name: name,
|
||||
})
|
||||
|
||||
@@ -383,17 +383,17 @@ func Main() {
|
||||
<-mainDone
|
||||
}
|
||||
|
||||
func translateKey(k string) (rune, bool) {
|
||||
func translateKey(k string) (string, bool) {
|
||||
if len(k) == 1 {
|
||||
c := k[0]
|
||||
if '0' <= c && c <= '9' || 'A' <= c && c <= 'Z' {
|
||||
return rune(c), true
|
||||
return string(c), true
|
||||
}
|
||||
if 'a' <= c && c <= 'z' {
|
||||
return rune(c - 0x20), true
|
||||
return string(c - 0x20), true
|
||||
}
|
||||
}
|
||||
var n rune
|
||||
var n string
|
||||
switch k {
|
||||
case "ArrowUp":
|
||||
n = key.NameUpArrow
|
||||
@@ -419,8 +419,10 @@ func translateKey(k string) (rune, bool) {
|
||||
n = key.NamePageUp
|
||||
case "PageDown":
|
||||
n = key.NamePageDown
|
||||
case "F1", "F2", "F3", "F4", "F5", "F6", "F7", "F8", "F9", "F10", "F11", "F12":
|
||||
n = k
|
||||
default:
|
||||
return 0, false
|
||||
return "", false
|
||||
}
|
||||
return n, true
|
||||
}
|
||||
|
||||
@@ -289,14 +289,14 @@ func Main() {
|
||||
C.gio_main(view, title, C.CGFloat(w), C.CGFloat(h))
|
||||
}
|
||||
|
||||
func convertKey(k rune) (rune, bool) {
|
||||
func convertKey(k rune) (string, bool) {
|
||||
if '0' <= k && k <= '9' || 'A' <= k && k <= 'Z' {
|
||||
return k, true
|
||||
return string(k), true
|
||||
}
|
||||
if 'a' <= k && k <= 'z' {
|
||||
return k - 0x20, true
|
||||
return string(k - 0x20), true
|
||||
}
|
||||
var n rune
|
||||
var n string
|
||||
switch k {
|
||||
case 0x1b:
|
||||
n = key.NameEscape
|
||||
@@ -322,8 +322,32 @@ func convertKey(k rune) (rune, bool) {
|
||||
n = key.NamePageUp
|
||||
case C.NSPageDownFunctionKey:
|
||||
n = key.NamePageDown
|
||||
case C.NSF1FunctionKey:
|
||||
n = "F1"
|
||||
case C.NSF2FunctionKey:
|
||||
n = "F2"
|
||||
case C.NSF3FunctionKey:
|
||||
n = "F3"
|
||||
case C.NSF4FunctionKey:
|
||||
n = "F4"
|
||||
case C.NSF5FunctionKey:
|
||||
n = "F5"
|
||||
case C.NSF6FunctionKey:
|
||||
n = "F6"
|
||||
case C.NSF7FunctionKey:
|
||||
n = "F7"
|
||||
case C.NSF8FunctionKey:
|
||||
n = "F8"
|
||||
case C.NSF9FunctionKey:
|
||||
n = "F9"
|
||||
case C.NSF10FunctionKey:
|
||||
n = "F10"
|
||||
case C.NSF11FunctionKey:
|
||||
n = "F11"
|
||||
case C.NSF12FunctionKey:
|
||||
n = "F12"
|
||||
default:
|
||||
return 0, false
|
||||
return "", false
|
||||
}
|
||||
return n, true
|
||||
}
|
||||
|
||||
@@ -112,6 +112,19 @@ const (
|
||||
_VK_RETURN = 0x0d
|
||||
_VK_UP = 0x26
|
||||
|
||||
_VK_F1 = 0x70
|
||||
_VK_F2 = 0x71
|
||||
_VK_F3 = 0x72
|
||||
_VK_F4 = 0x73
|
||||
_VK_F5 = 0x74
|
||||
_VK_F6 = 0x75
|
||||
_VK_F7 = 0x76
|
||||
_VK_F8 = 0x77
|
||||
_VK_F9 = 0x78
|
||||
_VK_F10 = 0x79
|
||||
_VK_F11 = 0x7A
|
||||
_VK_F12 = 0x7B
|
||||
|
||||
_UNICODE_NOCHAR = 65535
|
||||
|
||||
_WM_CANCELMODE = 0x001F
|
||||
@@ -457,11 +470,11 @@ func (w *window) HWND() (syscall.Handle, int, int) {
|
||||
return w.hwnd, w.width, w.height
|
||||
}
|
||||
|
||||
func convertKeyCode(code uintptr) (rune, bool) {
|
||||
func convertKeyCode(code uintptr) (string, bool) {
|
||||
if '0' <= code && code <= '9' || 'A' <= code && code <= 'Z' {
|
||||
return rune(code), true
|
||||
return string(code), true
|
||||
}
|
||||
var r rune
|
||||
var r string
|
||||
switch code {
|
||||
case _VK_ESCAPE:
|
||||
r = key.NameEscape
|
||||
@@ -487,8 +500,32 @@ func convertKeyCode(code uintptr) (rune, bool) {
|
||||
r = key.NamePageUp
|
||||
case _VK_NEXT:
|
||||
r = key.NamePageDown
|
||||
case _VK_F1:
|
||||
r = "F1"
|
||||
case _VK_F2:
|
||||
r = "F2"
|
||||
case _VK_F3:
|
||||
r = "F3"
|
||||
case _VK_F4:
|
||||
r = "F4"
|
||||
case _VK_F5:
|
||||
r = "F5"
|
||||
case _VK_F6:
|
||||
r = "F6"
|
||||
case _VK_F7:
|
||||
r = "F7"
|
||||
case _VK_F8:
|
||||
r = "F8"
|
||||
case _VK_F9:
|
||||
r = "F9"
|
||||
case _VK_F10:
|
||||
r = "F10"
|
||||
case _VK_F11:
|
||||
r = "F11"
|
||||
case _VK_F12:
|
||||
r = "F12"
|
||||
default:
|
||||
return 0, false
|
||||
return "", false
|
||||
}
|
||||
return r, true
|
||||
}
|
||||
|
||||
@@ -257,8 +257,8 @@ func (h *x11EventHandler) handleEvents() bool {
|
||||
if r, ok := x11SpecialKeySymToRune(h.keysym); ok {
|
||||
w.w.Event(key.Event{Name: r, Modifiers: mods})
|
||||
} else {
|
||||
if r, _ = utf8.DecodeRune(h.text[:l]); r != utf8.RuneError {
|
||||
w.w.Event(key.Event{Name: unicode.ToUpper(r), Modifiers: mods})
|
||||
if r, _ := utf8.DecodeRune(h.text[:l]); r != utf8.RuneError {
|
||||
w.w.Event(key.Event{Name: string(unicode.ToUpper(r)), Modifiers: mods})
|
||||
}
|
||||
// Send EditEvent only when not a CTRL key combination.
|
||||
if !mods.Contain(key.ModCtrl) {
|
||||
@@ -349,8 +349,8 @@ func x11KeyStateToModifiers(s C.uint) key.Modifiers {
|
||||
return m
|
||||
}
|
||||
|
||||
func x11SpecialKeySymToRune(s C.KeySym) (rune, bool) {
|
||||
var n rune
|
||||
func x11SpecialKeySymToRune(s C.KeySym) (string, bool) {
|
||||
var n string
|
||||
switch s {
|
||||
case C.XK_Escape:
|
||||
n = key.NameEscape
|
||||
@@ -378,8 +378,32 @@ func x11SpecialKeySymToRune(s C.KeySym) (rune, bool) {
|
||||
n = key.NamePageUp
|
||||
case C.XK_Page_Down, C.XK_KP_Next:
|
||||
n = key.NamePageDown
|
||||
case C.XK_F1:
|
||||
n = "F1"
|
||||
case C.XK_F2:
|
||||
n = "F2"
|
||||
case C.XK_F3:
|
||||
n = "F3"
|
||||
case C.XK_F4:
|
||||
n = "F4"
|
||||
case C.XK_F5:
|
||||
n = "F5"
|
||||
case C.XK_F6:
|
||||
n = "F6"
|
||||
case C.XK_F7:
|
||||
n = "F7"
|
||||
case C.XK_F8:
|
||||
n = "F8"
|
||||
case C.XK_F9:
|
||||
n = "F9"
|
||||
case C.XK_F10:
|
||||
n = "F10"
|
||||
case C.XK_F11:
|
||||
n = "F11"
|
||||
case C.XK_F12:
|
||||
n = "F12"
|
||||
default:
|
||||
return 0, false
|
||||
return "", false
|
||||
}
|
||||
return n, true
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user