Несмотря на то, что спрашивающий был удовлетворен button.doClick()
, я искал что-то вроде того, что происходит после установки мнемоники, то есть с button.setMnemonic(KeyEvent.VK_A)
.Вы можете фактически удерживать ALT + A без чего-либо происходящего (кроме визуального изменения).И после отпускания ключа A (с или без ALT) кнопка запускает ActionEvent.
Я обнаружил, что могу получить ButtonModel (см. Java 8 API ) с button.getModel()
, затем визуально нажмите кнопку с помощью model.setPressed(true); model.setArmed(true);
(оба мнемоники меняются) и визуально отпустите кнопку, установив для обоих параметров значение false
.И когда model.setPressed(false)
вызывается, когда кнопка и нажата, и включена, кнопка автоматически запускает ActionEvent (вызов model.setArmed(false)
только изменяет кнопку визуально).
[Цитата из документации ButtonModel по Java API] Кнопка срабатывает, и ActionEvent запускается, когда мышь отпускается, когда модель активирована [...]
Чтобы приложение реагировало на нажатия клавиш, когда кнопка видна (без содержащего окна или кнопки, которая должна быть владельцем фокуса, т. е. когда фокусируется другой компонент в окне) Я использовал привязки клавиш (см. Официальное руководство по Java ).
Рабочий код: Нажмите SHIFT + A, чтобы визуально нажать кнопку (в отличие от нажатия ALT клавишей после того, как мнемоника установлена с помощью button.setMnemonic()
).И отпустите клавишу, чтобы напечатать команду действия («кнопка») на консоли.
// MnemonicCode.java
import javax.swing.*;
import java.awt.event.*;
public class MnemonicCode extends JFrame
{
public MnemonicCode(int keyCode)
{
JButton button = new JButton("button");
getContentPane().add(button);
addMnemonicToButton(button,keyCode);
button.addActionListener(new ActionListener () {
public void actionPerformed(ActionEvent e)
{
System.out.println(e.getActionCommand());
}
});
pack();
setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
setVisible(true);
}
public static void main(String[] args) throws Exception
{
MnemonicCode bp = new MnemonicCode(KeyEvent.VK_A);
}
void addMnemonicToButton(JButton button,int keyCode)
{
int shiftMask = InputEvent.SHIFT_DOWN_MASK;
// signature: getKeyStroke(int keyCode, int modifiers, boolean onKeyRelease)
KeyStroke keyPress = KeyStroke.getKeyStroke(keyCode,shiftMask,false);
KeyStroke keyReleaseWithShift = KeyStroke.getKeyStroke(keyCode,shiftMask,true);
// get maps for key bindings
InputMap inputMap = button.getInputMap(JComponent.WHEN_IN_FOCUSED_WINDOW);
ActionMap actionMap = button.getActionMap();
// add key bindings for pressing and releasing the button
inputMap.put(keyPress,"press"+keyCode);
actionMap.put("press"+keyCode, new ButtonPress(button));
inputMap.put(keyReleaseWithShift,"releaseWithShift"+keyCode);
actionMap.put("releaseWithShift"+keyCode, new ButtonRelease(button));
///*
// add key binding for releasing SHIFT before A
// if you use more than one modifier it gets really messy
KeyStroke keyReleaseAfterShift = KeyStroke.getKeyStroke(keyCode,0,true);
inputMap.put(keyReleaseAfterShift,"releaseAfterShift"+keyCode);
actionMap.put("releaseAfterShift"+keyCode, new ButtonRelease(button));
//*/
}
class ButtonPress extends AbstractAction
{
private JButton button;
private ButtonModel model;
ButtonPress(JButton button)
{
this.button = button;
this.model = button.getModel();
}
public void actionPerformed(ActionEvent e)
{
// visually press the button
model.setPressed(true);
model.setArmed(true);
button.requestFocusInWindow();
}
}
class ButtonRelease extends AbstractAction
{
private ButtonModel model;
ButtonRelease(JButton button)
{
this.model = button.getModel();
}
public void actionPerformed(ActionEvent e)
{
if (model.isPressed()) {
// visually release the button
// setPressed(false) also makes the button fire an ActionEvent
model.setPressed(false);
model.setArmed(false);
}
}
}
}