使用Java 13中的新的JavaFX图表组件来实现数据可视化

2023年 8月 28日 71.7k 0

使用Java 13中的新的JavaFX图表组件来实现数据可视化

引言:数据可视化是将数据呈现为图表、图形和其他视觉元素的过程。通过数据可视化,我们可以更好地理解和解释数据,发现隐藏在数据背后的模式和关系。JavaFX是一个强大的Java库,其中包含许多用于创建交互式和富有创意的用户界面的组件。在Java 13中,JavaFX引入了一些新的图表组件,使数据可视化变得更加简单和灵活。在本文中,我们将介绍如何使用JavaFX的新图表组件来实现数据可视化,并提供一些示例代码。

一、环境设置首先,我们需要确保我们已经安装了Java 13和JavaFX。然后,我们需要在Java项目中引入JavaFX库。可以通过Maven或手动下载JavaFX库,并将其添加到项目中的类路径中。

二、创建基本的JavaFX应用在使用JavaFX的新图表组件之前,我们先创建一个基本的JavaFX应用程序。以下是一个简单的JavaFX应用程序模板:

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;

public class DataVisualizationApp extends Application {
public static void main(String[] args) {
launch(args);
}

@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("数据可视化应用");
StackPane root = new StackPane();
Scene scene = new Scene(root, 800, 600);
primaryStage.setScene(scene);
primaryStage.show();
}
}

登录后复制

这是一个最简单的JavaFX应用程序,它创建一个空的舞台(Stage),并设置了一个背景为800x600像素的场景(Scene)。我们可以在该场景中添加其他JavaFX组件来实现我们的数据可视化。

三、使用LineChart绘制折线图JavaFX的新图表组件之一是LineChart,它能够显示一组数据点之间的连续线条。以下是如何使用LineChart来绘制折线图的示例代码:

import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.scene.Scene;
import javafx.scene.chart.LineChart;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;

public class DataVisualizationApp extends Application {
public static void main(String[] args) {
launch(args);
}

@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("数据可视化应用");

// 创建x轴和y轴
final NumberAxis xAxis = new NumberAxis();
final NumberAxis yAxis = new NumberAxis();
xAxis.setLabel("X轴");
yAxis.setLabel("Y轴");

// 创建LineChart并设置数据
final LineChart lineChart = new LineChart(xAxis, yAxis);
lineChart.setTitle("折线图");
XYChart.Series series = new XYChart.Series();
series.setName("数据系列");
series.setData(FXCollections.observableArrayList(
new XYChart.Data(1, 23),
new XYChart.Data(2, 14),
new XYChart.Data(3, 15),
new XYChart.Data(4, 24),
new XYChart.Data(5, 34)
));

lineChart.getData().add(series);

StackPane root = new StackPane();
root.getChildren().add(lineChart);

Scene scene = new Scene(root, 800, 600);
primaryStage.setScene(scene);
primaryStage.show();
}
}

登录后复制

此代码示例创建了一个LineChart,并在该图表中添加了一个数据系列。可以通过在系列中添加XYChart.Data来指定数据点的x和y坐标。在示例中,我们创建了一个包含5个数据点的系列,并将其添加到LineChart中显示。

四、使用BarChart绘制柱状图除了折线图,我们还可以使用JavaFX的新图表组件之一,即BarChart,来绘制柱状图。以下是如何使用BarChart来绘制柱状图的示例代码:

import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.scene.Scene;
import javafx.scene.chart.BarChart;
import javafx.scene.chart.CategoryAxis;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.layout.StackPane;
import javafx.stage.Stage;

public class DataVisualizationApp extends Application {
public static void main(String[] args) {
launch(args);
}

@Override
public void start(Stage primaryStage) {
primaryStage.setTitle("数据可视化应用");

// 创建x轴和y轴
final CategoryAxis xAxis = new CategoryAxis();
final NumberAxis yAxis = new NumberAxis();
xAxis.setLabel("X轴");
yAxis.setLabel("Y轴");

// 创建BarChart并设置数据
final BarChart barChart = new BarChart(xAxis, yAxis);
barChart.setTitle("柱状图");
XYChart.Series series = new XYChart.Series();
series.setName("数据系列");
series.setData(FXCollections.observableArrayList(
new XYChart.Data("一月", 23),
new XYChart.Data("二月", 14),
new XYChart.Data("三月", 15),
new XYChart.Data("四月", 24),
new XYChart.Data("五月", 34)
));

barChart.getData().add(series);

StackPane root = new StackPane();
root.getChildren().add(barChart);

Scene scene = new Scene(root, 800, 600);
primaryStage.setScene(scene);
primaryStage.show();
}
}

登录后复制

此代码示例创建了一个BarChart,并在该图表中添加了一个数据系列。可以使用XYChart.Data来指定每个柱状图的名称(x轴)和高度(y轴)。在示例中,我们创建了一个包含5个柱状图的数据系列,并将其添加到BarChart中显示。

结论:通过JavaFX的新图表组件,实现数据可视化变得更加简单和灵活。我们可以使用LineChart绘制折线图,使用BarChart绘制柱状图,以及在每个图表中添加多个数据系列。这些示例代码可以作为我们开始使用JavaFX图表组件的基础,我们可以根据实际需求进行进一步的定制和扩展。希望本文可以帮助你开始使用JavaFX的新图表组件来实现数据可视化。

以上就是使用Java 13中的新的JavaFX图表组件来实现数据可视化的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论