zoukankan      html  css  js  c++  java
  • 利用JavaFx开发RIA桌面应用-事件监听

    1 事件监听

    最近利用javaFX开发桌面客户端,碰到需要给各种UI控件添加事件监听,在这里做一个简单的小结,供日后参考。

    2 分类处理

    Java GUI 和Android中,事件通常通过实现listener的接口函数,并通过addXXXListener 或者 setOnXXXListener的形式来设置接口函数来实现事件的执行。

    因此JavaFX的监听分为两种:

    • 控件级别监听
    • 属性级别监听

    然而在JavaFX中,只有极少数的事件是遵循Java GUI和Android的模式即控件级别的监听,例如,按钮的点击事件 。

    一、控件级别监听

    举例说明,Button点击事件处理的两种方式:

    1.直接对具体button监听,写在主代码中:

    Button btn = new Button();
    btn.setText("Say 'Hello World'");
    btn.setOnAction(new EventHandler<ActionEvent>() {
    
        @Override
        public void handle(ActionEvent event) {
    
        }
    });

    2.实现EventHandler接口,单独类创建事件代码,与主代码分离,我更青睐这种方式,可以统一管理事件,UI与具体事件分离:

    /**
     * Created by loongshaw on 2016/10/28.
     * CatalogCheckPage.java代码片段
     * NOTE 监听片段
     */
    Button btn = new Button();
    button.addEventHandler(MouseEvent.MOUSE_EXITED, new ShadowEvent(button,false));
    
    /**
     * Created by loongshaw on 2016/10/28.
     * ShadowEvent.java代码片段
     * NOTE 按钮阴影效果
     */
    public class ShadowEvent implements EventHandler<MouseEvent> {
    
        Button button;
        DropShadow dropShadow;
        boolean select;
    
        public ShadowEvent(Button button,DropShadow dropShadow,boolean select){
            this.button = button;
            this.dropShadow = dropShadow;
            this.select = select;
        }
    
        public ShadowEvent(Button button,boolean select){
            this.button = button;
            this.select = select;
        }
    
        public void handle(MouseEvent event) {
            if (select){
                button.setEffect(dropShadow);
            } else {
                button.setEffect(null);
            }
    
        }
    }

    二、属性级别监听

    JavaFX最重要的特性就是属性绑定 ,所有跟“属性”有关的事件,将一概不会通过“控件.setOnXXXX”这种形式执行。而是通过“属性绑定”来监听属性的改变 ,来执行事件,这一点将通过下述例子说明。

    举例说明:

    例一、比如监听checkbox是否选中,这是对selectedProperty这个属性进行监听,因此需要实现ChangeListener接口。

    // CatalogCheckPage.java代码片段
    checkBox.selectedProperty().addListener(new MyCheckBoxListener(checkBox,buttonOfPreEditionDataPath,textInputOfPreEditionDataPath));
    
    // MyCheckBoxListener.java代码片段
    public class MyCheckBoxListener implements ChangeListener<Boolean> {
    
        TextField textfield = new TextField();
        Button button = new Button();
        CheckBox checkBox;
    
        public MyCheckBoxListener(CheckBox checkBox,Button button,TextField textfield){
            this.checkBox = checkBox;
            this.button = button;
            this.textfield = textfield;
        }
    
        public void changed(ObservableValue<? extends Boolean> observable, Boolean oldValue, Boolean newValue){
            boolean select = checkBox.isSelected();
            // logger.info("checkbox newValue:" + newValue +",oldValue:"+oldValue);
            if (!select) {
                textfield.setDisable(true);
                button.setDisable(true);
            } else {
                textfield.setDisable(false);
                button.setDisable(false);
            }
        }
    }

    例二、比如监听窗口大小的改变,这是对Stage类的widthProperty这个属性进行监听,因此需要实现ChangeListener接口,同时ChangeListener里会回调一个“属性改变前的值”和“属性改变后的值”。

    // MainPage.java代码片段
    primaryStage.widthProperty().addListener(new StageChangeListener(primaryStage));
    
    // StageChangeListener.java窗体变化监听,当前用来设置图标
    public class StageChangeListener implements ChangeListener<Number> {
    
        Stage stage;
    
        public StageChangeListener(Stage stage){
            this.stage = stage;
        }
    
        public void changed(ObservableValue<? extends Number> observable, Number oldValue, Number newValue) {
    
            stage.getIcons().add(ImageUtil.getImage("/image/tools.png"));
        }
    }

    所以在JavaFX中,所有跟属性改变相关的事件,都可以根据 XXX.xxxxProperty().addListener 的形式来进行事件监听。理解这种方式将极大提升我们的开发效率。



  • 相关阅读:
    【WPF】WPF的二维路径标记语法绘图PathGeometry
    【转】【WPF】WPF无边框窗体
    【转】【数学】矩阵求逆的几何意义
    【转】【数学】矩阵的旋转
    【转】【OPenGL】理解OpenGL拾取模式(OpenGL Picking)
    WPF DataGrid 表头单元格居中DataGridCheckBoxColumn居中单击选中
    Revit 调用自己的窗体,以及导出图纸图片
    OpenXml 学习记录 标签目录 插入文本 表格 图片
    【转】【OpenXML】OpenXML操作word
    【转】【OpenXml】OpenXml操作Word的一些操作总结
  • 原文地址:https://www.cnblogs.com/jifeng/p/6544377.html
Copyright © 2011-2022 走看看