本章介绍单选按钮控件,单选按钮是ToggleButton的特殊实现。一个单选按钮可以被选择也可以不被选择。一般情况单选按钮放在一个组里使用,并且此组中的单选按钮在某一时刻只能存在一个被选中。下面的图片展示了3个单选按钮:
创建单选按钮
使用下面代码创建单选按钮
//A radio button with an empty string for its label
RadioButton rb1 = new RadioButton();
//Setting a text label
rb1.setText("Home");
//A radio button with the specified label
RadioButton rb2 = new RadioButton("Calendar");
我们可以通过setSelected方法来设置选中某个单选按钮。
因为RadioButton也是扩展子Labeled,所以我们也可以为他添加图片内容如下:
Image image = new Image(getClass().getResourceAsStream("ok.jpg"));
RadioButton rb = new RadioButton("Agree");
rb.setGraphic(new ImageView(image));
添加单选按钮到组
代码如下:
final ToggleGroup group = new ToggleGroup();
RadioButton rb1 = new RadioButton("Home");
rb1.setToggleGroup(group);
rb1.setSelected(true);
RadioButton rb2 = new RadioButton("Calendar");
rb2.setToggleGroup(group);
RadioButton rb3 = new RadioButton("Contacts");
rb3.setToggleGroup(group);
运行代码,显示如下:
处理事件:
代码如下:
ImageView image = new ImageView();
rb1.setUserData("Home")
rb2.setUserData("Calendar");
rb3.setUserData("Contacts");
final ToggleGroup group = new ToggleGroup();
group.selectedToggleProperty().addListener(
(ObservableValue<? extends Toggle> ov, Toggle old_toggle,
Toggle new_toggle) -> {
if (group.getSelectedToggle() != null) {
final Image image = new Image(
getClass().getResourceAsStream(
group.getSelectedToggle().getUserData().toString() +
".jpg"));
icon.setImage(image);
}
});
现在我们就可以,通过选择不同的单选按钮来展示不同的图片。
获取单选按钮的焦点
单选按钮的焦点默认是在第一个单选按钮上的,如果你使用setSelected方法设置第二个单选按钮选中的话。那么焦点依旧在第一个按钮上,如下图所示:
我们通过下面的方法,来获得焦点:
rb2.setSelected(true);
rb2.requestFocus();
注意:经过的实验的结果是。就算使用requestFocus方法之后,焦点还是在第一个按钮上。不明白为什么,如果谁知道,请赐教。