JavaFX基础- Button 的基本使用

说明

本文记录一下对Button的基本使用,包括但不限于 样式的设置,事件的监听等。

按钮样式的设置

方式一 : Java代码的方式

 // 创建一个按钮
        Button button = new Button("按钮");
        // 设置按钮的位置
        button.setLayoutX(50);
        button.setLayoutY(100);
        // 设置按钮的大小
        button.setPrefWidth(200);
        button.setPrefHeight(50);
        // 设置文本的字体格式和大小
        button.setFont(Font.font("Arial", 40));
        // 设置按钮的文本颜色
        button.setTextFill(Paint.valueOf("#ff0000"));
        // 使用Java Property 的方式设置按钮的背景颜色、圆角、内边距的大小
        BackgroundFill bgf = new BackgroundFill(Paint.valueOf("#00ff00"),new CornerRadii(20), new Insets(6));
        Background bg = new Background(bgf);
        button.setBackground(bg);

在这里插入图片描述

方式二:css 内联样式的方式

        // 创建一个按钮
        Button button = new Button("按钮");
        // 设置按钮的位置
        button.setLayoutX(50);
        button.setLayoutY(100);
        // 设置按钮的大小
        button.setPrefWidth(200);
        button.setPrefHeight(50);

        // 使用css 的方式设置按钮的背景颜色、圆角、内边距的大小
        // 设置样式
        button.setStyle(
                "-fx-background-color: #1E90FF; " +      // 背景颜色(天蓝色)
                        "-fx-background-radius: 10px; " +// 背景圆角
                        "-fx-text-fill: white; " +       // 文字颜色(白色)
                        "-fx-font-size: 16px; " +        // 字体大小
                        "-fx-font-family: 'Arial'; " +   // 字体
                        "-fx-border-color: #00008B; " +  // 边框颜色(海军蓝)
                        "-fx-border-width: 2px; " +      // 边框宽度
                        "-fx-border-style: dashed; " +   // 边框样式(虚线)
                        "-fx-border-radius: 10px; " +    // 边框圆角
                        "-fx-padding: 30px; " +      // 内边距 : 内容与背景的内边距(水平和垂直)
                        "-fx-background-insets: 5px;" + // 背景的内边距 : 向内缩进去
                        "-fx-border-insets: -5px;" // 边框的内边距 : 向外扩展出去
        );

在这里插入图片描述

设置鼠标进入时显示小手

  // 设置鼠标的样式 : 鼠标进入的时候显示小手状
  button.setCursor(Cursor.HAND);

监听单击事件

  // 设置按钮的单击事件
        button.setOnAction(event -> {
            System.out.println("event = " + event);
            System.out.println("按钮被点击了");
        });

实现监听双击

根据点击的次数判断是否是双击。

 // 实现鼠标的双击事件 1 : 使用JavaFX 的事件处理机制
        button.setOnMouseClicked(event -> {
            if (event.getClickCount() == 2 && event.getButton().name().equals(MouseButton.PRIMARY.name())){
                System.out.println("双击了");
            }
        });
        // 实现鼠标的双击事件 2 : 使用JavaFX 的事件处理机制
        button.addEventHandler(MouseEvent.MOUSE_CLICKED, event -> {
            if (event.getClickCount() == 2 && event.getButton().name().equals(MouseButton.PRIMARY.name())){
                System.out.println("双击了22");
            }
        });
运行结果:
双击了22
双击了

实现监听键盘事件

// 监听键盘事件
        button.setOnKeyPressed(event -> {
            System.out.println("按下了键盘1 : "+event.getCode() + " : "+event.getCode().getName()+" : "+event.getText());
        });
        button.setOnKeyReleased(event -> {
            System.out.println("松开了键盘"+event.getCode());
        });
        button.setOnKeyTyped(event -> {
            System.out.println("按下了键盘2"+event.getCode().name());
        });
JavaFX的RadioButton是一种用户界面控件,用于在多个选项中选择一个选项。它通常与其他RadioButton组合在一起,形成一个单选按钮组。当用户选择其中一个RadioButton时,其他RadioButton将自动取消选择。 JavaFX的RadioButton具有以下特点: 1. 可以通过设置文本或图像来标识每个RadioButton。 2. 可以使用ToggleGroup将多个RadioButton组合在一起,确保它们之间是互斥的,即只能选择其中一个。 3. 可以通过设置选中状态来确定哪个RadioButton被选中。 4. 可以通过添加事件监听器来响应RadioButton的选择状态变化。 以下是一个简单的JavaFX RadioButton的示例代码: ```java import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.control.RadioButton; import javafx.scene.control.ToggleGroup; import javafx.scene.layout.VBox; import javafx.stage.Stage; public class RadioButtonExample extends Application { @Override public void start(Stage primaryStage) { RadioButton radioButton1 = new RadioButton("Option 1"); RadioButton radioButton2 = new RadioButton("Option 2"); RadioButton radioButton3 = new RadioButton("Option 3"); ToggleGroup toggleGroup = new ToggleGroup(); radioButton1.setToggleGroup(toggleGroup); radioButton2.setToggleGroup(toggleGroup); radioButton3.setToggleGroup(toggleGroup); VBox vbox = new VBox(radioButton1, radioButton2, radioButton3); Scene scene = new Scene(vbox, 200, 200); primaryStage.setScene(scene); primaryStage.show(); } public static void main(String[] args) { launch(args); } } ``` 这个示例创建了三个RadioButton,并将它们添加到一个垂直布局的VBox中。然后,通过ToggleGroup将它们组合在一起。最后,将VBox添加到场景中,并显示在舞台上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值