JavaFX场景入门

这篇具有很好参考价值的文章主要介绍了JavaFX场景入门。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

JAVAFX

jdk1.8以上引入javafx类库

JDK11+JAVAFX(eclipse)

小知识点

舞台Stage

platform、screen类

Scene场景类

查看电脑屏幕宽高

Group容器

JAVAFX项目

Image

javafx场景

javaFx文本

javaFX颜色


JAVAFX

JavaFX场景入门,前端,数据库,javascriptJavaFX场景入门,前端,数据库,javascript

jdk1.8以上引入javafx类库

JavaFX场景入门,前端,数据库,javascript

JavaFX场景入门,前端,数据库,javascript

JDK11+JAVAFX(eclipse)

方式一

JavaFX场景入门,前端,数据库,javascript

方式二

直接引入

JavaFX场景入门,前端,数据库,javascript

避免

JavaFX场景入门,前端,数据库,javascript

另一种编写方式

JavaFX场景入门,前端,数据库,javascript

JavaFX场景入门,前端,数据库,javascript

JavaFX场景入门,前端,数据库,javascript

小知识点

setHgrow或setVgrow、需要精确布局时,应重写layoutChildren()值摆放每一个子节点

JavaFX场景入门,前端,数据库,javascript

setHgrow(hbox,Priority.ALWAYS);

javafx有4中控件来表示多项数据

ListView:列表

TreeView:树

TableView:表格

TreeTableView:多列列表

环境配置

JavaFX场景入门,前端,数据库,javascript

JavaFX场景入门,前端,数据库,javascript

舞台Stage

舞台(场景(布局(控件)))

JavaFX需要继承:javafx.application.AppLication

需要实现方法start

创建main方法 调用launch

需要stage调用show方法

stage.setOpacity(0.9);//设置透明度  0-1

//X,Y监听事件
    

stage.xProperty().addListener(new ChangeListener<Number>() {


        @Override

        public void changed(ObservableValue<? extends Number> observable, Number oldValue, Number newValue) {

           System.out.println("X窗口现在坐标:"+newValue);

           System.out.println("X窗口之前坐标:"+oldValue);

        }

     });

    

     stage.yProperty().addListener(new ChangeListener<Number>() {


        @Override

        public void changed(ObservableValue<? extends Number> observable, Number oldValue, Number newValue) {

           System.out.println("Y窗口现在坐标:"+newValue);

           System.out.println("Y窗口之前坐标:"+oldValue);

        }

     });



//创建多个窗口,设置模式

Stage s1 =new Stage();

     //s1.initStyle(StageStyle.TRANSPARENT);//透明的

     s1.initStyle(StageStyle.UNIFIED);

     s1.show();

    

    

     Stage s2 =new Stage();

     s2.setTitle("5");

     s2.initStyle(StageStyle.UTILITY);

     //s2.initStyle(StageStyle.UNDECORATED);//白色不带装饰

     s2.show();


// APPLICATION_MODAL设置初始化模态

S2关闭之后才能操作其他窗口

Stage s1 =new Stage();

     s1.setTitle("s1");

     s1.show();

    

    

     Stage s2 =new Stage();

     s2.initModality(Modality.APPLICATION_MODAL);

     s2.setTitle("s2");

     s2.show();


// WINDOW_MODAL设置初始化模态

Stage s1 =new Stage();

     s1.setTitle("s1");

    

     Stage s2 =new Stage();

     //s2.initModality(Modality.APPLICATION_MODAL);

     s2.setTitle("s2");

     //设置s2和s1关联

     s1.initOwner(s2);

    

     s1.initModality(Modality.WINDOW_MODAL);

    

     s2.show();

     s1.show();

    

案例:

import javafx.application.Application;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.control.Label;

import javafx.scene.control.TextField;

import javafx.scene.layout.HBox;

import javafx.scene.layout.VBox;

import javafx.scene.transform.Scale;

import javafx.stage.Stage;


public class javafx03tage extends Application {

    public  static  Stage stage;


    @Override

    public void start(Stage stage) throws Exception {

        //让舞台赋值给静态属性

        javafx03tage.stage =stage;


        stage.setTitle("小应用测试");

        //创建布局

        HBox hbox = new HBox();

        //创建控件

        TextField textField = new TextField();

        Button button = new Button("确定");

        button.setOnAction((e)->{

            String a = textField.getText();


            System.out.println("输入的内容为:"+a);

        });

        Button regist = new Button("注册");

        //写法1

//        regist.setOnAction((e)->{

//            regis();

//        });

//        写法2

        regist.setOnAction(e->javafx03tage.regis());

        //将控件加入布局

        hbox.getChildren().addAll(textField,button,regist);

//        hbox.getChildren().add(textField);

//        hbox.getChildren().add(button);

        //将布局加入场景

        Scene scene = new Scene(hbox,300,200);

        //将场景放入舞台

        stage.setScene(scene);

        stage.show();

    }

    public static void regis(){

        //创建垂直布局

        VBox vbox = new VBox();

        //创建控件

        TextField t1 = new TextField();

        TextField t2 = new TextField();

        Button b1 = new Button("注册");

        vbox.getChildren().addAll(t1,t2,b1);

        Scene scene = new Scene(vbox,300,200);

        javafx03tage.stage.setScene(scene);

    }

    public static void main(String[] args) {

        launch();

    }

}

platform、screen类

Platform类

public class platformcalss extends Application{

   public static void main(String[] args) {

     launch(args);

   }

   @Override

   public void start(Stage primaryStage) throws Exception {

     //设置为false,当窗口关闭,程序仍然运行,如要关闭则Platform.exit(); 若为true,窗口关闭,程序关闭

     //Platform.setImplicitExit(false);

     //是否支持3D效果

     boolean b = Platform.isSupported(ConditionalFeature.SCENE3D);

    

     Platform.runLater(new Runnable() {

        @Override

        public void run()

        {

           System.out.println("run方法里的线程名字:"+Thread.currentThread().getName());

           //可以在这里更新组件

        }

     });

   }

}

screen类

public class Screencalss extends Application{

   public static void main(String[] args) {

     launch(args);

   }

   @Override

   public void start(Stage primaryStage) throws Exception {

     //获取屏幕

     Screen screen = Screen.getPrimary();

     //获取屏幕全部宽度,高度

     Rectangle2D rec1= screen.getBounds();

     //获取可视范围的宽度,高度

     Rectangle2D rec2= screen.getVisualBounds();

     System.out.println(rec1.getWidth());

     System.out.println(rec2.getWidth());

     Platform.exit();

   }

}

Scene场景类

JavaFX场景入门,前端,数据库,javascript

scene类电脑屏幕相关

查看电脑屏幕宽高
Screen primary = Screen.getPrimary();

        double dpi = primary.getDpi();

        System.out.println("当前屏幕dpi:"+dpi);

        Rectangle2D rec1 = primary.getBounds();

        Rectangle2D rec2 = primary.getVisualBounds();

        System.out.println("----全部屏幕--------");

        System.out.println("左上角x:"+rec1.getMinX()+"左上角y"+rec1.getMinY());

        System.out.println("右下角x--"+ rec1.getMaxX()+"右下角y--"+ rec1.getMaxY());

        System.out.println("宽度:"+rec1.getWidth()+"高度"+rec1.getHeight());

        System.out.println("----可以看到的屏幕--------");

        System.out.println("左上角x:"+rec2.getMinX()+"左上角y"+rec2.getMinY());

        System.out.println("右下角x--"+ rec2.getMaxX()+"右下角y--"+ rec2.getMaxY());


        System.out.println("宽度:"+rec2.getWidth()+"高度"+rec2.getHeight());

给button设置图标

scene.setCursor(Cursor.HAND);//手,箭头啥的

Cursor CROSSHAIR  光标十字光标

Cursor . DEFAULT 光标默认值

Cursor DISAPPEAR   光标消失

Cursor CLOSED_HAND 光标闭合手

Contextmenudemo 上下文菜单演示

Cursor E _ RESIZE 光标E _ RESIZE

自定义图标

       scene.setCursor(Cursor.cursor("img"));

从本地获取图片路径的方式

 URL url = getClass().getClassLoader().getResource("icon/icon.png");

        String oath = url.toExternalForm();

完整代码

   @Override

    public void start(Stage primaryStage) throws Exception{

        Button button = new Button("按钮");

        button.setPrefHeight(100);

        button.setPrefWidth(300);

        URL url = getClass().getClassLoader().getResource("icon/icon.png");

        String path = url.toExternalForm();

        Group group = new Group(button);

        Scene scene = new Scene(group);


         scene.setCursor(Cursor.cursor(path));

        primaryStage.setTitle("javafx");

        primaryStage.setHeight(800);

        primaryStage.setWidth(800);

        primaryStage.setScene(scene);

        primaryStage.show();



    }


打开网页,运行到代码就执行打开的操作


 HostServices hostServices = getHostServices();


        hostServices.showDocument("https://www.baidu.com/");


platform类的使用

Platform.runLater-队列线程按照顺序执行


   Platform.runLater(new Runnable() {

                @Override

                public void run() {

                    System.out.println("stop()"+Thread.currentThread().getName());

                }


            });


ImplicitExit(false) 后台运行


  Platform.setImplicitExit(false);// 设置这个之后呢不执行stop方法了


        Platform.exit();//关闭 

检测平台支支不支持什么效果

Platform.isSupported(ConditionalFeature.SCENE3D)//三d效果

public void start(Stage stage) throws Exception {

    stage.setTitle("SceneDemo");

    HBox hbox =new HBox();

    Button button =new Button("打开百度");

    hbox.getChildren().add(button);

    button.setOnAction((e)->{

        HostServices hostServices = getHostServices();

        hostServices.showDocument("https://www.baidu.com/");

    });

    Scene scene =new Scene(hbox,400,500);

    scene.setCursor(Cursor.CLOSED_HAND);//手

    stage.setScene(scene);

    stage.show();

}

Group容器

stage.setTitle("GroupDemo");

              Group group =new Group();

              Button button =new Button("按钮");

              button.setLayoutX(50);

              button.setLayoutY(50);

              group.getChildren().add(button);

              //看位置是否有子节点

              boolean is =group.contains(0, 0);

              System.out.println("位置是否有子节点:"+is);

              //将所有的子节点放置object[]

              Object[] o= group.getChildren().toArray();

              System.out.println("多少个子节点:"+o.length);

              for (Object object : o) {

                     System.out.println(object);

              }

             

              group.getChildren().addListener(new ListChangeListener<Node>() {


                     @Override

                     public void onChanged(Change<? extends Node> c) {

                            //元素个数(当删除或增加时触发监听器)

                            System.out.println("当前子控件数量:"+c.getList().size());

                     }

              });

             

              Scene scene =new Scene(group);

              scene.setCursor(Cursor.CLOSED_HAND);

JAVAFX项目

Main.java主项目

Application.css样式

Build.fxbuild用于程序的打包发布

Icons图标、Pane窗格、Platform平台、addEventFilter添加事件筛选器、getCharacter获取字符、PRESSED按下pressed、TYPE打字,

getCode获取代码,

案例:

import javafx.application.Application;

import javafx.application.Platform;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.image.Image;

import javafx.scene.image.ImageView;

import javafx.scene.input.KeyEvent;

import javafx.scene.layout.BorderPane;

import javafx.stage.Stage;


import java.io.FileInputStream;


public class javafx05stage extends Application {

    @Override

    public void start(Stage stage) throws Exception {

        stage.setTitle("整卷");

        FileInputStream fileInputStream = new FileInputStream("F:\\IDEADemo\\hello\\Snipaste_2022-10-12_20-03-32.jpg");

        Image image = new Image(fileInputStream);

        stage.getIcons().add(image);

//        HBox hbox = new HBox();

//        Button button = new Button("确定");

//        hbox.getChildren().add(button);

        stage.setWidth(600);

        stage.setHeight(500);

        BorderPane borderPane = new BorderPane();

        FileInputStream fileInputStream1 = new FileInputStream("F:\\IDEADemo\\hello\\src\\Snipaste_2022-10-17_17-14-25.jpg");

        Image image1 = new Image(fileInputStream1,200,200,true,true);

        ImageView imageView = new ImageView(image1);

        borderPane.getChildren().add(imageView);

        Scene scene = new Scene(borderPane,500,300);

        //舞台的风格必须带上场景

        //stage.initStyle(StageStyle.UNDECORATED);

        stage.setScene(scene);

        //舞台事件

        stage.setOnCloseRequest((e)->{

            System.out.println("系统被关闭了");

        });

        //舞台键盘事件

        //ADWS上下左右

        stage.addEventFilter(KeyEvent.KEY_TYPED, e->{

            if (e.getCharacter().equalsIgnoreCase("A")){

                imageView.setTranslateX(imageView.getTranslateX()-10);

            }

            if (e.getCharacter().equalsIgnoreCase("D")){

                imageView.setTranslateX(imageView.getTranslateX()+10);

            }

            if (e.getCharacter().equalsIgnoreCase("W")){

                imageView.setTranslateY(imageView.getTranslateY()-10);

            }

            if (e.getCharacter().equalsIgnoreCase("S")){

                imageView.setTranslateY(imageView.getTranslateY()+10);

            }

        });

        //键盘按下:

        stage.addEventHandler(KeyEvent.KEY_PRESSED, e->{

            //ESC按下ESC,退出程序

            System.out.println(e.getCode().impl_getCode());

           if (27 == e.getCode().impl_getCode()){

               Platform.exit();

           };

        });

        stage.show();

    }

    public static void main(String[] args) {

        launch();

    }

}

Image

本地和网络图片

New Image(“file:c:/image/11.jpg”)

New Image(“https://img0.baidu.com/it/u=4119073184,4077902618&fm=253&fmt=auto&app=138&f=JPEG?w=442&h=267”)

File f =new File(“c:/image/11.jpg”);

String url =f.toURL().toString();

资源图片

与clas放在一起

Image image =new Image(“包名/11.jpg”);

案例

public class Imagedemo extends Application {

    Image[] images ={new Image("cat.jpeg"),new Image("cat1.jpeg"),new Image("cat2.jpeg")};

    static  int i = 0;

    ImageView imageView=new ImageView(images[i]);


    @Override

    public void start(Stage stage) throws Exception {

        stage.setTitle("imagedemo");

        Button button =new Button("下一个");


        BorderPane borderPane =new BorderPane();


        button.setOnAction(new EventHandler<ActionEvent>() {

            @Override

            public void handle(ActionEvent event) {

                i++;

                if (i>2) i=0;

                imageView.setImage(images[i]);

            }

        });


        borderPane.setTop(button);

        borderPane.setCenter(imageView);

        Scene scene =new Scene(borderPane,1200,800);

        stage.setScene(scene);

        stage.show();

    }


    public static void main(String[] args) {

        launch();

    }

}

JavaFX场景入门,前端,数据库,javascript

javafx场景

TextField文本字段、Cursor光标、imageView图像视图、addEventHandler添加事件处理程序、KeyEvent键盘事件、MouseEvent鼠标事件、

BorderPane布局

JavaFX场景入门,前端,数据库,javascript

BorderPane布局顶部,底部,左,右或中心区域中的子节点。每个区域只能有一个节点。BorderPane的顶部和底部区域允许可调整大小的节点占用所有可用宽度。

左边界区域和右边界区域占据顶部和底部边界之间的可用垂直空间。

默认情况下,所有边界区域尊重子节点的首选宽度和高度。放置在顶部,底部,左侧,右侧和中心区域中的节点的默认对齐方式如下:

● 顶部: Pos.TOP_LEFT

● 底部: Pos.BOTTOM_LEFT

● 左侧: Pos.TOP_LEFT

● 右侧: Pos.TOP_RIGHT

● 中心: Pos.CENTER

案例:图片跟随鼠标移动文章来源地址https://www.toymoban.com/news/detail-823935.html

public class javafx06stage extends Application {

    @Override

    public void start(Stage stage) throws Exception {

        stage.setTitle("场景测试");

        FileInputStream fileInputStream = new FileInputStream("F:\\IDEADemo\\hello\\src\\Snipaste_2022-10-17_17-14-25.jpg");

        Image image = new Image(fileInputStream,200,200,true,true);

        ImageView imageView =new ImageView(image);

        imageView.setTranslateX(150);

        imageView.setTranslateY(100);

        //BorderPane布局

        BorderPane borderPane =new BorderPane();

        borderPane.getChildren().addAll(imageView);

        //HBox hbox = new HBox();

//        VBox vbox = new VBox(10);

//        vbox.getChildren().addAll(new TextField(),new TextField(),new Button("确定"));

        //场景

        Scene scene = new Scene(borderPane,600,400);

        //场景鼠标光标

        scene.setCursor(Cursor.OPEN_HAND);

        stage.setScene(scene);

        //舞台事件

        stage.addEventFilter(MouseEvent.MOUSE_MOVED, e->{

            imageView.setTranslateX(e.getX()-100);

            imageView.setTranslateY(e.getY()-100);

        });

        stage.show();

    }

    public static void main(String[] args) {

        launch();

    }

}

到了这里,关于JavaFX场景入门的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Apache Doris 数据库有哪些应用场景?

    首先声明,本人无意叛变,依然是ClickHouse的忠实信徒。 对于Doris,一直听圈内的人在说,吹得神乎其神,但到底有多强,从来没有真正的去尝试一把。 直到这次,被人狠狠上了一课。 在一次全文检索的模糊查询的场景PK中,ClickHouse一败涂地,让本人很是没面子,咳咳,大哥

    2024年01月22日
    浏览(53)
  • colmap多相机重建多场景及数据库数据快速修改方法

    1 colmap流程 1.1 新建项目   首先打开colmap,然后创建新的project,其中数据库目录和名称自己选定,注意不要将它放到图像目录下即可。然后images选择的是图像目录(比如我这里是guangxi/section1),这个目录下应该包含有不同的文件夹,每个文件夹存放同一个相机拍摄的图像。

    2024年02月13日
    浏览(54)
  • 大数据技术8:StarRocks极速全场景MPP数据库

    前言:StarRocks原名DorisDB,是新一代极速全场景MPP数据库。StarRocks 是 Apache Doris 的 Fork 版本。StarRocks 连接的多种源。一是通过这个 CDC 或者说通过这个 ETL 的方式去灌到这个 StarRocks 里面;二是还可以去直接的和这些老的 kafka 或者是这种 TP 的数据库或者这种 log 的话,直接可以

    2024年02月04日
    浏览(40)
  • 《向量数据库指南》——腾讯云向量数据库Tencent Cloud VectorDB产品特性,架构和应用场景

    腾讯云向量数据库(Tencent Cloud VectorDB)是一款全托管的自研企业级分布式数据库服务,专用于存储、检索、分析多维向量数据。该数据库支持多种索引类型和相似度计算方法,单索引支持 10 亿级向量规模,可支持百万级 QPS 及毫秒级查询延迟。腾讯云向量数据库不仅能为大模

    2024年02月14日
    浏览(52)
  • 向量数据库的崛起与多元化场景创新

    在当今数字化时代,数据被认为是黄金,对于企业、科学家和决策者而言都具有巨大的价值。然而,随着数据规模的不断增长,有效地管理、存储和检索数据变得愈发复杂。这就引入了向量数据库这一现代数据库技术,它可以革命性地改善数据处理和分析的方式…伴随着大模

    2024年02月06日
    浏览(39)
  • 主流的 NoSQL 数据库 应用场景 优缺点

    主流的 NoSQL 数据库包括 MongoDB、Cassandra、Redis 和 Couchbase 等,它们在不同的应用场景下具有各自的优势和局限性。 应用场景 :适用于需要灵活的数据模型和丰富的查询能力的场景,如内容管理系统、实时分析等。 优点 :灵活的数据模型,支持复杂的数据结构和查询。水平扩

    2024年01月25日
    浏览(53)
  • JavaFX入门和网格布局面板的使用,Dao层交互,舞台与场景切换以及其他控件的使用

    网格布局 将整个面板划分为若干个格子 , 每个格子的大小是一样的 , 每个格子中可以放置一个控件(布局) , 类似于表格的方式。在网格布局 中放入控件的时候 , 还需要指定位置。 我们将要排出这个布局 , 也就是登陆页面的优化版本 位置原理讲解 以网格布局的思维来拆分

    2024年02月04日
    浏览(43)
  • Navicat 强大的数据模型功能 | 面向数据库设计、架构和数据资产梳理等使用场景

    数据模型是用来描述数据、组织数据和对数据进行操作的一组概念和定义。根据不同的应用需求,数据模型可以分为概念模型、逻辑模型和物理模型。这些数据模型帮助数据库设计人员设计和管理数据库,以满足用户的需求。 Navicat 强大的数据模型功能主要适用于 MySQL、Ora

    2024年02月09日
    浏览(51)
  • SQL与NoSQL数据库选型及实际业务场景探讨

    在企业系统架构设计中,选择合适的数据库类型是一项关键决策。本文将对比SQL和NoSQL数据库的特点,分析它们在数据模型、可扩展性、一致性与事务、查询复杂性与频率,以及性能与延迟等方面的优势和劣势。同时,结合轻易云数据集成平台作为实际业务场景的例子,探讨

    2024年02月15日
    浏览(102)
  • OLAP型数据库 ClickHouse的简介 应用场景 优势 不足

    ClickHouse 是一个开源的分布式列式数据库管理系统 (DBMS),专门用于在线分析处理 (OLAP)。它最初由 Yandex 开发,并且在处理大规模数据分析和实时查询方面表现出色。以下是关于 ClickHouse 的简介、应用场景、优势和不足的概述: ClickHouse 是一个高性能的列式数据库管理系统,专

    2024年02月02日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包