Für Leute (wie mich) fragen, wie KeyEventDispatcher zu verwenden, hier ist ein Beispiel, das ich zusammen. Es verwendet eine HashMap zum Speichern aller globalen Aktionen, weil ich große if (key == ..) then .. else if (key == ..) then .. else if (key ==..) ..
Konstrukte nicht mag.
/** map containing all global actions */
private HashMap<KeyStroke, Action> actionMap = new HashMap<KeyStroke, Action>();
/** call this somewhere in your GUI construction */
private void setup() {
KeyStroke key1 = KeyStroke.getKeyStroke(KeyEvent.VK_A, KeyEvent.CTRL_DOWN_MASK);
actionMap.put(key1, new AbstractAction("action1") {
@Override
public void actionPerformed(ActionEvent e) {
System.out.println("Ctrl-A pressed: " + e);
}
});
// add more actions..
KeyboardFocusManager kfm = KeyboardFocusManager.getCurrentKeyboardFocusManager();
kfm.addKeyEventDispatcher(new KeyEventDispatcher() {
@Override
public boolean dispatchKeyEvent(KeyEvent e) {
KeyStroke keyStroke = KeyStroke.getKeyStrokeForEvent(e);
if (actionMap.containsKey(keyStroke)) {
final Action a = actionMap.get(keyStroke);
final ActionEvent ae = new ActionEvent(e.getSource(), e.getID(), null);
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
a.actionPerformed(ae);
}
});
return true;
}
return false;
}
});
}
Die Verwendung von SwingUtils.invokeLater() ist vielleicht nicht notwendig, aber es ist wahrscheinlich eine gute Idee, nicht die globale Ereignisschleife zu sperren.
+1 Die beste und einfachste Antwort, die ich gefunden habe. Ich werde diese x1000 –
x1001 upvote wäre besser, auf diese Weise würde er zumindest eine Aufwertung bekommen. – Epaga
@Epaga Oder 999 mal –