JavaFx实现键盘、鼠标、按钮的监听

在JavaFX中,为UI组件添加鼠标、键盘和按钮事件监听器的方法如下:

一、简单示例:

1. 首先,确保已经导入了JavaFX库。在`pom.xml`文件中添加以下依赖(如果使用Maven):

java 复制代码
xml<dependencies>
  <dependency>
      <groupId>org.openjfx</groupId>
      <artifactId>javafx-controls</artifactId>
      <version>16</version>
    </dependency>
</dependencies>

2.创建一个JavaFX应用程序,并在其中添加一个按钮、一个文本框和一个标签。为按钮、文本框和标签添加鼠标、键盘和按钮事件监听器。

java 复制代码
import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.input.KeyEvent;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class JavaFXListenersExample extends Application {

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        Button button = new Button("点击我");
        TextField textField = new TextField();
        Label label = new Label("鼠标和键盘事件监听器示例");

        // 为按钮添加事件监听器
        button.setOnAction(new EventHandler<ActionEvent>() {
            @Override
            public void handle(ActionEvent event) {
                System.out.println("按钮被点击了!");
            }
        });

        // 为文本框添加键盘事件监听器
        textField.setOnKeyPressed(new EventHandler<KeyEvent>() {
            @Override
            public void handle(KeyEvent event) {
                System.out.println("键盘按下事件:" + event.getCode());
            }
        });

        // 为标签添加鼠标事件监听器
        label.setOnMouseClicked(new EventHandler<MouseEvent>() {
            @Override
            public void handle(MouseEvent event) {
                System.out.println("鼠标点击事件:" + event.getButton());
            }
        });

        VBox root = new VBox(button, textField, label);
        Scene scene = new Scene(root, 300, 250);

        primaryStage.setTitle("JavaFX 监听器示例");
        primaryStage.setScene(scene);
        primaryStage.show();
    }
}

总结:

在这个示例中,我们创建了一个JavaFX应用程序,其中包含一个按钮、一个文本框和一个标签。

我们为按钮添加了一个`ActionEvent`监听器,当用户单击按钮时,会打印出"按钮被点击了!"。

我们为文本框添加了一个`KeyEvent`监听器,当用户在文本框中按下键盘时,会打印出相应的键盘按键。

我们为标签添加了一个`MouseEvent`监听器,当用户单击标签时,会打印出相应的鼠标按钮。

二、复杂监听(鼠标--单击 、按钮--点击、键盘--打印按下内容)

java 复制代码
import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.input.KeyEvent;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class JavaFXListenersExample extends Application {

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        Button button = new Button("点击我");
        TextField textField = new TextField();
        Label label = new Label("鼠标和键盘事件监听器示例");

        // 为按钮添加事件监听器
        button.setOnAction(new EventHandler<ActionEvent>() {
            @Override
            public void handle(ActionEvent event) {
                System.out.println("按钮被点击了!");
            }
        });

        // 为文本框添加键盘事件监听器
        textField.setOnKeyPressed(new EventHandler<KeyEvent>() {
            @Override
            public void handle(KeyEvent event) {
                System.out.println("键盘按下事件:" + event.getCode());
            }
        });

        // 为标签添加鼠标事件监听器
        label.setOnMouseClicked(new EventHandler<MouseEvent>() {
            @Override
            public void handle(MouseEvent event) {
                System.out.println("鼠标点击事件:" + event.getButton());
            }
        });

        VBox root = new VBox(button, textField, label);
        Scene scene = new Scene(root, 300, 250);

        primaryStage.setTitle("JavaFX 监听器示例");
        primaryStage.setScene(scene);
        primaryStage.show();
    }
}

JavaFX还支持其他类型的事件监听器,如鼠标移动、拖放等。我们可以根据需要为UI组件添加相应的监听器来实现需求。

相关推荐
gnip2 小时前
企业级配置式表单组件封装
前端·javascript·vue.js
一只叫煤球的猫3 小时前
写代码很6,面试秒变菜鸟?不卖课,面试官视角走心探讨
前端·后端·面试
excel4 小时前
Three.js 材质(Material)详解 —— 区别、原理、场景与示例
前端
掘金安东尼4 小时前
抛弃自定义模态框:原生Dialog的实力
前端·javascript·github
皮皮林5514 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
hj5914_前端新手8 小时前
javascript基础- 函数中 this 指向、call、apply、bind
前端·javascript
薛定谔的算法8 小时前
低代码编辑器项目设计与实现:以JSON为核心的数据驱动架构
前端·react.js·前端框架
Hilaku8 小时前
都2025年了,我们还有必要为了兼容性,去写那么多polyfill吗?
前端·javascript·css
yangcode8 小时前
iOS 苹果内购 Storekit 2
前端
LuckySusu8 小时前
【js篇】JavaScript 原型修改 vs 重写:深入理解 constructor的指向问题
前端·javascript