使用诸如 JavaScript 之类的脚本语言是从服务器加载带有一些相关控制逻辑的 fxml 页面的一种方法,这样就不需要在客户端机器上进行编译——它与已建立的 html+JavaScript 模型非常相似。
您可以试用WebFX作为这种方法的示例。
节拍器.fxml
<?xml version="1.0" encoding="UTF-8"?>
<?language javascript?>
<?import java.lang.*?>
<?import java.util.*?>
<?import javafx.scene.*?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.shape.*?>
<AnchorPane id="AnchorPane" prefHeight="370.0" prefWidth="320.0" xmlns:fx="http://javafx.com/fxml">
<children>
<HBox id="HBox" alignment="CENTER" layoutX="36.0" layoutY="328.0" spacing="5.0">
<children>
<Button fx:id="startButton" mnemonicParsing="false" onAction="handleStartButtonAction(event);" text="%start" />
<Button fx:id="pauseButton" mnemonicParsing="false" onAction="handlePauseButtonAction(event);" text="%pause" />
<Button fx:id="resumeButton" mnemonicParsing="false" onAction="handleResumeButtonAction(event);" text="%resume" />
<Button fx:id="stopButton" mnemonicParsing="false" onAction="handleStopButtonAction(event);" text="%stop" />
</children>
</HBox>
<Circle fx:id="circle" fill="RED" layoutX="64.0" layoutY="58.0" radius="7.0" stroke="BLACK" strokeType="INSIDE" strokeWidth="0.0" />
</children>
<fx:script source="metronome.js" />
</AnchorPane>
节拍器.js
var webfx = {title: "Metronome WebFX Sample"};
var java = Packages.java;
var javafx = Packages.javafx;
var URL = java.net.URL;
var ResourceBundle = java.util.ResourceBundle;
var Animation = javafx.animation.Animation;
var Interpolator = javafx.animation.Interpolator;
var Timeline = javafx.animation.Timeline;
var TranslateTransitionBuilder = javafx.animation.TranslateTransitionBuilder;
var Duration = javafx.util.Duration;
var anim = TranslateTransitionBuilder.create()
.duration(new Duration(1000.0))
.node(circle)
.fromX(0)
.toX(200)
.interpolator(Interpolator.LINEAR)
.autoReverse(true)
.cycleCount(Timeline.INDEFINITE)
.build();
function handleStartButtonAction() { anim.playFromStart(); }
function handlePauseButtonAction() { anim.pause(); }
function handleResumeButtonAction() { anim.play(); }
function handleStopButtonAction() { anim.stop(); }
startButton.disableProperty().bind(anim.statusProperty().isNotEqualTo(Animation.Status.STOPPED));
pauseButton.disableProperty().bind(anim.statusProperty().isNotEqualTo(Animation.Status.RUNNING));
resumeButton.disableProperty().bind(anim.statusProperty().isNotEqualTo(Animation.Status.PAUSED));
stopButton.disableProperty().bind(anim.statusProperty().isEqualTo(Animation.Status.STOPPED));
如果您想使用 Java 等静态语言而不是 JavaScript 之类的脚本语言作为控制器,则需要找到在客户端上获取已编译类文件的方法。例如,通过在服务器上编译并拥有一个可以从服务器加载它的类加载器,或者通过在客户端应用程序中提供 java 编译器并在那里编译源代码。