如何使用JavaFX创建面积图?

面积图接受一系列数据点(x,y)作为输入值,使用一条线连接它们,并映射所获得的线和轴之间的区域。在JavaFX中,您可以通过实例化javafx.scene.chart.AreaChart类来创建面积图。

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

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

设定数据

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

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

因此,要为一行创建数据-

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

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

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

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

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

areachart.getData().add(series);

示例

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.chart.AreaChart;
import javafx.stage.Stage;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.layout.StackPane;
public class AreaChartExample extends Application {
   public void start(Stage stage) {
      //定义X和Y轴
      NumberAxis xAxis = new NumberAxis();
      NumberAxis yAxis = new NumberAxis(); …
      //将标签设置到轴
      xAxis.setLabel("Months");
      yAxis.setLabel("Rainfall (mm)");
      //创建面积图
      AreaChart<String, Number> areaChart = new AreaChart(xAxis, yAxis);
      //准备面积图的数据
      XYChart.Series series = new XYChart.Series();
      series.getData().add(new XYChart.Data(1, 13.2));
      series.getData().add(new XYChart.Data(2, 7.9));
      series.getData().add(new XYChart.Data(3, 15.3));
      series.getData().add(new XYChart.Data(4, 20.2));
      series.getData().add(new XYChart.Data(5, 35.7));
      series.getData().add(new XYChart.Data(6, 103.8));
      series.getData().add(new XYChart.Data(7, 169.9));
      series.getData().add(new XYChart.Data(8, 178.7));
      series.getData().add(new XYChart.Data(9, 158.3));
      series.getData().add(new XYChart.Data(10, 97.2));
      series.getData().add(new XYChart.Data(11, 22.4));
      series.getData().add(new XYChart.Data(12, 5.9));
      //将名称设置为行(系列)
      series.setName("Rainfall In Hyderabad");
      //将数据设置为面积图
      areaChart.getData().addAll(series);
      //创建一个堆栈窗格来保存图表
      StackPane pane = new StackPane(areaChart);
      //设置场景
      Scene scene = new Scene(pane, 595, 300);
      stage.setTitle("Area Chart");
      stage.setScene(scene);
      stage.show();
   }
   public static void main(String args[]){
      launch(args);
   }
}

输出结果