java如何衔接不同文件中的swing组件

java如何衔接不同文件中的swing组件,第1张

java如何衔接不亮洞和同颤顷文件中的swing组件

1、JFrame,JDialog,JWindow与JApplet这四个组件我们统称为最上层(Top-Level)组件,因为其余的Swing组件都必须依附在此四组件之一上才能显示出来。 2、敬盯最上层的四个组件都实现了RootPaneContainer接口,RootPaneContainer定义了各种容器取得与设置的方法,这里的容器包括JRootPane,GlassPane,LayeredPane,和ContentPane。

在Java Swing编程过程中 经常需要处理键盘事件 例如处理快捷键等 这里就介绍如何定义键盘事件 以及如何处理这些事件 在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 apublic 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是有效的

单击其他的按钮(parentPanel外的按钮) 这时按下 w 程序会有相应的输出 而按下 f F a 程序没有反应 这是因为这些按钮具有焦点 他们不是son按钮的祖先 而son所在的窗口具有焦点 所以只有组件所在窗口具有焦点的InputMap是有效的

附 主要程序代码

import java awt *import javax swing *import borland jbcl layout *import java awt event ActionEventimport java awt event ActionListenerimport sun java swing plaf motif *public class EventPanel extends JPanel implements ActionListener{JButton btnYellow = new JButton()JButton btnBlue = new JButton()JButton btnRed = new JButton()JPanel parentPanel = new JPanel()JPanel sonPanel = new JPanel()XYLayout xYLayout = new XYLayout()JButton son = new JButton()JButton parent = new JButton()public EventPanel(){try{jbInit()}catch(Exception ex){ ex printStackTrace()}}void jbInit() throws Exception{btnYellow setText( Yellow )btnYellow setBounds(new Rectangle( ))this setLayout(null)btnBlue setBounds(new Rectangle( ))btnBlue setText( Blue )btnRed setBounds(new Rectangle( ))btnRed setText( Red )parentPanel setBorder(BorderFactory createRaisedBevelBorder())parentPanel setBounds(new Rectangle( ))parentPanel setLayout(xYLayout )sonPanel setBorder(BorderFactory createLoweredBevelBorder())son setText( son )parent setText( parent )this add(btnYellow null)this add(btnBlue null)this add(btnRed null)this add(parentPanel null)parentPanel add(sonPanel new XYConstraints( ))sonPanel add(son null)parentPanel add(parent new XYConstraints( ))btnYellow addActionListener(this)btnRed addActionListener(this)btnBlue addActionListener(this)InputMap focusIm focusFatherIm ancestorIm windowImActionMap am//create four TextAction for diff purpose

TextAction whenFocusSon = new TextAction( focus son )TextAction whenFocusFather = new TextAction( focus father )TextAction window = new TextAction( window )TextAction ancestor = new TextAction( ancestor )//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)//put the keyStroke to the 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 )//get the actionMap

am = son getActionMap()am put( actionFocusSon whenFocusSon)am put( actionFocusFather whenFocusFather)am put( actionAncestor ancestor)am put( actionWindow window)}public void actionPerformed(ActionEvent e){//this code is used to change the backgracolor

Object source=e getSource()Color color=null//=getBackground()

lishixinzhi/Article/program/Java/hx/201311/26711

在Swing中,可以通毕慎过获取多个输入框的文本来实现同时获此带取多个输入框文本的功能。以下是一个示例代码:

```

import javax.swing.*

import java.awt.*

import java.awt.event.*

public class MultiTextFieldExample extends JFrame implements ActionListener {

private JTextField textField1, textField2

private JButton button

public MultiTextFieldExample() {

super("Multi Text Field Example")

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)

// 创建两个文本框和一个按钮

textField1 = new JTextField(20)

textField2 = new JTextField(20)

button = new JButton("Get Text")

// 将按钮添加到窗口,并注册事件监听器

add(textField1, BorderLayout.NORTH)

add(textField2, BorderLayout.CENTER)

add(button, BorderLayout.SOUTH)

// 注册事件监听器

button.addActionListener(this)

pack()

setVisible(true)

}

@Override

public void actionPerformed(ActionEvent e) {

if (e.getSource() == button) { // 判断是否点击了“Get Text”按钮

String text1 = textField1.getText() // 获取第一个文本框的内容

String text2 = textField2.getText() // 获取第二个文本框的内容

System.out.println("Text from field 1: " + text1) // 输出第一个文本框的内容

System.out.println("Text from field 2: " + text2) // 输出第二个文本框的内容

}

}

public static void main(String[] args) {

SwingUtilities.invokeLater(new Runnable() {

@Override

public void run() {

new MultiTextFieldExample()

}

})

}

}

```

上述代码创建了两个`JTextField`对象和一个`JButton`对象,当用户单击“Get Text”按钮时,程序将从这两个输入字段中读取其当前值并输出到控制台。手扒敬


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12521481.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存