
package test; import javaawteventKeyEvent;import javaawteventKeyListener;import javaawteventWindowAdapter;import javaawteventWindowEvent; import javaxswingJFrame; public class MyListener implements KeyListener{ public void keyPressed(KeyEvent e) { int code = egetKeyCode(); if(code==KeyEventVK_ENTER){ Systemoutprintln("回车"); } } public void keyReleased(KeyEvent e) { } public void keyTyped(KeyEvent e) { } public static void main(String[] args) { ABC abc = new ABC(); abcsetVisible(true); } } class ABC extends JFrame{ private MyListener listener; public ABC(){ listener = new MyListener(); thisaddKeyListener(listener); }}
import javaawt;
import javaxswing;
import javaawtevent;
class ziti implements KeyListener
{JFrame jf;
JComboBox jc;
String[] kk={"隶书","楷体","黑体","宋体"};
String str="隶书"; int k1=FontPLAIN; int k2=16;
ziti()
{jf=new JFrame("字体事件测试");
jc=new JComboBox(kk)
Container co=jfgetContentPane();
JPanel pp=new JPanel();
coadd(pp);
ppsetLayout(null);
ppadd(jc
jfsetSize(400,500);
jfsetLocation(50,50);
jfsetVisible (true);
jcsetBounds(10,100,100,30);
jcaddKeyListener(this);
}
public void keyTyped(KeyEvent e)
{ str=kk[jcgetSelectedIndex()];
}
public void keyPressed(KeyEvent e){}
public void keyReleased(KeyEvent e){}
}
public class cv1
{public static void main(String[] args)
{ new ziti();
}
}
基本上就是这么写的 里面加你要写的就好咯 有什么问题你可以追问
方法一 实现KeyListener 接口并复写其中的方法
public class Test extends JFrame implements KeyListener{
public void keyPressed(KeyEvent e) {} // 按键按下
public void keyReleased(KeyEvent e){} // 按键松开
}
具体使用:
public void keyPressed(KeyEvent e) {
switch (egetKeyCode()) {
case KeyEventVK_ENTER: // 按下回车键
// 在这里写代码
break;
case KeyEventVK_UP: // 按下方向键上
// 在这里写代码
break;
}
在jdk 中 分别针对Jponent和Text类的对象定制了不同的处理键盘事件的方法 在Jponent中 定义了registerKeyboardAction方法 使用这个方法来将需要处理的键盘事件以及处理事件的行为绑定在一起 Text类中具有keymap对象 同Jponent中的处理方法类似 这个对象保存著需要处理的键盘事件和对应的行为
而在jdk 中 使用一种新的方法来处理键盘事件 它将jdk 的两种方法整合在一起 不需要区分被处理的是Jponent还是Text类型的组件 它定义了两个新的类 InputMap和ActionMap 他们均是简单的表或映射 一个InputMap将一个Keystroke对应到一个对象 ActionMap将一个对象对应到一个行为(Action) 通常InputMap中KeyStroke所对应的对象是一个字符串 通过这个字符串可以在ActionMap中查找到相应的行为
InputMap和ActionMap中均有put方法 InputMap的put方法可以将Keystroke对应到一个对象 而ActionMap的put方法可以将一个对象对应到一个行为
在每一个Jponent组件中 会有三个缺省的InputMap和一个缺省的ActionMap 他们可以通过调用getInputMap(int condition)和getActionMap()得到 三个InputMap分别是当组件本身拥有焦点时的InputMap(WHEN_FOCUSED) 当组件的祖先拥有焦点时的InputMap(WHEN_ANCESTOR_OF_FOCUSED_PONENT)和组件所在的窗体具有焦点时的InputMap(WHEN_IN_FOCUSED_WINDOW)(括号内表示为了得到这些InputMap 应该在getInputMap中设置的参数) 以下分别说明这三种InputMap:
组件本身拥有焦点时的InputMap:当组件拥有焦点时 键盘按键按下 则java在这个InputMap中查找键盘事件所对应的KeyStroke对象
组件的祖先拥有焦点时的InputMap:当组件的祖先拥有焦点时 键盘按键按下 则java查找这个InputMap
组件所在的窗口拥有焦点时的InputMap:当组件所在的窗口具有焦点时 键盘按键按下 则java查找这个InputMap
当一个键被按下 这个事件被转化成一个KeyStroke对象 java会查找这个Jponent的相应InputMap(例如 当组件的祖先具有焦点时 java就查找这个Jponent的祖先拥有焦点的InputMap)中是否有这个KeyStroke 如果有 取出它所对应的对象(通常是字符串) 利用这个对象在这个Jponent的ActionMap中查找 如果找到对应的行为(Action) 则java执行这个行为的actionPerformed方法(随后介绍这个方法) 从而达到处理键盘事件的目的
每一个InputMap可以具有parent属性 这个属性的值是一个InputMap 当在一个InputMap中查找不到键盘事件的KeyStroke时 java会自动在它的parent属性指定的InputMap中查找 依次向上查找 直至找到 使用parent的好处是 当有一些固定的 不希望用户进行改动的键盘映射可以存放在parent属性所指定的InputMap中 从而避免被意外修改 另外可以将多个Jponent的缺省InputMap设置具有相同的parent 使得可以共享一些键盘绑定的设置 可以通过InputMap类的setparent()方法设置它的parent属性 ActionMap也具有相同的parent属性 使用方法也相同
以上是如何将一个键盘事件对应到一个行为 以下就简单介绍行为(Action)
行为是一个实现了Action接口的类 在Action接口中定义了 个方法 其中最关键的是actionPerformed()方法 这个方法描述了这个行为的具体 *** 作过程 其他几个方法包括setEnabled isEnabled putValue getValue addPropertyChangeListener 和removePropertyChangeListener方法 他们分别用来设置行为是否可用 判断行为可用的状态 设置和取得行为的一些属性 最后两个方法用来允许其他对象在行动对象的属性发生变化后得到通知
通常我们使用一个实现了Action接口的大部分方法的抽象类AbstractAction类作为基类 重载actionPerformed方法以实现我们的行为
我们用一个例子来具体说明如何进行实际的 *** 作
首先编写一个具体的行为 对指定的键盘事件进行处理
public class TextAction extends AbstractAction
{
private String a;
public TextAction(String a)
{ this a = a; }
public void actionPerformed(ActionEvent parm )
{
String b = parm getActionCommand() //得到行为的命令字符串
System out println( mand= +b)
System out println( prompt= +this a)
}
}
建立四个TextAction对象
TextAction whenFocusSon = new TextAction( focus son )
TextAction whenFocusFather = new TextAction( focus father )
TextAction window = new TextAction( window )
TextAction ancestor = new TextAction( ancestor )
随后 在一个窗体中加入两个面板 名为sonPanel和parentPanel 使得parentPanel是sonPanel的祖先 并在sonPanel中加入一个名为son的button 在parentPanel中加入名为parent的button 在fatherPanel外加入几个button
得到son组件的三个InputMap 并创建一个名为focusFatherIm的InputMap 使得这个InputMap成为focusIm的parent:
//get default inputMap (when focus inputmap) and set a parent InputMap
focusIm = son getInputMap()
focusFatherIm = new InputMap()
focusIm setParent(focusFatherIm)
//get WHEN_ANCESTOR_OF_FOCUSED_PONENT inputMap
ancestorIm = son getInputMap(WHEN_ANCESTOR_OF_FOCUSED_PONENT)
//get WHEN_IN_FOCUSED_WINDOW inputMap
windowIm = son getInputMap(WHEN_IN_FOCUSED_WINDOW)
在这些InputMap中分别加入键盘绑定
focusIm put(KeyStroke getKeyStroke( f ) actionFocusSon )
focusFatherIm put(KeyStroke getKeyStroke( F ) actionFocusFather )
ancestorIm put(KeyStroke getKeyStroke( a ) actionAncestor )
windowIm put(KeyStroke getKeyStroke( w ) actionWindow )
得到son组件的缺省的ActionMap 并将已经建立的行为与特定的对象(字符串)进行绑定
am = son getActionMap()
am put( actionFocusSon whenFocusSon)
am put( actionFocusFather whenFocusFather)
am put( actionAncestor ancestor)
am put( actionWindow window)
运行程序及其相应结果
单击son按钮 这时如果按下 f F a w 程序均会有相应的输出 这是因为 此时的焦点在son按钮上 而son按钮组件的三个InputMap都是有效的 所以他们对应的事件都会发生
单击parent按钮 这时按下 w 程序会有相应的输出 而按下 f F a 程序没有反应 这是因为parent按钮具有焦点 这个按钮不是son按钮的祖先 而son所在的窗口具有焦点 所以只有组件所在窗口具有焦点的InputMap是有效的
lishixinzhi/Article/program/Java/hx/201311/26304
因为文本的selected也是一个事件,你直接给一个 eventconsume();
必然破坏了对这个事件的处理,下面是处理办法:
if (in > 5) {
//如果有文字被选择
if(text1getSelectionStart()!=text1getSelectionEnd()){
}
else{
eventconsume();
}
ToolkitgetDefaultToolkit()beep();
}
以上就是关于Java获取Eclipse控制台键盘按键全部的内容,包括:Java获取Eclipse控制台键盘按键、java 怎么写键盘事件监听、java中如何实现键盘输入事件等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)