JavaFX 创建带负值的面积图示例

javafxobject oriented programmingprogramming更新于 2025/6/26 5:07:17

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

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

带有 ve 个值的面积图

  • XYChart.Data 类表示图表中的一个数据点,您可以通过实例化此类来创建数据点。

XYChart.Data dataPoint1 = new XYChart.Data(x-value, y-value)
XYChart.Data dataPoint2 = new XYChart.Data(x-value, y-value)
XYChart.Data dataPoint3 = new XYChart.Data(x-value, y-value)
  • 当您使用以下函数时,您可以将 ve 个整数作为值(在数轴上)传递:这样做的话,会在(相反的)轴的 0 点处绘制一条水平线,所有负值都绘制在其下方,所有正值都绘制在其上方。

  • 创建所有必需的数据点后,您可以创建一个需要实例化 XYChart.Series 类的系列,并将数据点添加到其中。

XYChart.Series series = XYChart.Series
series.getData().add(dataPoint1);
series.getData().add(dataPoint2);
series.getData().add(dataPoint3);
  • 您可以根据需要创建任意数量的此类系列。

示例

import javafx.application.Application;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.stage.Stage;
import javafx.scene.chart.AreaChart;
import javafx.scene.chart.CategoryAxis;
import javafx.scene.chart.NumberAxis;
import javafx.scene.chart.XYChart;
import javafx.scene.layout.StackPane;
public class AreaCharts_NegativeValues extends Application {
   public void start(Stage stage) {
      //定义 x 轴和 y 轴
      CategoryAxis xAxis = new CategoryAxis();
      NumberAxis yAxis = new NumberAxis(-5, 7.5, 2.5);
      //设置轴的标签
      yAxis.setLabel("Values");
      //创建面积图
      AreaChart areaChart = new AreaChart(xAxis, yAxis);
      //准备系列1的数据点
      XYChart.Series series1 = new XYChart.Series();
      series1.getData().add(new XYChart.Data("Apples", 2));
      series1.getData().add(new XYChart.Data("Oranges", -2));
      series1.getData().add(new XYChart.Data("Pears", -3));
      series1.getData().add(new XYChart.Data("Grapes", 2));
      series1.getData().add(new XYChart.Data("Bananas", 1));
      //准备系列 3 的数据点
      XYChart.Series series 2 = new XYChart.Series();
      series2.getData().add(new XYChart.Data("Apples", 2));
      series2.getData().add(new XYChart.Data("Oranges", 4));
      series2.getData().add(new XYChart.Data("Pears", 4));
      series2.getData().add(new XYChart.Data("Grapes", -2));
      series2.getData().add(new XYChart.Data("Bananas", 5));
      //设置所有系列的名称
      series1.setName("John";);
      series2.setName("Jane";);
      //设置面积图的数据
      areaChart.getData().addAll( series1, series2);
      //创建一个堆栈窗格来保存图表
      StackPane pane = new StackPane(areaChart);
      pane.setPadding(new Insets(15, 15, 15, 15));
      pane.setStyle("-fx-background-color: BEIGE");
      //设置场景
      Scene scene = new Scene(pane, 595, 350);
      stage.setTitle("Area Chart");
      stage.setScene(scene);
      stage.show();
   }
   public static void main(String args[]){
      launch(args);
   }
}

输出


相关文章