当用户单击按钮时,JavaFX Button类可以触发事件。Button类扩展了Labeled类,可以显示文本,图像或两者都可以。

以下代码显示了如何向Button添加单击操作侦听器。

import javafx.application.Application;

import javafx.event.ActionEvent;

import javafx.event.EventHandler;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.layout.StackPane;

import javafx.stage.Stage;

public class Main extends Application {

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage primaryStage) {

primaryStage.setTitle("Hello World!");

Button btn = new Button();

btn.setText("Say 'Hello World'");

btn.setOnAction(new EventHandler() {

@Override

public void handle(ActionEvent event) {

System.out.println("Hello World!");

}

});

StackPane root = new StackPane();

root.getChildren().add(btn);

primaryStage.setScene(new Scene(root, 300, 250));

primaryStage.show();

}

}

上面的代码生成以下结果。

创建按钮

我们使用以下构造函数在JavaFX中创建一个Button。

创建带有空文本标题的按钮。

Button button = new Button();

创建具有指定文本的按钮。

Button button = new Button("OK");

要创建带有文本和图标的按钮。

Image imageOk = new Image(getClass().getResourceAsStream("OK.png"));

Button button = new Button("OK", new ImageView(imageOk));

按钮内容

创建JavaFX Button对象后,我们可以使用以下方法设置文本并设置安装图标。

setText(String text) - 设置按钮的文本标题

setGraphic(Node graphic) - 设置图标

除了ImageView对象,我们可以使用javafx.scene.shape包中的形状作为Button中的图形元素。

setGraphicTextGap方法设置文本和图形内容之间的差距。

以下代码将图像安装到按钮。

Image okImage = new Image(getClass().getResourceAsStream("OK.png"));

button.setGraphic(new ImageView(okImage));

按钮操作

我们可以使用Button类的setOnAction方法为用户单击事件添加点击事件处理程序。

button.setOnAction((ActionEvent e) -> {

System.out.println("clicked");

});

按钮效果

我们可以将javafx.scene.effect包中的效果应用到按钮。

以下代码将DropShadow效果应用于按钮。

DropShadow shadow = new DropShadow();

button.setEffect(shadow);

button.setEffect(null);//remove the effect

以下代码显示了如何为Button设置阴影效果。

import javafx.application.Application;

import javafx.event.EventHandler;

import javafx.scene.Group;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.effect.DropShadow;

import javafx.scene.input.MouseEvent;

import javafx.scene.layout.VBox;

import javafx.stage.Stage;

public class Main extends Application {

DropShadow shadow = new DropShadow();

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage stage) {

Scene scene = new Scene(new Group());

stage.setTitle("Button Sample");

stage.setWidth(300);

stage.setHeight(190);

VBox vbox = new VBox();

vbox.setLayoutX(20);

vbox.setLayoutY(20);

final Button button1 = new Button("Accept");

button1.addEventHandler(MouseEvent.MOUSE_ENTERED, new EventHandler() {

@Override

public void handle(MouseEvent e) {

button1.setEffect(shadow);

}

});

button1.addEventHandler(MouseEvent.MOUSE_EXITED, new EventHandler() {

@Override

public void handle(MouseEvent e) {

button1.setEffect(null);

}

});

vbox.getChildren().add(button1);

vbox.setSpacing(10);

((Group) scene.getRoot()).getChildren().add(vbox);

stage.setScene(scene);

stage.show();

}

}

上面的代码生成以下结果。

按钮样式

我们可以使用CSS样式来改变按钮的外观和感觉。在单独的CSS文件中定义样式,并通过使用getStyleClass方法应用CSS文件。

下面的代码是一个CSS文件,它改变了按钮的字体和颜色。

.button1{

-fx-font: 30 arial;

-fx-base: #ee2211;

}

然后我们使用下面的代码来安装CSS。

button.getStyleClass().add("button1");

-fx-font属性设置button1的字体名称和大小。 -fx-base属性覆盖默认颜色。

下面的代码显示了如何使用CSS来改变Button的外观。

import javafx.application.Application;

import javafx.event.ActionEvent;

import javafx.event.EventHandler;

import javafx.scene.Group;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.layout.VBox;

import javafx.stage.Stage;

public class Main extends Application {

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage stage) {

Scene scene = new Scene(new Group());

stage.setWidth(300);

stage.setHeight(190);

VBox vbox = new VBox();

vbox.setLayoutX(20);

vbox.setLayoutY(20);

Button button1 = new Button("Accept");

button1.setStyle("-fx-font: 30 arial; -fx-base: #ee2211;");

vbox.getChildren().add(button1);

vbox.setSpacing(10);

((Group)scene.getRoot()).getChildren().add(vbox);

stage.setScene(scene);

stage.show();

}

}

上面的代码生成以下结果。

按钮鼠标事件

以下代码显示了如何处理Button的Mouse in和Mouse out(鼠标移入和移出)事件。

import javafx.application.Application;

import javafx.event.EventHandler;

import javafx.scene.Group;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.input.MouseEvent;

import javafx.scene.layout.VBox;

import javafx.stage.Stage;

public class Main extends Application {

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage stage) {

Scene scene = new Scene(new Group());

stage.setWidth(300);

stage.setHeight(190);

VBox vbox = new VBox();

vbox.setLayoutX(20);

vbox.setLayoutY(20);

final Button button1 = new Button("OK");

button1.addEventHandler(MouseEvent.MOUSE_ENTERED,

new EventHandler() {

@Override

public void handle(MouseEvent e) {

System.out.println("mouse entered");

}

});

button1.addEventHandler(MouseEvent.MOUSE_EXITED,

new EventHandler() {

@Override

public void handle(MouseEvent e) {

System.out.println("mouse out");

}

});

vbox.getChildren().add(button1);

((Group) scene.getRoot()).getChildren().add(vbox);

stage.setScene(scene);

stage.show();

}

}

上面的代码生成以下结果。

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

java fx 按钮长度_JavaFX按钮相关推荐

  1. java fx 重绘_JavaFX 2.2:如何强制重绘/更新ListView

    我在JavaFX 2模式对话窗口中有一个ListView控件.JavaFX 2.2:如何强制重绘/更新ListView 此ListView显示DXAlias实例,它由单元工厂生产的ListCells. ...

  2. java fx 轮播_javafx实现轮播图

    下面是轮播图的主体代码 Button buttonTest = new Button(""); buttonTest.setPrefSize(1300, 510); //用线程实现 ...

  3. Android系统原理与源码分析(1):利用Java反射技术阻止通过按钮关闭对话框

    原文出处:博主宇宙的极客http://www.cnblogs.com/nokiaguy/archive/2010/07/27/1786482.html 众所周知,AlertDialog类用于显示对话框 ...

  4. java取消按钮事件_java按钮事件处理程序

    程序代码: import java.awt.*; import java.awt.event.*; import java.applet.*; public class ButtonDemo exte ...

  5. java单击切换div_[Java教程]点击同一按钮实现div的隐藏与现实切换

    [Java教程]点击同一按钮实现div的隐藏与现实切换 0 2016-01-16 21:00:12 点击同一按钮实现div的隐藏与现实切换: 在很多应用中,都有这样的功能,点击同一个按钮可以实现div ...

  6. android中在java代码中设置Button按钮的背景颜色

    android中在java代码中设置Button按钮的背景颜色 1.设置背景图片,图片来源于drawable: flightInfoPanel.setBackgroundDrawable(getRes ...

  7. 用java的事件监听机制实现一个简单的画板应用:通过选择图形按钮和颜色按钮来画出自己想画的图形:直线、空心矩形、圆形、折线、多边形、圆角矩形、弧线、曲线、喷枪

    今天做一个简单的画板,完整代码附在文章末尾处. - 功能:通过选择图形按钮和颜色按钮来画出自己想画的图形. - 界面展示: - 思路: 1.做一个可视化界面:创建JFrame对象,并设置Title.S ...

  8. JAVA:编写一个程序,模拟电梯得功能。功能接口包括电梯上行按钮、下行按钮、楼层选择与电梯在行驶过程中得楼层显示。

    编写一个程序,模拟电梯得功能.功能接口包括电梯上行按钮.下行按钮.楼层选择与电梯在行驶过程中得楼层显示. (1) 由用户选择按上行按钮还就是下行按钮,选择操作后再由用户输入要进入得楼层,进而电梯开始运 ...

  9. java重置按钮功能函数_Bootstrap按钮功能之查询按钮和重置按钮

    Bootstrap按钮功能之查询按钮和重置按钮 1.问题背景 一般情况下,查询列表有查询条件.查询按钮和重置按钮,输入查询条件,点击查询按钮查询列表等数据:点击重置按钮会将查询条件恢复到原始状态 2. ...

最新文章

  1. 面试:你了解中兴吗_HTTP简介:您需要了解的所有内容
  2. python入门指南 许半仙 txt-小九 第7章(1/1)_新笔趣阁
  3. 小程序学习(一):点击爱心变色 -- 最简单的事件实现
  4. 01Pandas_数据结构
  5. 掌控谈话~让对方说“不”
  6. Bootstrap3 折叠插件的事件
  7. 星巴克人造肉产品来了,植物牛肉餐品真香?
  8. 试解析Tomcat运行原理(一)--- socket通讯
  9. SpringMVC中接收数据和返回数据
  10. 为什么android手机内存不够,安卓手机老是内存不足怎么解决
  11. stream 内存带宽测试工具
  12. mysql是个单用户数据库_MySQL是一个支持单用户的数据库管理系统 答案:×
  13. Unity手游实战:从0开始SLG——本地化篇(一)聊聊游戏本地化
  14. 数据库里存放的是什么?
  15. Mac系统上查看端口占用和释放端口
  16. 编程作业(python)| 吴恩达 机器学习(6)支持向量机 SVM
  17. 电流型和电压型PHY
  18. cad注释比例和打印比例不一样_CAD注释性比例该如何设置?看完你就懂了
  19. 指数函数----e是什么?
  20. NBA联赛全面暂停!VR直播观赛会跃身主流吗?

热门文章

  1. VS2013打包生成安装文件setup.exe(详细图解)
  2. mysql 字符串的hash函数_【转载】字符串Hash函数比较
  3. WSL2运行 Anbox
  4. FFmpeg的编解码(二)
  5. emacs VS vim 替换为回车符
  6. android Audio调试程序常用命令
  7. Binder运行机制的流程图
  8. win10双网卡冗余的几种方法
  9. win10磁盘管理界面各系统分区介绍
  10. illustrator插件开发指南pdf_Jenkins之pipeline开发工具