Java調用JavaFX的方法。這三種方法分別為:
1. 用ScriptEngineManager類。這是基於JSR-223規范的java腳本API( scripting API)。可以在java程序中運行一些腳本,如 JavaFX script, javascript等。
2. 通過JavaFX reflection API。這是JavaFX提供的反射API,幾乎可以調用所有的JavaFX類。
3. 先用JavaFX類實現一個Java的interface,然后Java程序可以通過這個interface來調用JavaFX的功能。這中間的interface起了個橋梁的作用。
第三種方法應該是比較“正規”而且“優美”的調用方式。但是也有一點不足:程序代碼的入口必須從JavaFX啟動。
這是因為JavaFX程序比較容易生成JavaFX類的實例,從而可以供Java方使用。可是我們有時會碰到一些特定的情況,需要從Java端啟動代碼。例如,如果你已經有了一個較完整的Java程序,你需要用調用JavaFX的某些功能,這時候較好的方法是把Java作為程序的入口。為了解決這個問題,我把第2和第3種方法作了融合,大家可以看看下面的例子。
假定我們需要從Java中調用JavaFX的圖表(charting)功能。我們首先用JavaFX reflection API生成JavaFX類的實例。然后我們再通過java的interface來使用它。因此,我們先定義一個Java的interface:
/*
* JavaInterface.java
*
* @author Henry Zhang http://www.javafxblogs.com
*/
package javatest;
public interface JavaInterface {
public void addData(String name, float data);
public void showChart();
}
下一步是創建JavaFX類MyChart來實現這個interface:
/*
* MyChart.fx
*
* @author Henry Zhang http://www.javafxblogs.com
*/
package javatest;
import javafx.scene.chart.PieChart;
import javafx.scene.Scene;
import javafx.scene.text.Font;
import javafx.scene.text.Text;
import javafx.stage.Stage;
import javafx.scene.chart.PieChart3D;
public class MyChart extends JavaInterface {
var chartData : PieChart.Data[] = [];
public override function addData( l:String, v: Number):Void {
var labelString = l;
var data = PieChart.Data {
label : l
value : v
action: function() {
println("{labelString} clicked!");
}
} ;
insert data into chartData;
}
public override function showChart() : Void {
var chart =
PieChart3D {
data : chartData
pieThickness: 25
pieLabelFont: Font{ size: 9 };
pieToLabelLineOneLength: 10
pieToLabelLineTwoLength : 20
pieLabelVisible: true
pieValueVisible: true
translateY: -50
};
Stage {
title: "PieChart Window"
width: 520
height: 300
scene: Scene {
content: [
Text {
font : Font {
size : 16
}
x: 200
y: 20
content: "Pie Chart"
},
chart
]
}
}
}
}
最后就是從java類JavaTest中調用圖表功能:
/*
* JavaTest.java
* @author Henry Zhang http://www.javafxblogs.com
*/
package javatest;
import javafx.reflect.FXClassType;
import javafx.reflect.FXLocal;
import javafx.reflect.FXLocal.Context;
import javafx.reflect.FXLocal.ObjectValue;
public class JavaTest {
public static void main(String args[]) {
Context context = FXLocal.getContext();
FXClassType instance = context.findClass("javatest.MyChart");
ObjectValue obj = (ObjectValue)instance.newInstance();
JavaInterface ji = (JavaInterface)obj.asObject();
String [] labels = {"January", "Febuary", "March", "April"};
int [] values = { 18, 20, 25, 37 };
for ( int i=0; i < values.length; i++ ) {
ji.addData(labels[i], values[i]);
}
ji.showChart();
}
}
在代碼中,這3句是創建JavaFX類javatest.MyChart實例,
Context context = FXLocal.getContext();
FXClassType instance = context.findClass("javatest.MyChart");
ObjectValue obj = (ObjectValue)instance.newInstance();
而一下這句則是把JavaFX實例轉化為Java可用的對象:
JavaInterface ji = (JavaInterface)obj.asObject();
如果你用的是NetBeans IDE, 你可以在項目屬性中把javatest.JavaTest類設為主類(Main class)(即啟動類)。編譯之后會生成一個javatest.jar文件。程序運行的結果如圖:
在命令行中可以采用以下方式:
javafx -jar javatest.jar
實際上,可以用純Java的方式來啟動程序,只要把JavaFX的運行環境帶上即可,如:
java -Djava.library.path="<path to javafx sdk lib>"
-classpath "<all javafx sdk jars>" -jar javatest.jar
因為JavaFX需要的jar文件很多,因此這種“最純”的java方法使用起來比較麻煩。我覺得還是用javafx命令簡潔些, 而且javafx就是上述java命令的封裝而已。
(以上內容摘自:http://www.th7.cn/Program/java/201510/616465.shtml)

