Qt | 控件之QComboBox
QComboBox是下拉列表组件类,它提供一个下拉列表供用户选择,也可以直接当做一个QLineEdit用作输入。用户点击控件后,可以从出现的下拉菜单中选择一项。QComboBox除了显示可见下拉列表外,每个item(列表项)还可以关联一个QVariant类型的变量,用于存储一些不可见数据。
QVariant可以存储各种数据类型,类似于C++联合(union)数据类型,它不仅能够保存很多Qt类型的值,包括QColor,QBrush,QFont,QPen,QString和QSize等,也能够存放Qt的容器类型的值。
头文件:
#include<QComboBox>
创建方式:
- 静态方式:直接从工具箱中拖拉复选框控件的方式,不需要手动添加头文件,Qt Creator会自动添加;
- 动态方式:通过new创建复选框的方式,需要我们通过代码来手动添加头文件。
动态方式创建:QComboBox combo = new ComboBox(this);
设置样式:
setStyleSheet();
如果只是简单的创建一个QComboBox,对它显示的样式没有要求,就可以用系统的样式,不需要自己手动进行设置,但是如果为了界面美化需要设置样式表,可以使用setStyleSheet()函数对QComboBox的样式进行设置。
/* 未下拉时 */
"QComboBox {border:1px solid #eeeeee;border-radius:4px;
padding:1px 18px 1px 50px; background:#ffffff;
font-size:14px;color:#333333;font-family:Microsoft YaHei UI;}
QComboBox:checked {border:1px solid #069aae;}//下拉后,整个下拉窗体样式
QComboBox QAbstractItemView{outline: 0px solid gray;//选定项的虚线框
border:1px solid #eeeeee;//整个下拉窗体的边框
color:#333333;font-size:14px;font-family:Microsoft YaHei UI;
background-color: #ffffff;//整个下拉窗体的背景色
selection-color:#333333;selection-background-color:#f1f8ff;}//被选中的背景色
/* 下拉箭头样式 */
QComboBox::drop-down {subcontrol-origin: padding;subcontrol-position: top right;