JavaFX - 堆叠条形图
StackedBarChart 是 BarChart 的变体,它绘制指示类别数据值的条形图。条形图可以是垂直的,也可以是水平的,具体取决于哪个轴是类别轴。每个系列的条形图都堆叠在前一个系列的顶部。
以下是堆叠条形图,它描绘了人口增长情况。
在 JavaFX 中,堆叠条形图由名为 StackedBarChart 的类表示。此类属于 javafx.scene.chart 包。通过实例化此类,您可以在 JavaFX 中创建 StackedBarChart 节点。
生成堆叠条形图的步骤
要在 JavaFX 中生成堆叠条形图,请按照以下步骤操作。
步骤 1:创建类
创建一个 Java 类并继承 javafx.application 包的 Application 类。然后,您可以按如下方式实现此类的 start() 方法。
public class ClassName extends Application { @Override public void start(Stage primaryStage) throws Exception { } }
步骤 2:定义轴
定义堆积条形图的 X 轴和 Y 轴并为其设置标签。在我们的示例中,X 轴代表各大洲,y 轴代表以百万为单位的人口。
//Defining the x axis CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String>observableArrayList(Arrays.asList ("Africa", "America", "Asia", "Europe", "Oceania"))); xAxis.setLabel("category"); //Defining the y axis NumberAxis yAxis = new NumberAxis(); yAxis.setLabel("Population (In millions)");
步骤 3:创建堆叠条形图
通过实例化包 javafx.scene.chart 中名为 StackedBarChart 的类来创建折线图。向此类的构造函数传递上一步中创建的表示 X 轴和 Y 轴的对象。
//Creating the Bar chart StackedBarChart<String, Number> stackedBarChart = new StackedBarChart<>(xAxis, yAxis); stackedBarChart.setTitle("Historic World Population by Region");
步骤 4:准备数据
实例化 XYChart.Series 类,并将数据(一系列 x 和 y 坐标)添加到该类的 Observable 列表中,如下所示 −
//Prepare XYChart.Series objects by setting data XYChart.Series<String, Number> series1 = new XYChart.Series<>(); series1.setName("1800"); series1.getData().add(new XYChart.Data<>("Africa", 107)); series1.getData().add(new XYChart.Data<>("America", 31)); series1.getData().add(new XYChart.Data<>("Asia", 635)); series1.getData().add(new XYChart.Data<>("Europe", 203)); series1.getData().add(new XYChart.Data<>("Oceania", 2)); XYChart.Series<String, Number> series2 = new XYChart.Series<>(); series2.setName("1900"); series2.getData().add(new XYChart.Data<>("Africa", 133)); series2.getData().add(new XYChart.Data<>("America", 156)); series2.getData().add(new XYChart.Data<>("Asia", 947)); series2.getData().add(new XYChart.Data<>("Europe", 408)); series1.getData().add(new XYChart.Data<>("Oceania", 6)); XYChart.Series<String, Number> series3 = new XYChart.Series<>(); series3.setName("2008"); series3.getData().add(new XYChart.Data<>("Africa", 973)); series3.getData().add(new XYChart.Data<>("America", 914)); series3.getData().add(new XYChart.Data<>("Asia", 4054)); series3.getData().add(new XYChart.Data<>("Europe", 732)); series1.getData().add(new XYChart.Data<>("Oceania", 34));
步骤 5:将数据添加到堆积条形图
将上一步中准备的数据系列添加到条形图中,如下所示 −
//Setting the data to bar chart stackedBarChart.getData().addAll(series1, series2, series3);
步骤 6:创建组对象
在 start() 方法中,通过实例化名为 Group 的类来创建组对象。该类属于 javafx.scene 包。
将上一步中创建的 StackedBarChart(节点)对象作为参数传递给 Group 类的构造函数。应按如下方式将其添加到组中 −
Group root = new Group(stackedBarChart);
步骤 7:创建场景对象
通过实例化名为 Scene 的类来创建场景,该类属于包 javafx.scene。将上一步中创建的 Group 对象(根)传递给此类。
除了根对象之外,您还可以传递两个表示屏幕高度和宽度的双精度参数以及 Group 类的对象,如下所示。
Scene scene = new Scene(group ,600, 300);
步骤 8:设置 Stage 的标题
您可以使用 Stage 类的 setTitle() 方法将标题设置为 Stage 。此 primaryStage 是一个 Stage 对象,它作为参数传递给场景类的启动方法。
使用 primaryStage 对象,将场景的标题设置为 Sample Application,如下所示。
primaryStage.setTitle("Sample Application");
步骤 9:将场景添加到 Stage
您可以使用名为 Stage 的类的方法 setScene() 将场景对象添加到 Stage 。使用此方法添加前面步骤中准备的场景对象,如下所示。
primaryStage.setScene(scene);
步骤 10:显示 Stage 内容
使用 Stage 类的 show() 方法显示场景内容,如下所示。
primaryStage.show();
步骤 11:启动应用程序
通过从主方法调用 Application 类的静态方法 launch() 来启动 JavaFX 应用程序,如下所示。
public static void main(String args[]){ launch(args); }
示例
下表列出了 1800 年、1900 年和 2008 年各大洲的人口。
非洲 | 美洲 | 亚洲 | 欧洲 | 大洋洲 | |
---|---|---|---|---|---|
1800 | 107 | 31 | 635 | 203 | 2 |
1900 | 133 | 156 | 947 | 408 | 6 |
2008 | 973 | 914 | 4054 | 732 | 34 |
以下是使用 JavaFX 生成描述上述数据的堆积条形图的 Java 程序。
将此代码保存在名为 StackedBarChartExample.java 的文件中。
import java.util.Arrays; import javafx.application.Application; import javafx.collections.FXCollections; import javafx.scene.Group; import javafx.scene.Scene; import javafx.scene.chart.CategoryAxis; import javafx.stage.Stage; import javafx.scene.chart.NumberAxis; import javafx.scene.chart.StackedBarChart; import javafx.scene.chart.XYChart; public class StackedBarChartExample extends Application { @Override public void start(Stage stage) { //Defining the axes CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String>observableArrayList(Arrays.asList ("Africa", "America", "Asia", "Europe", "Oceania"))); xAxis.setLabel("category"); NumberAxis yAxis = new NumberAxis(); yAxis.setLabel("Population (In millions)"); //Creating the Bar chart StackedBarChart<String, Number> stackedBarChart = new StackedBarChart<>(xAxis, yAxis); stackedBarChart.setTitle("Historic World Population by Region"); //Prepare XYChart.Series objects by setting data XYChart.Series<String, Number> series1 = new XYChart.Series<>(); series1.setName("1800"); series1.getData().add(new XYChart.Data<>("Africa", 107)); series1.getData().add(new XYChart.Data<>("America", 31)); series1.getData().add(new XYChart.Data<>("Asia", 635)); series1.getData().add(new XYChart.Data<>("Europe", 203)); series1.getData().add(new XYChart.Data<>("Oceania", 2)); XYChart.Series<String, Number> series2 = new XYChart.Series<>(); series2.setName("1900"); series2.getData().add(new XYChart.Data<>("Africa", 133)); series2.getData().add(new XYChart.Data<>("America", 156)); series2.getData().add(new XYChart.Data<>("Asia", 947)); series2.getData().add(new XYChart.Data<>("Europe", 408)); series1.getData().add(new XYChart.Data<>("Oceania", 6)); XYChart.Series<String, Number> series3 = new XYChart.Series<>(); series3.setName("2008"); series3.getData().add(new XYChart.Data<>("Africa", 973)); series3.getData().add(new XYChart.Data<>("America", 914)); series3.getData().add(new XYChart.Data<>("Asia", 4054)); series3.getData().add(new XYChart.Data<>("Europe", 732)); series1.getData().add(new XYChart.Data<>("Oceania", 34)); //Setting the data to bar chart stackedBarChart.getData().addAll(series1, series2, series3); //Creating a Group object Group root = new Group(stackedBarChart); //Creating a scene object Scene scene = new Scene(root, 600, 400); //Setting title to the Stage stage.setTitle("stackedBarChart"); //Adding scene to the stage stage.setScene(scene); //Displaying the contents of the stage stage.show(); } public static void main(String args[]){ launch(args); } }
使用以下命令从命令提示符编译并执行保存的 java 文件。
javac StackedBarChartExample.java java StackedBarChartExample
执行时,上述程序会生成一个 JavaFX 窗口,其中显示如下所示的面积图。