JavaFX
含义
用来开发图形化界面【GUI】
前置条件
JDK的版本必须大于等于1.8
建议
- 安装JavaFX插件
- 安装Scene Builder
相关概念和关系
- Stage
- Scene
- 子容器
- 很多子容器
- 很多控件
- 子容器
- Scene
FXML入门案例
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KGHRAcD2-1658907117772)(assets/1626137359833.png)]
Login.fxml
<?xml version="1.0" encoding="UTF-8"?>
<?import java.lang.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.layout.AnchorPane?>
<AnchorPane prefHeight="303.0" prefWidth="400.0" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/8">
<children>
<TextField layoutX="29.0" layoutY="246.0" text="test" />
<TextArea layoutX="22.0" layoutY="23.0" prefHeight="200.0" prefWidth="200.0" />
</children>
</AnchorPane>
Main.java
package application;
import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.layout.AnchorPane;
import javafx.stage.Stage;
public class Main extends Application {
@Override
public void start(Stage primaryStage) {
try {
//scene builder
//步骤
//新建一个FXML文件【存放控件的】
//加载FXML文件
//getClass().getResource("XX.FXML"); 从当前类的路径开始查找
//getClass().getResource("/XX.FXML"); 从src路径开始查找
AnchorPane anchorPane = FXMLLoader.load(getClass().getResource("/Login.fxml"));
//给场景设置跟布局,并且设置宽度和高度,该大小多的舞台就多大
Scene scene = new Scene(anchorPane,400,400);
//含义javafx 可以使用css文件来修饰控件
scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
} catch(Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
launch(args);
}
}
常见问题
因为JDK11版本中javaFX相关的组件独立成一个单独的模块,所以开发javaFX应用程序需要下载javaFX的模块
https://download2.gluonhq.com/openjfx/11.0.2/openjfx-11.0.2_windows-x64_bin-sdk.zip
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wOToyjJ3-1658907117774)(assets/1626144881126.png)]
新建User Library
-
解压javaFX模块
-
配置User Library
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jtIaQvwt-1658907117774)(assets/1626144995848.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MJ3R27Wd-1658907117775)(assets/1626145102751.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IB4QoAWX-1658907117775)(assets/1626145679851.png)]
新建JAVAFX项目
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Jh6THr8w-1658907117776)(assets/1626145186496.png)]
发现报错,因为Main.java使用到的javaFX相关类没有和之前创建的javaFX【也就是上一张截图】关联
关联JavaFX UserLibrary
选择项目鼠标右击,如下图
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-