javafx css样式_使用CSS设置JavaFX饼图样式
javafx css樣式
渲染圖表時(shí), JavaFX默認(rèn)提供某些顏色。 但是,在某些情況下,您想自定義這些顏色。 在此博客文章中,我將使用一個(gè)示例來更改JavaFX餅圖的顏色,該示例打算在今天下午在2013年RMOUG培訓(xùn)日的演示中包括。一些基于Java的圖表API提供了Java方法來設(shè)置顏色。 JavaFX誕生于HTML5流行的年代,而是使用級聯(lián)樣式表 (CSS)來允許開發(fā)人員調(diào)整其圖表中使用的顏色,符號,位置,對齊方式和其他樣式問題。 我在這里演示了如何使用CSS更改顏色。
在本文中,我將看兩個(gè)代碼示例,這些示例演示了簡單的JavaFX應(yīng)用程序,這些應(yīng)用程序基于Oracle示例“ hr”模式中的數(shù)據(jù)來呈現(xiàn)餅圖。 首先
該示例未指定顏色,因此將JavaFX的默認(rèn)顏色用于餅圖和圖例背景。 那 接下來顯示示例。
EmployeesPerDepartmentPieChart(默認(rèn)JavaFX樣式)
package rmoug.td2013.dustin.examples;import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.chart.PieChart; import javafx.scene.layout.StackPane; import javafx.stage.Stage;/*** Simple JavaFX application that generates a JavaFX-based Pie Chart representing* the number of employees per department.* * @author Dustin*/ public class EmployeesPerDepartmentPieChart extends Application {final DbAccess databaseAccess = DbAccess.newInstance();@Overridepublic void start(final Stage stage) throws Exception{final PieChart pieChart =new PieChart(ChartMaker.createPieChartDataForNumberEmployeesPerDepartment(this.databaseAccess.getNumberOfEmployeesPerDepartmentName()));pieChart.setTitle('Number of Employees per Department');stage.setTitle('Employees Per Department');final StackPane root = new StackPane();root.getChildren().add(pieChart);final Scene scene = new Scene(root, 800 ,500);stage.setScene(scene);stage.show();}public static void main(final String[] arguments){launch(arguments);} }執(zhí)行上述簡單應(yīng)用程序后,將顯示下一個(gè)屏幕快照中顯示的輸出。
我現(xiàn)在將改編上面的示例,以使用自定義的藍(lán)色主題派切片“主題”,圖例上帶有棕色背景。 Java代碼僅需要一行就可以包含具有圖表樣式詳細(xì)信息CSS文件。 在這種情況下,我添加了幾行以捕獲并打印出嘗試加載CSS文件時(shí)可能發(fā)生的任何異常。 使用這種方法,加載CSS文件時(shí)遇到的任何問題都將僅導(dǎo)致說明問題的標(biāo)準(zhǔn)錯(cuò)誤輸出,并且應(yīng)用程序?qū)⒁云湔5哪J(rèn)顏色運(yùn)行。
EmployeesPerDepartmentPieChartWithCssStyling(自定義CSS樣式)
package rmoug.td2013.dustin.examples;import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.chart.PieChart; import javafx.scene.layout.StackPane; import javafx.stage.Stage;/*** Simple JavaFX application that generates a JavaFX-based Pie Chart representing* the number of employees per department and using style based on that provided* in CSS stylesheet chart.css.* * @author Dustin*/ public class EmployeesPerDepartmentPieChartWithCssStyling extends Application {final DbAccess databaseAccess = DbAccess.newInstance();@Overridepublic void start(final Stage stage) throws Exception{final PieChart pieChart =new PieChart(ChartMaker.createPieChartDataForNumberEmployeesPerDepartment(this.databaseAccess.getNumberOfEmployeesPerDepartmentName()));pieChart.setTitle('Number of Employees per Department');stage.setTitle('Employees Per Department');final StackPane root = new StackPane();root.getChildren().add(pieChart);final Scene scene = new Scene(root, 800 ,500);try{scene.getStylesheets().add('chart.css');}catch (Exception ex){System.err.println('Cannot acquire stylesheet: ' + ex.toString());}stage.setScene(scene);stage.show();}public static void main(final String[] arguments){launch(arguments);} }接下來顯示的是chart.css文件:
chart.css
/*Find more details on JavaFX supported named colors athttp://docs.oracle.com/javafx/2/api/javafx/scene/doc-files/cssref.html#typecolor *//* Colors of JavaFX pie chart slices. */ .data0.chart-pie { -fx-pie-color: turquoise; } .data1.chart-pie { -fx-pie-color: aquamarine; } .data2.chart-pie { -fx-pie-color: cornflowerblue; } .data3.chart-pie { -fx-pie-color: blue; } .data4.chart-pie { -fx-pie-color: cadetblue; } .data5.chart-pie { -fx-pie-color: navy; } .data6.chart-pie { -fx-pie-color: deepskyblue; } .data7.chart-pie { -fx-pie-color: cyan; } .data8.chart-pie { -fx-pie-color: steelblue; } .data9.chart-pie { -fx-pie-color: teal; } .data10.chart-pie { -fx-pie-color: royalblue; } .data11.chart-pie { -fx-pie-color: dodgerblue; }/* Pie Chart legend background color and stroke. */ .chart-legend { -fx-background-color: sienna; }運(yùn)行此CSS樣式的示例將導(dǎo)致輸出,如下一個(gè)屏幕快照所示。 切片為不同的藍(lán)色陰影,圖例的背景為“ si色”。 請注意,例如,當(dāng)我使用JavaFX“命名顏色”時(shí),也可以對藍(lán)色使用“#0000ff”。
我的便利類ChartMaker和DbAccess沒有在此處顯示代碼。 后者只是通過JDBC從Oracle數(shù)據(jù)庫模式中檢索圖表的數(shù)據(jù),而前者則將該數(shù)據(jù)轉(zhuǎn)換為適合PieChart(ObservableList)構(gòu)造函數(shù)的Observable集合。
這里需要注意的是,正如Andres Almiray所指出的那樣 ,通常不適合像我在本博客和其他博客文章中所做的那樣,從JavaFX UI主線程(又名JavaFX Application Thread)執(zhí)行長時(shí)間運(yùn)行的進(jìn)程。例子。 我可以在這些文章中忽略它,因?yàn)槭纠芎唵?#xff0c;數(shù)據(jù)庫檢索很快,并且圖表呈現(xiàn)應(yīng)用程序沒有比該呈現(xiàn)更多的內(nèi)容,因此很難觀察到任何“懸掛”。 在以后的博客文章中,我打算探討使用JavaFX javafx.concurrent包( 在JavaFX的Concurrency中已經(jīng)對此進(jìn)行了很好的描述)來處理數(shù)據(jù)庫訪問(或任何長時(shí)間運(yùn)行的操作)的更好方法。
JavaFX允許開發(fā)人員控制更多,而不僅僅是使用CSS繪制圖表顏色。 兩個(gè)非常有用的資源詳細(xì)介紹了如何使用CSS樣式化JavaFX圖表,這是“ 使用JavaFX圖表”部分的“ 用CSS樣式化圖表”和“ JavaFX CSS參考指南” 。 CSS作為一種樣式化Web和移動(dòng)應(yīng)用程序的方法正變得越來越流行。 通過在JavaFX中支持CSS樣式,可以輕松地將與它們共存的基于HTML的應(yīng)用程序相同的樣式應(yīng)用于JavaFX應(yīng)用程序。
參考:我們的JCG合作伙伴 Dustin Marx在Inspired by Actual Events博客上使用CSS設(shè)置JavaFX餅圖樣式 。
翻譯自: https://www.javacodegeeks.com/2013/02/styling-javafx-pie-chart-with-css.html
javafx css樣式
總結(jié)
以上是生活随笔為你收集整理的javafx css样式_使用CSS设置JavaFX饼图样式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何在家利用空闲时间赚钱如何在家用电脑赚
- 下一篇: 即将举行的网络研讨会:调试生产中Java