codecamp

JavaFX 切换按钮

JavaFX教程 - JavaFX 切换按钮


切换按钮具有两种状态:选择或未选择。

我们通常将两个或多个切换按钮组合成一个组,并允许用户只选择一个按钮或不选择。

创建切换按钮

我们可以使用ToggleButton类的三个构造函数创建一个切换按钮。

要创建没有任何字幕或图标的切换按钮

ToggleButton tb = new ToggleButton();

要创建带有文字说明的切换按钮

ToggleButton tb = new ToggleButton("Press me");

要创建带有文字说明和图标的切换按钮

Image image = new Image(getClass().getResourceAsStream("icon.png"));
ToggleButton tb = new ToggleButton ("Press me", new ImageView(image));

setText方法可以将文本设置为ToggleButton和setGraphic方法可以将图像安装到ToggleButton。


切换按钮组

切换组不强制选择至少一个按钮。单击所选的切换按钮可取消选择切换按钮。

ToggleGroup group = new ToggleGroup();

ToggleButton tb1 = new ToggleButton("High");
tb1.setToggleGroup(group);
tb1.setSelected(true);

ToggleButton tb2 = new ToggleButton("Medium");
tb2.setToggleGroup(group);

ToggleButton tb3 = new ToggleButton("Low");
tb3.setToggleGroup(group);

切换按钮行为

setUserData方法将用户值与切换按钮相关联。

ChangeListener对象检查组中所选的切换。如果没有选择任何开关按钮,则输出默认值。

如果选择其中一个切换按钮,getSelectedToggle和getUserData方法返回用户定义的值。

tb1.setUserData("High");
tb2.setUserData("Medium");
tb3.setUserData("Low");

ToggleGroup group = new ToggleGroup();

group.selectedToggleProperty().addListener            
    (ObservableValue<? extends Toggle> ov, Toggle toggle, Toggle new_toggle) -> {
    if (new_toggle == null)
        System.out.println("default value");
    else
        System.out.println(group.getSelectedToggle().getUserData());
});

样式切换按钮

我们可以将CSS样式应用于切换按钮。

首先,我们在myStyle.css文件中声明切换按钮的样式。

.toggle-button1{
    -fx-font: 30 arial; 
    -fx-base: green;   
}
 
.toggle-button2{
    -fx-font: 25 arial; 
    -fx-base: blue;  
}
 
.toggle-button3{
    -fx-font: 30 arial; 
    -fx-base: red;   
}

其次,我们在应用程序中安装样式。

scene.getStylesheets().add("myStyle.css");

tb1.getStyleClass().add("toggle-button1");
tb2.getStyleClass().add("toggle-button2");
tb3.getStyleClass().add("toggle-button3");
JavaFX 单选按钮
JavaFX 复选框
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

JavaFX 效果

JavaFX 主题

JavaFX 转换

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }