Java: JavaFX桌面GUI开发

简介: Java: JavaFX桌面GUI开发

1、基本概念

窗口          Stage
  -场景       Scene
    -布局     stackPane
      -控件   Button

2、最小框架代码

创建命令行应用

package com.company;
import javafx.application.Application;
import javafx.stage.Stage;
public class HelloWorld extends Application {
    @Override
    public void start(Stage primaryStage) throws Exception {
        primaryStage.show();
    }
    public static void main(String[] args) {
        launch(args);
    }
}

对就是啥都没有,空白的窗体

d22.3.png


3、控件布局

package com.company;
import javafx.application.Application;
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) throws Exception {
        // 实例化按钮
        Button button = new Button("这是按钮上的文字");
        // 创建布局控件
        StackPane stackPane = new StackPane();
        // 将button添加到布局
        stackPane.getChildren().add(button);
        // 创建场景 宽=400 高=400
        Scene scene = new Scene(stackPane, 400, 400);
        // 将场景添加到窗口
        primaryStage.setScene(scene);
        // 显示窗口
        primaryStage.show();
    }
}

d22.4.png


4、事件添加

Main.java

package com.company;
import javafx.application.Application;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;
public class Main extends Application implements EventHandler<MouseEvent> {
    private Button button;
    public static void main(String[] args) {
        // write your code here
//        System.out.println("你好");
        launch(args);
    }
    @Override
    public void start(Stage primaryStage) throws Exception {
        // 实例化按钮
        button = new Button("这是按钮");
        // 1、添加按钮点击事件, this.handle 处理事件
//        button.setOnMouseClicked(this);
//        2、使用单独实现的类 事件监听
//        button.setOnMouseClicked(new MyMouseEvent());
//        3、使用匿名类添加事件监听
        button.setOnMouseClicked(new EventHandler<MouseEvent>() {
            @Override
            public void handle(MouseEvent event) {
                System.out.println("鼠标点击按钮了");
            }
        });
//        4、jdk 8  使用简写执行一条输出
        button.setOnMouseClicked(e -> System.out.println("简写的监听事件"));
//        5、同时输出多条
        button.setOnMouseClicked(e -> {
            System.out.println("简写的监听事件1");
            System.out.println("简写的监听事件2");
        });
        // 创建布局控件
        StackPane stackPane = new StackPane();
        // 将button添加到布局
        stackPane.getChildren().add(button);
        // 创建场景
        Scene scene = new Scene(stackPane, 400, 400);
        // 给场景添加事件处理的对象
//        scene.setOnMousePressed(this);
        scene.setOnMousePressed(new MySceneMouseEvent());
        // 将场景添加到窗口
        primaryStage.setScene(scene);
        // 显示窗口
        primaryStage.show();
    }
    @Override
    public void handle(MouseEvent event) {
        // event.getSource() 获取事件对象
        if (event.getSource() == button) {
            System.out.println("点击了按钮");
        } else {
            System.out.println("点击了场景");
        }
    }
}

MyMouseEvent.java 处理鼠标点击事件的类

package com.company;
import javafx.event.EventHandler;
import javafx.scene.input.MouseEvent;
public class MyMouseEvent implements EventHandler<MouseEvent> {
    @Override
    public void handle(MouseEvent event) {
        System.out.println("MyMouseEvent click");
    }
}

MySceneMouseEvent.java 处理场景点击事件的类

package com.company;
import javafx.event.EventHandler;
import javafx.scene.input.MouseEvent;
public class MySceneMouseEvent implements EventHandler<MouseEvent> {
    @Override
    public void handle(MouseEvent event) {
        System.out.println("场景鼠标点击");
    }
}

5、场景切换

package com.company;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
public class SceneChange extends Application {
    Scene scene1,  scene2;
    public static void main(String[] args) {
        launch(args);
    }
    @Override
    public void start(Stage primaryStage) throws Exception {
        // 场景1
        Button button1 = new Button("场景1 的button");
        // 事件监听 点击后切换到场景2
        button1.setOnMouseClicked(e -> {
            primaryStage.setScene(scene2);
        });
        VBox vBox = new VBox();
        vBox.getChildren().add(button1);
        scene1 = new Scene(vBox, 400, 400);
        // 场景2
        Button button2 = new Button("场景2 的button");
        // 事件监听 点击后切换到场景1
        button2.setOnMouseClicked(e -> {
            primaryStage.setScene(scene1);
        });
        StackPane stackPane = new StackPane();
        stackPane.getChildren().add(button2);
        scene2 = new Scene(stackPane, 400, 400);
        primaryStage.setScene(scene1);
        primaryStage.show();
    }
}

d22.5.png


d22.6.png


6、窗体切换

Main.java

package com.company;
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
public class Main extends Application {
    private Stage stage;
    @Override
    public void start(Stage primaryStage) throws Exception {
        stage = primaryStage;
        // 窗口点击叉号关闭询问
        stage.setOnCloseRequest(event -> {
            event.consume();  // 消除默认事件
            handleClose();
        });
        // 布局
        Button button = new Button("关闭窗口");
        // 鼠标点击关闭窗口
        button.setOnMouseClicked(event -> handleClose());
        VBox vBox = new VBox();
        vBox.getChildren().add(button);
        Scene scene = new Scene(vBox, 400, 400);
        stage.setScene(scene);
        stage.show();
    }
    public void handleClose() {
        // 接收窗体返回值
        boolean ret = WindowAlert.display("关闭窗口", "是否关闭窗口?");
        System.out.println(ret);
        if (ret) {
            stage.close();
        }
    }
    public static void main(String[] args) {
        launch(args);
    }
}

WindowAlert.java

package com.company;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.layout.VBox;
import javafx.stage.Modality;
import javafx.stage.Stage;
public class WindowAlert {
    public static boolean answer;
    /**
     * @param title 标题
     * @param msg   消息
     */
    public static boolean display(String title, String msg) {
        // 创建舞台
        Stage stage = new Stage();
        // 设置显示模式
        stage.initModality(Modality.APPLICATION_MODAL);
        stage.setTitle(title);
        // 创建控件
        Button buttonYes = new Button("是");
        buttonYes.setOnMouseClicked(event -> {
            answer = true;
            stage.close();
        });
        Button buttonNo = new Button("否");
        buttonNo.setOnMouseClicked(event -> {
            answer = false;
            stage.close();
        });
        Label label = new Label(msg);
        // 创建布局
        VBox vBox = new VBox();
        vBox.getChildren().addAll(label, buttonYes, buttonNo);
        vBox.setAlignment(Pos.CENTER); // 布局居中显示
        // 创建场景
        Scene scene = new Scene(vBox, 200, 200);
        // 显示舞台
        stage.setScene(scene);
//        stage.show();
        stage.showAndWait();  // 等待窗体关闭才继续
        // 窗体返回值
        return answer;
    }
}

d22.7.png

相关文章
|
8月前
|
IDE Java Linux
Java一分钟之-JavaFX:构建桌面GUI应用
JavaFX是Java用于构建桌面应用的强大力量,提供丰富的UI组件、动画、媒体播放和跨平台能力。本文简要介绍JavaFX,讨论环境配置、布局混乱和事件处理等常见问题及其解决方案。通过学习官方文档、实践和使用IDE辅助,开发者能避免这些问题。示例代码展示了一个简单的JavaFX应用,展示如何创建UI、处理事件和构建布局。
460 1
|
7月前
|
前端开发 Java UED
Java中的图形用户界面编程:Swing与JavaFX的比较与应用
Java中的图形用户界面编程:Swing与JavaFX的比较与应用
|
7月前
|
数据可视化 前端开发 Java
Java中的图形用户界面开发
Java中的图形用户界面开发
|
8月前
|
设计模式 自然语言处理 前端开发
JAVA图形用户界面
JAVA图形用户界面
|
8月前
|
前端开发 Java 开发工具
盘点Java GUI框架
盘点Java GUI框架
453 0
|
编解码 Java 图形学
java GUI (一)
java GUI (一)
169 0
|
Java 容器
Java GUI(二)
Java GUI(二)
122 0
|
Java
Java: JavaFX桌面GUI开发
Java: JavaFX桌面GUI开发
165 0
Java: JavaFX桌面GUI开发
|
Java 容器
java基础--GUI(图形化界面)
Graphical User Interface(图形用户接口) 用图形的方式,来显示计算机操作的界面,这样更方便直观
337 0
java基础--GUI(图形化界面)
|
存储 Java 人机交互
Java GUI Swing组件
Java GUI Swing组件
240 0
Java GUI Swing组件