JavaFX - 条形图
条形图用于使用矩形条表示分组数据。这些条的长度表示值。条形图中的条可以垂直或水平绘制。
以下是比较各种汽车品牌的条形图。
在 JavaFX 中,条形图由名为 BarChart 的类表示。此类属于 javafx.scene.chart 包。通过实例化此类,您可以在 JavaFX 中创建 BarChart 节点。
生成条形图的步骤
要在 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 轴表示分数。
//定义 x 轴 CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String>observableArrayList(Arrays.asList( "Speed", "User ratings", "Milage", "Safety"))); xAxis.setLabel("category"); //定义 y 轴 NumberAxis yAxis = new NumberAxis(); yAxis.setLabel("score");
步骤 3:创建条形图
通过实例化包 javafx.scene.chart 中名为 BarChart 的类来创建折线图。将上一步中创建的表示 X 轴和 Y 轴的对象传递给此类的构造函数。
//创建条形图 BarChart<String, Number> barChart = new BarChart<>(xAxis, yAxis); barChart.setTitle("各种汽车之间的比较");
步骤 4:准备数据
实例化 XYChart.Series 类,并将数据(一系列 x 和 y 坐标)添加到此类的 Observable 列表中,如下所示 −
//通过设置数据准备 XYChart.Series 对象 XYChart.Series<String, Number> series1 = new XYChart.Series<>(); series1.setName("Fiat"); series1.getData().add(new XYChart.Data<>("Speed", 1.0)); series1.getData().add(new XYChart.Data<>("User rating", 3.0)); series1.getData().add(new XYChart.Data<>("Milage", 5.0)); series1.getData().add(new XYChart.Data<>("Safety", 5.0)); XYChart.Series<String, Number> series2 = new XYChart.Series<>(); series2.setName("Audi"); series2.getData().add(new XYChart.Data<>("Speed", 5.0)); series2.getData().add(new XYChart.Data<>("User rating", 6.0)); series2.getData().add(new XYChart.Data<>("Milage", 10.0)); series2.getData().add(new XYChart.Data<>("Safety", 4.0)); XYChart.Series<String, Number> series3 = new XYChart.Series<>(); series3.setName("Ford"); series3.getData().add(new XYChart.Data<>("Speed", 4.0)); series3.getData().add(new XYChart.Data<>("User rating", 2.0)); series3.getData().add(new XYChart.Data<>("Milage", 3.0)); series3.getData().add(new XYChart.Data<>("Safety", 6.0));
步骤 5:将数据添加到条形图
将上一步中准备的数据系列添加到条形图,如下所示 −
//将数据设置为条形图 barChart.getData().addAll(series1, series2, series3);
步骤 6:创建组对象
在 start() 方法中,通过实例化名为 Group 的类来创建组对象。这属于包 javafx.scene。
将上一步中创建的 BarChart(节点)对象作为参数传递给 Group 类的构造函数。应这样做以将其添加到组中,如下所示 −
Group root = new Group(barChart);
步骤 7:创建场景对象
通过实例化名为 Scene 的类来创建场景,该类属于包 javafx.scene。将上一步中创建的 Group 对象 (root) 传递给此类。
除了 root 对象之外,您还可以传递两个表示屏幕高度和宽度的双精度参数以及 Group 类的对象,如下所示。
Scene scene = new Scene(group ,600, 300);
步骤 8:设置舞台(Stage)的标题
您可以使用 Stage 类的 setTitle() 方法将标题设置为舞台(Stage)。 primaryStage 是一个 Stage 对象,它作为参数传递给场景类的 start 方法。
使用 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); }
示例
以下示例借助条形图描绘了各种汽车统计数据。以下是汽车品牌及其不同特征的列表,我们将使用条形图显示这些特征 −
汽车 | 速度 | 用户评分 | 里程 | 安全性 |
---|---|---|---|---|
Fiat | 1.0 | 3.0 | 5.0 | 5.0 |
Audi | 5.0 | 6.0 | 10.0 | 4.0 |
Ford | 4.0 | 2.0 | 3.0 | 6.0 |
以下是一个 Java 程序,它生成一个条形图,使用 JavaFX 描绘上述数据。
将此代码保存在名为 BarChartExample.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.BarChart; import javafx.scene.chart.CategoryAxis; import javafx.stage.Stage; import javafx.scene.chart.NumberAxis; import javafx.scene.chart.XYChart; public class BarChartExample extends Application { @Override public void start(Stage stage) { //Defining the axes CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String> observableArrayList(Arrays.asList("Speed", "User rating", "Milage", "Safety"))); xAxis.setLabel("category"); NumberAxis yAxis = new NumberAxis(); yAxis.setLabel("score"); //Creating the Bar chart BarChart<String, Number> barChart = new BarChart<>(xAxis, yAxis); barChart.setTitle("Comparison between various cars"); //Prepare XYChart.Series objects by setting data XYChart.Series<String, Number> series1 = new XYChart.Series<>(); series1.setName("Fiat"); series1.getData().add(new XYChart.Data<>("Speed", 1.0)); series1.getData().add(new XYChart.Data<>("User rating", 3.0)); series1.getData().add(new XYChart.Data<>("Milage", 5.0)); series1.getData().add(new XYChart.Data<>("Safety", 5.0)); XYChart.Series<String, Number> series2 = new XYChart.Series<>(); series2.setName("Audi"); series2.getData().add(new XYChart.Data<>("Speed", 5.0)); series2.getData().add(new XYChart.Data<>("User rating", 6.0)); series2.getData().add(new XYChart.Data<>("Milage", 10.0)); series2.getData().add(new XYChart.Data<>("Safety", 4.0)); XYChart.Series<String, Number> series3 = new XYChart.Series<>(); series3.setName("Ford"); series3.getData().add(new XYChart.Data<>("Speed", 4.0)); series3.getData().add(new XYChart.Data<>("User rating", 2.0)); series3.getData().add(new XYChart.Data<>("Milage", 3.0)); series3.getData().add(new XYChart.Data<>("Safety", 6.0)); //Setting the data to bar chart barChart.getData().addAll(series1, series2, series3); //Creating a Group object Group root = new Group(barChart); //Creating a scene object Scene scene = new Scene(root, 600, 400); //Setting title to the Stage stage.setTitle("Bar Chart"); //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 BarChartExample.java java BarChartExample
执行时,上述程序会生成一个 JavaFX 窗口,其中显示如下所示的面积图。