如何使用JavaFX创建堆积的条形图?

条形图接受一系列数据点(x,y)作为输入值,并创建表示其值的条形图。通常,这些图表用于表示类别的值。根据类别的轴,条形图的条形可以是垂直的或水平的。

StackedBarChart是BarChart的一种变体,它绘制显示指示类别数据值的条形图。这些条可以是垂直的或水平的,具体取决于哪个轴是类别轴。每个系列的栏都堆叠在上一个系列的顶部。

在JavaFX中,可以通过实例化javafx.scene.chart.StackedBarChart类来创建堆叠的条形图。

在实例化此类时,必须传递Axis类的两个对象,它们代表x轴和y轴(作为构造函数的参数)。由于Axis类是抽象的,因此您需要传递其具体子类的对象NumberNumber(用于数字值)或CategoryAxis(字符串值)。

创建轴后,可以使用setLabel()方法为其设置标签。

设定数据

XYChart.Series代表的一系列的数据项。您可以通过实例化此类来为条形图创建一系列点。此类包含一个可观察的列表,其中包含该系列中的所有点。

XYChart.Data表示在xy平面内的特定数据点。要创建一个点,您需要通过传递特定点的x和y值来实例化此类。

因此,要为条形创建数据-

  • 通过实例化XYChart.Data类来创建所需数量的点。

  • 通过实例化XYChart.Series类创建一个系列。

  • 使用getData()方法获取XYChart.Series类的可观察列表。

  • 使用add()addAll()方法将创建的数据点添加到列表中。

  • 将创建的数据系列添加到面积图中,如下所示:

barChart.getData().add(series);

示例

import javafx.application.Application;
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;
import javafx.scene.layout.StackPane;
public class StackedBarChartExample extends Application {
   @Override
   public void start(Stage stage) {
      //Defining the axes
      CategoryAxis xAxis = new CategoryAxis();
      xAxis.setLabel("Year");
      NumberAxis yAxis = new NumberAxis();
      yAxis.setLabel("Population (In millions)");
      //Creating the Bar chart
      StackedBarChart stackedBarChart = new StackedBarChart(xAxis, yAxis);
      stackedBarChart.setTitle("World Population by Region");
      //Prepare XYChart.Series objects by setting data
      XYChart.Series series1 = new XYChart.Series<>();
      series1.setName("Asia");
      series1.getData().add(new XYChart.Data<>("2012", 900));
      series1.getData().add(new XYChart.Data<>("2013", 1000));
      series1.getData().add(new XYChart.Data<>("2014", 1170));
      series1.getData().add(new XYChart.Data<>("2015", 1250));
      series1.getData().add(new XYChart.Data<>("2016", 1530));
      XYChart.Series series2 = new XYChart.Series<>();
      series2.setName("Europe");
      series2.getData().add(new XYChart.Data<>("2012", 390));
      series2.getData().add(new XYChart.Data<>("2013", 400));
      series2.getData().add(new XYChart.Data<>("2014", 440));
      series2.getData().add(new XYChart.Data<>("2015", 480));
      series2.getData().add(new XYChart.Data<>("2016", 540));
      //Setting the data to bar chart
      stackedBarChart.getData().addAll(series1, series2);
      //Creating a stack pane to hold the chart
      StackPane pane = new StackPane(stackedBarChart);
      //Setting the Scene
      Scene scene = new Scene(pane, 595, 300);
      stage.setTitle("Stacked Bar Chart");
      stage.setScene(scene);
      stage.show();
   }
   public static void main(String args[]){
      launch(args);
   }
}

输出结果