在JavaFX Text节点周围绘制边框

时间:2013-12-15 19:30:39

标签: javafx-2

我想在我的JavaFX场景图中的任意javafx.scene.text.Text节点周围绘制红色边框,例如Button对象中的那些节点。

很容易检索所有Text节点,但没有找到它们在场景中的位置,它们有x和y属性,似乎没有正确设置,但它们没有宽度和高度。 / p>

到目前为止,我已尝试将红色笔划的矩形添加到堆栈窗格,但x和y总是错误的,我无法获得大小。

1 个答案:

答案 0 :(得分:6)

一种解决方案是将文本节点包装在布局窗格(例如HBox)中,并在布局窗格上使用CSS:

import javafx.application.Application;
import javafx.scene.Node;
import javafx.scene.Scene;
import javafx.scene.layout.HBox;
import javafx.scene.text.Text;
import javafx.stage.Stage;

public class TextBorderExample extends Application {

    @Override
    public void start(Stage primaryStage) {
        final HBox root = new HBox(5);

        root.getChildren().addAll(
                new Text("This"), new Text("Is"), new Text("A"), createBorderedText("Red"), new Text("Bordered"), new Text("Text")
        );

        primaryStage.setScene(new Scene(root));
        primaryStage.show();
    }
    private Node createBorderedText(String text) {
        final HBox hbox = new HBox();
        hbox.getChildren().add(new Text(text));
        hbox.setStyle("-fx-border-color: red;");
        return hbox ;
    }

    public static void main(String[] args) {
        launch(args);
    }
}

另一种方法是使用Rectangle,如下所示:

import javafx.application.Application;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.geometry.Bounds;
import javafx.scene.Scene;
import javafx.scene.layout.HBox;
import javafx.scene.paint.Color;
import javafx.scene.shape.Rectangle;
import javafx.scene.text.Text;
import javafx.stage.Stage;

public class TextBorderExample extends Application {

    @Override
    public void start(Stage primaryStage) {
        final HBox root = new HBox(5);
        final Text red = new Text("Red");
        final Rectangle redBorder = new Rectangle(0, 0, Color.TRANSPARENT);
        redBorder.setStroke(Color.RED);
        redBorder.setManaged(false);
        red.boundsInParentProperty().addListener(new ChangeListener<Bounds>() {

            @Override
            public void changed(ObservableValue<? extends Bounds> observable,
                    Bounds oldValue, Bounds newValue) {
                redBorder.setLayoutX(red.getBoundsInParent().getMinX());
                redBorder.setLayoutY(red.getBoundsInParent().getMinY());
                redBorder.setWidth(red.getBoundsInParent().getWidth());
                redBorder.setHeight(red.getBoundsInParent().getHeight());
            }

        });
        root.getChildren().addAll(new Text("This"), new Text("Is"), new Text("A"), red, new Text("Bordered"), new Text("Text"));
        root.getChildren().add(redBorder);


        primaryStage.setScene(new Scene(root));
        primaryStage.show();
    }

    public static void main(String[] args) {
        launch(args);
    }
}