- JavaFX 教程
- JavaFX - 首页
- JavaFX - 概述
- JavaFX 安装和架构
- JavaFX - 环境
- JavaFX - 使用 Netbeans 安装
- JavaFX - 使用 Eclipse 安装
- JavaFX - 使用 Visual Studio Code 安装
- JavaFX - 架构
- JavaFX - 应用
- JavaFX 二维图形
- JavaFX - 二维图形
- JavaFX - 绘制直线
- JavaFX - 绘制矩形
- JavaFX - 绘制圆角矩形
- JavaFX - 绘制圆形
- JavaFX - 绘制椭圆
- JavaFX - 绘制多边形
- JavaFX - 绘制折线
- JavaFX - 绘制三次贝塞尔曲线
- JavaFX - 绘制二次贝塞尔曲线
- JavaFX - 绘制弧形
- JavaFX - 绘制 SVG 路径
- JavaFX 二维对象的属性
- JavaFX - 描边类型属性
- JavaFX - 描边宽度属性
- JavaFX - 描边填充属性
- JavaFX - 描边属性
- JavaFX - 描边线连接属性
- JavaFX - 描边斜接限制属性
- JavaFX - 描边线端点属性
- JavaFX - 平滑属性
- JavaFX 路径对象
- JavaFX - 路径对象
- JavaFX - LineTo 路径对象
- JavaFX - HLineTo 路径对象
- JavaFX - VLineTo 路径对象
- JavaFX - QuadCurveTo 路径对象
- JavaFX - CubicCurveTo 路径对象
- JavaFX - ArcTo 路径对象
- JavaFX 颜色和纹理
- JavaFX - 颜色
- JavaFX - 线性渐变图案
- JavaFX - 径向渐变图案
- JavaFX 文本
- JavaFX - 文本
- JavaFX 特效
- JavaFX - 特效
- JavaFX - 颜色调整特效
- JavaFX - 颜色输入特效
- JavaFX - 图片输入特效
- JavaFX - 混合特效
- JavaFX - 光晕特效
- JavaFX - 辉光特效
- JavaFX - 方框模糊特效
- JavaFX - 高斯模糊特效
- JavaFX - 运动模糊特效
- JavaFX - 反射特效
- JavaFX - 棕褐色调特效
- JavaFX - 阴影特效
- JavaFX - 投影阴影特效
- JavaFX - 内阴影特效
- JavaFX - 光照特效
- JavaFX - 远光源特效
- JavaFX - 聚光灯特效
- JavaFX - 点光源特效
- JavaFX - 位移映射
- JavaFX - 透视变换
- JavaFX 动画
- JavaFX - 动画
- JavaFX - 旋转转换
- JavaFX - 缩放转换
- JavaFX - 平移转换
- JavaFX - 淡入淡出转换
- JavaFX - 填充转换
- JavaFX - 描边转换
- JavaFX - 顺序转换
- JavaFX - 并行转换
- JavaFX - 暂停转换
- JavaFX - 路径转换
- JavaFX 图片
- JavaFX - 图片
- JavaFX 三维图形
- JavaFX - 三维图形
- JavaFX - 创建长方体
- JavaFX - 创建圆柱体
- JavaFX - 创建球体
- JavaFX 事件处理
- JavaFX - 事件处理
- JavaFX - 使用便捷方法
- JavaFX - 事件过滤器
- JavaFX - 事件处理器
- JavaFX UI 控件
- JavaFX - UI 控件
- JavaFX - 列表视图
- JavaFX - 手风琴
- JavaFX - 按钮栏
- JavaFX - 选择框
- JavaFX - HTML 编辑器
- JavaFX - 菜单栏
- JavaFX - 分页
- JavaFX - 进度指示器
- JavaFX - 滚动面板
- JavaFX - 分隔符
- JavaFX - 滑块
- JavaFX - 微调器
- JavaFX - 分割面板
- JavaFX - 表格视图
- JavaFX - 标签页面板
- JavaFX - 工具栏
- JavaFX - 树视图
- JavaFX - 标签
- JavaFX - 复选框
- JavaFX - 单选按钮
- JavaFX - 文本字段
- JavaFX - 密码字段
- JavaFX - 文件选择器
- JavaFX - 超链接
- JavaFX - 工具提示
- JavaFX - 警报框
- JavaFX - 日期选择器
- JavaFX - 文本区域
- JavaFX 图表
- JavaFX - 图表
- JavaFX - 创建饼图
- JavaFX - 创建折线图
- JavaFX - 创建区域图
- JavaFX - 创建条形图
- JavaFX - 创建气泡图
- JavaFX - 创建散点图
- JavaFX - 创建堆叠区域图
- JavaFX - 创建堆叠条形图
- JavaFX 布局面板
- JavaFX - 布局面板
- JavaFX - HBox 布局
- JavaFX - VBox 布局
- JavaFX - BorderPane 布局
- JavaFX - StackPane 布局
- JavaFX - TextFlow 布局
- JavaFX - AnchorPane 布局
- JavaFX - TilePane 布局
- JavaFX - GridPane 布局
- JavaFX - FlowPane 布局
- JavaFX CSS
- JavaFX - CSS
- JavaFX 多媒体
- JavaFX - 处理多媒体
- JavaFX - 播放视频
- JavaFX 有用资源
- JavaFX - 快速指南
- JavaFX - 有用资源
- JavaFX - 讨论
JavaFX - 二维图形
在上一章中,我们学习了 JavaFX 的基本应用,了解了如何创建一个空窗口以及如何在 JavaFX 的 XY 平面上绘制一条直线。除了直线,我们还可以绘制其他几种二维图形。
二维图形
一般来说,二维图形是在 XY 平面上绘制的几何图形,包括直线、矩形、圆形等。
使用 JavaFX 库,您可以绘制:
预定义图形,例如直线、矩形、圆形、椭圆、多边形、折线、三次贝塞尔曲线、二次贝塞尔曲线、弧形。
路径元素,例如 MoveTO 路径元素、直线、水平线、垂直线、三次贝塞尔曲线、二次贝塞尔曲线、弧形。
除此之外,您还可以通过解析 SVG 路径来绘制二维图形。
上述每个二维图形都由一个类表示,所有这些类都属于包 **javafx.scene.shape**。名为 **Shape** 的类是 JavaFX 中所有二维图形的基类。
在 JavaFX 中创建二维图形
要创建图表,您需要:
- 实例化所需图形的相应类。
- 设置图形的属性。
- 将图形对象添加到组中。
实例化相应类
要创建二维图形,首先需要实例化其相应的类。例如,如果要创建一个圆形,需要如下实例化名为 Circle 的类:
Circle circle = new Circle();
设置图形的属性
实例化类之后,需要使用 setter 方法为图形设置属性。例如,可以使用以下 setter 方法设置 Circle 类中心的 X、Y 坐标及其半径:
// Setting the Properties of a circle circle.setCenterX(300.0f); circle.setCenterY(135.0f); circle.setRadius(100.0f);
将图形对象添加到组中
最后,需要将圆形对象作为构造函数的参数传递给组,如下所示。
//Creating a Group object Group root = new Group(circle);
JavaFX 中提供的各种二维图形
下表列出了 JavaFX 提供的各种图形(类)。
序号 | 图形和描述 |
---|---|
1 |
直线
直线是连接两点的几何结构。包 **javafx.scene.shape** 的 **Line** 类表示 XY 平面上的直线。 |
2 |
矩形
一般来说,矩形是一个四边形,它有两对平行且相交的边,所有内角都是直角。在 JavaFX 中,矩形由名为 **Rectangle** 的类表示。此类属于包 **javafx.scene.shape**。 |
3 |
圆角矩形
在 JavaFX 中,您可以绘制具有尖锐边缘或圆弧边缘的矩形,具有圆弧边缘的矩形称为圆角矩形。 |
4 |
圆形
圆形是由一条形成闭合环路的线构成的,环路上的每个点与中心点的距离都相同。在 JavaFX 中,圆形由名为 **Circle** 的类表示。此类属于包 **javafx.scene.shape**。 |
5 |
椭圆
椭圆由两点定义,每个点称为焦点。如果取椭圆上的任意一点,则到焦点点的距离之和为常数。椭圆的大小由这两个距离之和决定。 在 JavaFX 中,椭圆由名为 **Ellipse** 的类表示。此类属于包 **javafx.scene.shape**。 |
6 |
多边形
由多个共面的线段首尾相连形成的闭合图形。在 JavaFX 中,多边形由名为 **Polygon** 的类表示。此类属于包 **javafx.scene.shape**。 |
7 |
折线
折线与多边形相同,只是折线末端不闭合。或者,是由一个或多个线段组成的连续线。在 JavaFX 中,折线由名为 **Polyline** 的类表示。此类属于包 **javafx.scene.shape**。 |
8 |
三次贝塞尔曲线
三次贝塞尔曲线是 XY 平面上的三次贝塞尔参数曲线。在 JavaFX 中,三次贝塞尔曲线由名为 **CubicCurve** 的类表示。此类属于包 **javafx.scene.shape**。 |
9 |
二次贝塞尔曲线
二次贝塞尔曲线是 XY 平面上的二次贝塞尔参数曲线。在 JavaFX 中,二次贝塞尔曲线由名为 **QuadCurve** 的类表示。此类属于包 **javafx.scene.shape**。 |
10 |
弧形
弧形是曲线的一部分。在 JavaFX 中,弧形由名为 **Arc** 的类表示。此类属于包 **javafx.scene.shape**。 弧形的类型除此之外,我们还可以绘制三种类型的弧形:**开放型、弦形、圆形**。 |
11 |
SVGPath
在 JavaFX 中,我们可以通过解析 SVG 路径来构建图像。此类图形由名为 **SVGPath** 的类表示。此类属于包 **javafx.scene.shape**。此类具有名为 **content** 的字符串类型属性。它表示应从中绘制图像的 SVG 路径编码字符串。 |
二维对象的属性
对于所有二维对象,您可以设置各种属性,例如填充、描边、StrokeType 等。以下部分讨论二维对象的各种属性。
我们将在本教程的后续部分详细学习这些属性。
二维对象的运算
如果我们将多个图形添加到一个组中,则第一个图形将被第二个图形重叠,如下所示。
除了变换(旋转、缩放、平移等)、转换(动画)之外,您还可以对二维对象执行三种运算,即:**并集、差集**和**交集**。
**并集运算:**此运算将两个或多个图形作为输入,并返回它们占据的区域。
交集运算:此运算以两个或多个形状作为输入,并返回它们之间的交集区域。
减法运算:此运算以两个或多个形状作为输入。然后,它返回第一个形状的面积,但不包括与第二个形状重叠的面积。