StackedBarChart是BarChart的变体,它绘制了指示类别数据值的条形图。条形可以是垂直的或水平的,这取决于哪个轴是类别轴。每个系列的栏位于上一系列的顶部。
以下是堆积条形图,描绘了人口增长。
在JavaFX中,堆积条形图由名为StackedBarChart 的类表示 。该类属于包javafx.scene.chart 。通过实例化此类,您可以在JavaFX中创建StackedBarChart节点。
生成堆积条形图的步骤 要在JavaFX中生成堆积条形图,请按照以下步骤操作。
第1步:创建一个类 创建Java类并继承包javafx.application 的Application 类。然后,您可以按如下方式实现此类的start() 方法。
1 2 3 4 5 public class ClassName extends Application { @Override public void start(Stage primaryStage) throws Exception { } }
第2步:定义轴 定义堆积条形图的X轴和Y轴,并为它们设置标签。在我们的例子中,X轴代表大陆,y轴代表数百万的人口。
1 2 3 4 5 6 7 8 9 10 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)" );
第3步:创建堆积条形图 通过实例化包javafx.scene.chart的 名为StackedBarChart 的类来创建折线图。对于此类的构造函数,传递表示在上一步中创建的X轴和Y轴的对象。
1 2 3 4 StackedBarChart<String , Number> stackedBarChart = new StackedBarChart <>(xAxis, yAxis); stackedBarChart.setTitle("Historic World Population by Region" );
第4步:准备数据 实例化XYChart.Series 类并将数据(一系列,x和y坐标)添加到此类的Observable列表中,如下所示 -
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 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步:将数据添加到堆积条形图 将上一步骤中准备的数据系列添加到条形图中,如下所示 -
1 2 stackedBarChart.getData.addAll;
第6步:创建组对象 在start() 方法中,通过实例化名为Group 的类来创建组对象。这属于包javafx.scene 。
将上一步中创建的StackedBarChart(节点)对象作为参数传递给Group类的构造函数。这样做是为了将其添加到组中,如下所示 -
1 Group root = new Group(stackedBarChart);
第7步:创建场景对象 通过实例化名 为Scene 的类来创建一个Scene,该类属于包javafx.scene 。对于此类,传递在上一步中创建的Group对象(root)。
除了根对象之外,您还可以传递两个表示屏幕高度和宽度的双参数,以及Group类的对象,如下所示。
1 Scene scene = new Scene(group ,600 , 300 )
第8步:设置舞台的标题 您可以使用Stage 类的setTitle() 方法将标题设置为舞台 。此primaryStage 是一个Stage对象,它作为参数传递给场景类的start方法。
使用primaryStage 对象,将场景标题设置为Sample Application ,如下所示。
1 primaryStage.setTitle("Sample Application" )
第9步:将场景添加到舞台 您可以使用名为Stage的类的方法setScene() 将Scene对象添加到舞台。使用此方法添加前面步骤中准备的Scene对象,如下所示。
1 primaryStage.setScene(scene)
第10步:显示舞台的内容 显示场景的使用命名的方法的内容显示() 的的阶段 类,如下所示。
第11步:启动应用程序 通过从main方法调用Application 类的静态方法launch() 来启动JavaFX应用程序,如下所示。
1 2 3 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
以下是一个Java程序,它使用JavaFX生成描述上述数据的堆积条形图。
将此代码保存在名为StackedBarChartExample.java 的文件中。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 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) { 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)" ); StackedBarChart<String , Number> stackedBarChart = new StackedBarChart <>(xAxis, yAxis); stackedBarChart.setTitle("Historic World Population by Region" ); 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 )); stackedBarChart.getData().addAll(series1, series2, series3); Group root = new Group (stackedBarChart); Scene scene = new Scene (root, 600 , 400 ); stage.setTitle("stackedBarChart" ); stage.setScene(scene); stage.show(); } public static void main(String args[]){ launch(args); } }
使用以下命令从命令提示符编译并执行保存的java文件。
1 2 javac StackedBarChartExample.java java StackedBarChartExample
在执行时,上述程序生成一个显示面积图的JavaFX窗口,如下所示。