如何使用按钮更改矩形

时间:2013-07-13 19:13:35

标签: java javafx-2 javafx javafx-8

我正在研究这个无法正常工作的例子:

public class test extends Application
{

    private void init(Stage primaryStage)
    {

        Group root = new Group();
        primaryStage.setScene(new Scene(root));

        String pillButtonCss = DX57DC.class.getResource("PillButton.css").toExternalForm();

        // create 3 toggle buttons and a toogle group for them
        ToggleButton tb1 = new ToggleButton("Left Button");
        tb1.setId("pill-left");
        ToggleButton tb2 = new ToggleButton("Center Button");
        tb2.setId("pill-center");
        ToggleButton tb3 = new ToggleButton("Right Button");
        tb3.setId("pill-right");

        final ToggleGroup group = new ToggleGroup();
        tb1.setToggleGroup(group);
        tb2.setToggleGroup(group);
        tb3.setToggleGroup(group);
        // select the first button to start with
        group.selectToggle(tb1);

        //////////////////////////////////////////

        final VBox vbox = new VBox();

        final Rectangle rect1 = new Rectangle(300, 300);
        rect1.setFill(Color.ALICEBLUE);
        final Rectangle rect2 = new Rectangle(300, 300);
        rect2.setFill(Color.AQUA);
        final Rectangle rect3 = new Rectangle(300, 300);
        rect3.setFill(Color.AZURE);

        tb1.setUserData(rect1);
        tb2.setUserData(rect2);
        tb3.setUserData(rect3);

        group.selectedToggleProperty().addListener(new ChangeListener<Toggle>()
        {
            @Override
            public void changed(ObservableValue<? extends Toggle> ov, Toggle toggle, Toggle new_toggle)
            {
                if (new_toggle == null)
                {
                    //rect.setFill(Color.WHITE);
                }
                else
                {
                    vbox.getChildren().addAll((Node[]) group.getSelectedToggle().getUserData());
                    //rect.setFill((Color) group.getSelectedToggle().getUserData());
                }
            }
        });


        ///////////////////////////////////////////


        HBox hBox = new HBox();
        hBox.getChildren().addAll(tb1, tb2, tb3);
        hBox.setPadding(new Insets(20, 20, 260, 20));
        hBox.getStylesheets().add(pillButtonCss);



        vbox.getChildren().add(hBox);
        //vbox.getChildren().add(rect);

        root.getChildren().add(vbox);
    }

    @Override
    public void start(Stage primaryStage) throws Exception
    {
        init(primaryStage);
        primaryStage.show();
    }

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

我想创建几个我想要存储数据的Rectangle(或其中的对象或对象)。我想使用按钮切换显示在用户面前的矩形(对象)。我实施的示例无法正常工作。你能告诉我实现这个的正确方法是什么吗?

1 个答案:

答案 0 :(得分:1)

你可以创建一个带有矩形的Stackpane和一个带有Text的Label(如果那就是你要存储的数据)。或者,您也可以将任何窗格的背景设置为具有彩色矩形。

将此窗格作为Userdata添加到相应的按钮,并在切换时将按钮userdata添加到VBox。

final StackPane rect1pane = new StackPane();
final Rectangle rect1 = new Rectangle(300, 300);
rect1pane.getChildren().add(rect1);
rect1pane.getChildren().add(new Label("Some text"));
tb1.setUserData(rect1pane);

togglePropertyListener:

...
else{
//Delete rectangles added before ( or check if this one isnt already dispayed)
if(group.getSelectedToggle().getUserData() instanceof Node)
     vbox.getChildren().add((Node)group.getSelectedToggle().getUserData());
}

如果您只想让您的示例代码发生变化:

vbox.getChildren().addAll((Node[]) group.getSelectedToggle().getUserData());

vbox.getChildren().addAll((Node) group.getSelectedToggle().getUserData());

因为你刚刚添加了Selected ToggleButton的Rectangle,它只是一个而不是一个数组。

点击一下后看你的窗口变大了(260px底部填充没有帮助,因为即使空间在hbox下面是空的,它仍然是hbox的一部分,不能被你添加的矩形使用)或者只需移动

 group.selectToggle(tb1);

到init方法的最后一行;)