1

我有 3 个 ToggleButtons 和一个包含 3 个单元格的 GridPane。

案例 1: 只选择了 1 个 ToggleButton,对应的 GridPane 单元格预计会填满整个窗格。

情况 2: 选择了 2 个 ToggleButtons,相应的 2 个 GridPane 单元格预计将均匀地填充整个窗格。(当然选择3个toggleButtons时,相同的逻辑。)

目前,我已经通过以下实现实现了我的目标,但我想学习的是让它更智能。用这个词smarter,我的意思是实现一些更短的东西,将 ToggleButton 状态转换为双精度值(取消选择 => 0 ,选择=> 100)。我不想通过重复 if 子句来实现这些,但我正在尝试实现可以​​在.bind()方法调用之前附加的东西。

一个 ToggleButton 的当前实现如下:

myToggleButton.selectedProperty().addListener(new ChangeListener<Boolean>() {
        @Override
        public void changed(ObservableValue<? extends Boolean> observable, Boolean oldValue, Boolean newValue) {
            if(newValue){
                myGridPane.getColumnConstraints().get(0).setPercentWidth(100);
            }else{
                myGridPane.getColumnConstraints().get(0).setPercentWidth(0);
            }
        }
    });
4

1 回答 1

1

是的,你可以,尝试以下绑定PercentWidth

ObservableBooleanValue condition = myToggleButton.selectedProperty();
NumberBinding number = Bindings.when(condition).then(100).otherwise(0);
myGridPane.getColumnConstraints().get(0).percentWidthProperty.bind(number);
于 2015-04-17T07:03:32.493 回答