如何在不使用FXML的情况下创建自定义复合控件?

时间:2019-04-30 19:38:04

标签: java javafx fxml

我想创建代表复合控件的类。这将是HBox,其中包含其他控件,例如TextFields等。

我知道可以像在tutorial中那样使用FXML来完成此操作,但是我想在没有它的情况下做到这一点。

这是我解决此问题的方法:

复合控件的类

public class VInputText extends HBox {

    private HBox hbox;
    private FontAwesomeIconView icon;
    private TextField textField;
    private Label label;

    public VInputText(double spacing) {

        hbox = new HBox(spacing);
        hbox.setAlignment(Pos.CENTER_LEFT);
        hbox.setPrefSize(Control.USE_COMPUTED_SIZE, Control.USE_COMPUTED_SIZE);

        icon = new FontAwesomeIconView();
        icon.setGlyphName("TIMES");
        icon.setSize("1.3em");

        textField = new TextField();

        label = new Label("<- my validated field");

        hbox.getChildren().addAll(icon, textField, label);
    }
}

FXML

<AnchorPane prefHeight="300.0" prefWidth="400.0" xmlns="http://javafx.com/javafx/8.0.171" xmlns:fx="http://javafx.com/fxml/1" fx:controller="pl.edu.utp.wtie.controllers.AppController">
   <children>
      <VBox fx:id="vBox" prefHeight="300.0" prefWidth="400.0" spacing="5.0" />
   </children>
</AnchorPane>

控制器

public class AppController {

    @FXML
    private VBox vBox;

    @FXML
    void initialize() {
        System.out.println("AppController.java");

        VInputText input = new VInputText(5);

        vBox.getChildren().add(input);

    }
}

问题在于应用正在编译,但复合控件未在场景中显示。如果需要其余代码,则可以将其粘贴。预先感谢。

1 个答案:

答案 0 :(得分:0)

我正在粘贴某人解决的解决方案,但答案已删除。与其创建 HBox ,不如使用 this 关键字:

public class VInputText extends HBox {

    private FontAwesomeIconView icon;
    private TextField textField;
    private Label label;

    public VInputText(double spacing) {

        this.setSpacing(spacing);
        this.setAlignment(Pos.CENTER_LEFT);
        this.setPrefSize(Control.USE_COMPUTED_SIZE, Control.USE_COMPUTED_SIZE);

        icon = new FontAwesomeIconView();
        icon.setGlyphName("TIMES");
        icon.setSize("1.3em");

        textField = new TextField();

        label = new Label("<- my validated field");

        this.getChildren().addAll(icon, textField, label);
    }
}