(翻译)第十二回 JavaFX2.0 复选框CheckBox

简介:   原文地址http://download.oracle.com/javafx/2.0/ui_controls/checkbox.htm   CheckBox类让你可以在应用中创建复选框。

 

原文地址http://download.oracle.com/javafx/2.0/ui_controls/checkbox.htm

 

CheckBox类让你可以在应用中创建复选框。尽管复选框看起来很想单选框 ,但是它们并不能被放置进一个开关组中来实现很多选项的选择。你可以复习一下前面关于Radio Button 和Toggle Button相关的内容。

Figure 6-1  是有三个复选框的一个应用,这些复选框用来控制工具栏中的图标是否显示。

Figure 6-1 Checkbox Sample

Checkbox sample
Description of "Figure 6-1 Checkbox Sample"

 

创建Checkbox

Example 6-1   creates two simple checkboxes.

//Example 6-1 Creating Checkboxes

//A checkbox without a caption 
CheckBox cb1 = new CheckBox(); 
//A checkbox with a string caption 
CheckBox cb2 = new CheckBox("Second"); 
cb1.setText("First"); 
cb1.setSelected(true); 

 

创建复选框后,就可以使用JavaFX API中的方法对它们进行设置。在Example 6-1 setText方法为 c1这个复选框定义了标题,设置setSelected方法为 true以使程序运行后 cb1是选中的。

定义状态

复选框能被定义为明确或不明确。被定义为明确后就可以被选中或取消选中,但是不明确的话就不能被选中或取消选中。结合使用CheckBox类的 setSelected  setIndeterminate方法来为复选框指定状态。 Table 6-1 是三个不同状态的复选框,它们的 INDETERMINATE  SELECTED属性不相同。

Table 6-1 States of a Checkbox

INDETERMINATE   = false

SELECTED   = false

The checkbox is deselected.

INDETERMINATE   =false

SELECTED   = true

The checkbox is selected.

INDETERMINATE   = true

SELECTED   = true/false

The checkbox is undefined.

当复选框要呈现多种状态的UI元素时要为它们指定三种状态,如"Yes", "No", "Not Applicable"。CheckBox 类的 allowIndeterminatePropety设置了复选框对象是否能在全部三种状态(选中、取消选中、不明确)中循环 。如果设置 ,这个控件就可以在三种状态中循环。否则 ,这控件只能在选中和取消选中两种状态中切换。下一部分的应用中构造了三个复选框,并且只有两个状态。

 

 

设置行为

Example 6-2 中的代码块创建了三个复选框,这样当一个复选框被选中后,相应的图标就显示出来。

//Example 6-2 Setting the Behavior for the Checkboxes

final String[] names = new String[]{"Security", "Project", "Chart"}; 
final Image[] images = new Image[names.length];
final ImageView[] icons = new ImageView[names.length];
final CheckBox[] cbs = new CheckBox[names.length]; 
for (int i = 0; i < names.length; i++) 
{ final Image image = images[i] = 
new Image(getClass().getResourceAsStream(names[i] + ".png")); 
final ImageView icon = icons[i] = new ImageView();
final CheckBox cb = cbs[i] = new CheckBox(names[i]); 
cb.selectedProperty().addListener
(new ChangeListener<Boolean>() {
 public void changed(ObservableValue<? extends Boolean> ov, Boolean old_val, Boolean new_val) 
{ icon.setImage(new_val ? image : null);
 } });
 } 

 

names这个数组使用了一个 for循环来创建复选框和相应的图标。比如说, cbs[0]是第一个复选框,被分配了"Security"这个标题;同时image[0]接收了"Security.png"作为getResourceStream方法的文件名。如果一个特定的复选框被选中后,相应的图片就被分配成它的图标。如果一个复选框被取消选中,图标接收 null图片所以没有图标分配。

Figure 6-2  是应用中的 Security 和Chart 复选框被选中,Project 取消选中。

Figure 6-2 Checkbox Application in Action

Two checkboxes are selected
Description of "Figure 6-2 Checkbox Application in Action"

 

 

美化Checkbox

Figure 6-2  中的复选框有CheckBox 默认的外观和感觉。可以通过使用 setStyle  方法来改变它的样子,见 Example 6-3 .

//Example 6-3 Styling a Checkbox

cb1.setStyle( "-fx-border-color: lightblue; "
 + "-fx-font-size: 20;"
 + "-fx-border-insets: -5; "
 + "-fx-border-radius: 5;"
 + "-fx-border-style: dotted;"
 + "-fx-border-width: 2;" ); 

 

新风格包括了一条浅蓝色点边框和一个扩大字体的标题。Figure 6-3  是使用了这种风格的 cb1复选框。

Figure 6-3 Styled Checkbox

Description of Figure 6-3 follows
Description of "Figure 6-3 Styled Checkbox"

要为应用中的所有复选框设置特定的风格,按照下面的步骤:

  • 创建一个 .css文件;

  • 在 .css文件中创建checkbox CSS 类。

  • checkbox   CSS 类中定义所有需要的风格。

  • 在你的JavaFX应用中,使用setStyleClass  方法来使用CSS文件。

 

 

 

 

 

目录
相关文章
|
16天前
|
移动开发 JavaScript 小程序
uView Checkbox 复选框
uView Checkbox 复选框
20 0
|
4月前
|
C++
C++ Qt开发:CheckBox多选框组件
Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍`CheckBox`单行输入框组件的常用方法及灵活运用。`QCheckBox` 是 Qt 中用于实现复选框的组件,它提供了丰富的功能和灵活性。与之前文章中的`RadioButton`组件不同,`CheckBox`组件支持多项选择以及三态支持,即可以是选中、未选中或半选中的状态。
43 0
C++ Qt开发:CheckBox多选框组件
|
5月前
复选框checkbox实现自定义样式
复选框checkbox实现自定义样式
26 1
|
8月前
|
Android开发
Android 中CheckBox复选框按钮的基本用法
Android 中CheckBox复选框按钮的基本用法
93 0
Android 中CheckBox复选框按钮的基本用法
|
8月前
|
Android开发
Android 复选框CheckBox 设置只能选中其中一个
Android 复选框CheckBox 设置只能选中其中一个
178 0
|
8月前
|
XML Android开发 数据格式
Android CheckBox 复选框(自定义复选框)
Android CheckBox 复选框(自定义复选框)
239 0
|
11月前
零基础VB教程039期:如何使用单选按钮optionbutton以及多选框checkbox
零基础VB教程039期:如何使用单选按钮optionbutton以及多选框checkbox
190 0
|
11月前
实战总结(二)—— CheckBox复选框和SpannableString
实战总结(二)—— CheckBox复选框和SpannableString
|
Python
【tkinter学习笔记 - 3】:Radiobutton单选按钮、Checkbutton复选按钮
【tkinter学习笔记 - 3】:Radiobutton单选按钮、Checkbutton复选按钮
148 0
【tkinter学习笔记 - 3】:Radiobutton单选按钮、Checkbutton复选按钮
JavaFX控件——FileChooser(文件选择框)
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Hanniel/article/details/78877164 和其他的接口组件不同,FileChooser 不属于javafx.scene.controls包,FileChooser 类在javafx.stage 包下,和其他主要的图形元素在一起,比如:Stage,Window,以及Popup。
2683 0

热门文章

最新文章