javafx - fxml:如何处理控制器中的按钮动作?
问题描述
我有一个最小的例子:控制器,主,fxml 文件,带有一个按钮和两个 textArea(s),一个输入,另一个输出。按下按钮时,输入将打印在输出中。当我在 fxml (onAction="#printOutput") 中插入按钮的操作时,它工作正常。我想知道如何(以及为什么不)我可以在控制器中执行相同的操作而无需处理 fxml。注意:我来自 Android,我避免在 xml 中实现相同的功能,因为调试非常困难,而且它不提供灵活性。文件如下:
控制器
public class FxFXMLController {
@FXML private TextField inputText;
@FXML private TextArea outputText;
@FXML private Button okBtn;
//Do I connect here an okBtn.setAction() with printOutput? if not, where?
public FxFXMLController() {
// Nothing
}
@FXML
private void printOutput() {
// insert this into outputText in fxml file: onAction="#printOutput"
outputText.setText(inputText.getText());
}
}
主要的
public class FxFXMLExample3 extends Application {
public static void main(String[] args) {
Application.launch(args);
}
@Override
public void start(Stage stage) throws IOException {
FXMLLoader loader = new FXMLLoader();
VBox root = (VBox) loader.load((getClass().getResource("FxFXMLExample3.fxml")));
Scene scene = new Scene(root);
stage.setScene(scene);
stage.setTitle("A FXML Example with a Controller");
stage.show();
}
}
FXML
<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.*?>
<?import javafx.scene.layout.*?>
<VBox fx:id="vbox" layoutX="10.0" layoutY="10.0" prefHeight="250.0" prefWidth="300.0" spacing="10" xmlns="http://javafx.com/javafx/10.0.2-internal" xmlns:fx="http://javafx.com/fxml/1" fx:controller="sample.FxFXMLController">
<style>
-fx-padding: 10;
-fx-border-style: solid inside;
-fx-border-width: 2;
-fx-border-insets: 5;
-fx-border-radius: 5;
-fx-border-color: blue;
</style>
<Label fx:id="inputLbl" alignment="CENTER_LEFT" cache="true" cacheHint="SCALE" prefHeight="30.0" prefWidth="200.0" text="Please insert Your Input here:" textAlignment="LEFT" />
<TextField fx:id="inputText" prefWidth="100.0" />
<Button fx:id="okBtn" alignment="CENTER_RIGHT" contentDisplay="CENTER" mnemonicParsing="false" text="OK" textAlignment="CENTER" />
<Label fx:id="outputLbl" alignment="CENTER_LEFT" cache="true" cacheHint="SCALE" prefHeight="30.0" prefWidth="200.0" text="Your Input:" textAlignment="LEFT" />
<TextArea fx:id="outputText" prefHeight="100.0" prefWidth="200.0" wrapText="true" />
</VBox>
解决方案
您可以使用初始化函数在您的按钮上注册一个新的事件侦听器,然后您可以在该侦听器中执行您想要的任何操作。这是代码:
public class FxFXMLController {
@FXML private TextField inputText;
@FXML private TextArea outputText;
@FXML private Button okBtn;
@FXML
public void initialize() {
okBtn.setOnAction(event -> {
this.printOutput();
});
}
public FxFXMLController() {
// Nothing
}
@FXML
private void printOutput() {
// insert this into outputText in fxml file: onAction="#printOutput"
outputText.setText(inputText.getText());
}
}
推荐阅读
- angular - ngModel 为不同的字段显示相同的值
- sql - 从某个组中获取最后一个值(Oracle)
- reactjs - Native Base 两个头文件
- php - 动态 PHP 表过滤和排序
- extjs - 将值从一个视图发送到另一个 ExtJS 4
- javascript - 单击 SVG 后如何与另一个 SVG 交互
- php - wp_kses 清理正在删除有效的字体系列名称
- javascript - Firefox 桌面浏览器的画布中断,Chrome 桌面只有在加载 cookie 时才能正常工作
- c# - 如何正确递归此对象列表?
- c# - 在 C# 中完成程序后,在类析构函数中关闭 SqlConnection 是否安全?