JavaFX图表(九)之堆积面积图
翻譯自??JavaFX - 堆積面積圖
StackedArea Chart是區域圖的變體,顯示每個值的貢獻趨勢(例如 - 加班)。堆疊區域使每個系列相鄰,但不與前面的系列重疊。這與區域圖表形成對比,其中每個系列覆蓋前面的系列。
以下是描繪人口增長的堆積圖表。
?
在JavaFX中,堆積區域圖表由名為StackedAreaChart的類表示。該類屬于包javafx.scene.chart。通過實例化此類,您可以在JavaFX中創建StackedAreaChart節點。
生成堆積面積圖的步驟
要在JavaFX中生成堆積區域圖表,請按照以下步驟操作。
第1步:創建一個類
創建一個Java類并繼承包javafx.application的Application類。然后,您可以按如下方式實現此類的start()方法。
public class ClassName extends Application { @Override public void start(Stage primaryStage) throws Exception { } }第2步:定義軸
定義堆積面積圖的X和Y軸并為其設置標簽。在我們的例子中,X軸表示從1750年到2050年的不同年份。這些年有50年的主要蜱單位。而Y軸代表數百萬人口的增長。
//Defining the X axis CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String>observableArrayList(Arrays.asList("1 750", "1800", "1850", "1900", "1950", "1999", "2050" ))); //Defining the Y axis NumberAxis yAxis = new NumberAxis(0, 10000, 2500); yAxis.setLabel("Population in Billions");第3步:創建堆積面積圖
通過實例化包javafx.scene.chart的名為StackedAreaChart的類來創建折線圖。對于此類的構造函數,傳遞表示在上一步中創建的X軸和Y軸的對象。
//Creating the Area chart StackedAreaChart<String, Number> areaChart = new StackedAreaChart(xAxis, yAxis); areaChart.setTitle("Historic and Estimated Worldwide Population Growth by Region");第4步:準備數據
實例化XYChart.Series類并將數據(一系列,x和y坐標)添加到此類的Observable列表中,如下所示 -
//Prepare XYChart.Series objects by setting data XYChart.Series series1 = new XYChart.Series(); series1.setName("Asia"); series1.getData().add(new XYChart.Data("1750", 502)); series1.getData().add(new XYChart.Data("1800", 635)); series1.getData().add(new XYChart.Data("1850", 809)); series1.getData().add(new XYChart.Data("1900", 947)); series1.getData().add(new XYChart.Data("1950", 1402)); series1.getData().add(new XYChart.Data("1999", 3634)); series1.getData().add(new XYChart.Data("2050", 5268)); XYChart.Series series2 = new XYChart.Series(); series2.setName("Africa"); series2.getData().add(new XYChart.Data("1750", 106)); series2.getData().add(new XYChart.Data("1800", 107)); series2.getData().add(new XYChart.Data("1850", 111)); series2.getData().add(new XYChart.Data("1900", 133)); series2.getData().add(new XYChart.Data("1950", 221)); series2.getData().add(new XYChart.Data("1999", 767)); series2.getData().add(new XYChart.Data("2050", 1766)); XYChart.Series series3 = new XYChart.Series(); series3.setName("Europe"); series3.getData().add(new XYChart.Data("1750", 163)); series3.getData().add(new XYChart.Data("1800", 203)); series3.getData().add(new XYChart.Data("1850", 276)); series3.getData().add(new XYChart.Data("1900", 408)); series3.getData().add(new XYChart.Data("1950", 547)); series3.getData().add(new XYChart.Data("1999", 729)); series3.getData().add(new XYChart.Data("2050", 628)); XYChart.Series series4 = new XYChart.Series(); series4.setName("America"); series4.getData().add(new XYChart.Data("1750", 18)); series4.getData().add(new XYChart.Data("1800", 31)); series4.getData().add(new XYChart.Data("1850", 54)); series4.getData().add(new XYChart.Data("1900", 156)); series4.getData().add(new XYChart.Data("1950", 339)); series4.getData().add(new XYChart.Data("1999", 818)); series4.getData().add(new XYChart.Data("2050", 1201)); XYChart.Series series5 = new XYChart.Series(); series5.setName("Oceania"); series5.getData().add(new XYChart.Data("1750", 2)); series5.getData().add(new XYChart.Data("1800", 2)); series5.getData().add(new XYChart.Data("1850", 2)); series5.getData().add(new XYChart.Data("1900", 6)); series5.getData().add(new XYChart.Data("1950", 13)); series5.getData().add(new XYChart.Data("1999", 30)); series5.getData().add(new XYChart.Data("2050", 46));第5步:將數據添加到堆積區域圖表
將上一步驟中準備的數據系列添加到堆積區域圖表中,如下所示 -
//Setting the data to area chart areaChart.getData().addAll(series1, series2, series3, series4, series5);第6步:創建組對象
在start()方法中,通過實例化名為Group的類來創建組對象,該類屬于包javafx.scene。
將上一步中創建的StackedAreaChart(node)對象作為參數傳遞給Group類的構造函數。這應該是為了將它添加到組中,如下所示 -
Group root = new Group(stackedAreaChart);第7步:創建場景對象
通過實例化名為Scene的類來創建一個Scene,該類屬于包javafx.scene。在此類中,傳遞上一步中創建的Group對象(root)。
除了根對象之外,還可以傳遞兩個表示屏幕高度和寬度的雙參數,以及Group類的對象,如下所示。
Scene scene = new Scene(group ,600, 300);第8步:設置舞臺的標題
您可以使用Stage類的setTitle()方法將標題設置為舞臺。所述primaryStage是Stage對象,它被傳遞給場景類作為參數的啟動方法。
使用primaryStage對象,將場景標題設置為Sample Application,如下所示。
primaryStage.setTitle("Sample Application");第9步:將場景添加到舞臺
您可以使用名為Stage的類的方法setScene()將Scene對象添加到舞臺。使用此方法添加前面步驟中準備的Scene對象,如下所示。
primaryStage.setScene(scene);第10步:顯示舞臺的內容
顯示場景的使用命名的方法的內容顯示()的的階段類,如下所示。
primaryStage.show();第11步:啟動應用程序
通過從main方法調用Application類的靜態方法launch()來啟動JavaFX應用程序,如下所示。
public static void main(String args[]){ launch(args); }例
下表列出了從1750年到2050年不同大陸的人口。
| ? | 亞洲非洲歐洲美國大洋洲||||
| 502 | 106 | 163 | 18 | 2 |
| 635 | 107 | 203 | 31 | 2 |
| 809 | 111 | 276 | 54 | 2 |
| 947 | 133 | 408 | 156 | 6 |
| 1402 | 221 | 547 | 339 | 13 |
| 3634 | 767 | 729 | 818 | 三十 |
| 5268 | 1766 | 628 | 1201 | 46 |
以下是一個Java程序,它使用JavaFX生成描述上述數據的堆積區域圖。
將此代碼保存在名為StackedAreaChartExample.java的文件中。
import java.util.Arrays; import javafx.application.Application; import static javafx.application.Application.launch; 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.StackedAreaChart; import javafx.scene.chart.XYChart; public class StackedAreaChartExample extends Application { @Override public void start(Stage stage) { //Defining the axes CategoryAxis xAxis = new CategoryAxis(); xAxis.setCategories(FXCollections.<String>observableArrayList( Arrays.asList("1750", "1800", "1850", "1900", "1950", "1999", "2050" ))); NumberAxis yAxis = new NumberAxis(0, 10000, 2500); yAxis.setLabel("Population in Millions"); //Creating the Area chart StackedAreaChart<String, Number> areaChart = new StackedAreaChart(xAxis, yAxis);areaChart.setTitle("Historic and Estimated Worldwide Population Growth by Region");//Prepare XYChart.Series objects by setting data XYChart.Series series1 = new XYChart.Series(); series1.setName("Asia"); series1.getData().add(new XYChart.Data("1750", 502)); series1.getData().add(new XYChart.Data("1800", 635)); series1.getData().add(new XYChart.Data("1850", 809)); series1.getData().add(new XYChart.Data("1900", 947)); series1.getData().add(new XYChart.Data("1950", 1402)); series1.getData().add(new XYChart.Data("1999", 3634)); series1.getData().add(new XYChart.Data("2050", 5268)); XYChart.Series series2 = new XYChart.Series(); series2.setName("Africa"); series2.getData().add(new XYChart.Data("1750", 106)); series2.getData().add(new XYChart.Data("1800", 107)); series2.getData().add(new XYChart.Data("1850", 111)); series2.getData().add(new XYChart.Data("1900", 133)); series2.getData().add(new XYChart.Data("1950", 221)); series2.getData().add(new XYChart.Data("1999", 767)); series2.getData().add(new XYChart.Data("2050", 1766)); XYChart.Series series3 = new XYChart.Series(); series3.setName("Europe"); series3.getData().add(new XYChart.Data("1750", 163)); series3.getData().add(new XYChart.Data("1800", 203)); series3.getData().add(new XYChart.Data("1850", 276)); series3.getData().add(new XYChart.Data("1900", 408)); series3.getData().add(new XYChart.Data("1950", 547)); series3.getData().add(new XYChart.Data("1999", 729)); series3.getData().add(new XYChart.Data("2050", 628)); XYChart.Series series4 = new XYChart.Series(); series4.setName("America"); series4.getData().add(new XYChart.Data("1750", 18)); series4.getData().add(new XYChart.Data("1800", 31)); series4.getData().add(new XYChart.Data("1850", 54)); series4.getData().add(new XYChart.Data("1900", 156)); series4.getData().add(new XYChart.Data("1950", 339)); series4.getData().add(new XYChart.Data("1999", 818)); series4.getData().add(new XYChart.Data("2050", 1201)); XYChart.Series series5 = new XYChart.Series(); series5.setName("Oceania"); series5.getData().add(new XYChart.Data("1750", 2)); series5.getData().add(new XYChart.Data("1800", 2)); series5.getData().add(new XYChart.Data("1850", 2)); series5.getData().add(new XYChart.Data("1900", 6)); series5.getData().add(new XYChart.Data("1950", 13)); series5.getData().add(new XYChart.Data("1999", 30)); series5.getData().add(new XYChart.Data("2050", 46)); //Setting the data to area chart areaChart.getData().addAll(series1, series2, series3, series4, series5); //Creating a Group object Group root = new Group(areaChart); //Creating a scene object Scene scene = new Scene(root, 600, 400); //Setting title to the Stage stage.setTitle("Stacked Area 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 StackedAreaChartExample.java java StackedAreaChartExample在執行時,上述程序生成一個顯示堆積面積圖的JavaFX窗口,如下所示。
?
總結
以上是生活随笔為你收集整理的JavaFX图表(九)之堆积面积图的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 周杰伦电影有哪些 周杰伦电影列述
- 下一篇: 且行且珍惜出自 且行且珍惜出自哪里