导读

组合框是一个重要且应用广泛的组件,一般由两个子组件组成:文本下拉单部分和按钮部分。在许多既需要用户选择、又需要用户手动输入的应用场景下,组合框能够很好的满足我们的需求。如我们经常使用的聊天软件QQ登录框,便是一个很好的应用例子:

显然,用户既可以自己手动输入新的QQ号码,也可以在列表框中选择历史输入记录。对于提高用户体验是一个不错的手段。这篇博文重点讲述如何用QSS对组合框进行定制。

基本自定义

组合框的使用非常简单,为了加快叙述速度,我们直接在Qt Designer中拖一个QComboBox控件放到主窗口中。此时,我们什么都不用做就有了一个简单的组合框,如下:

但很显然,我们得添加一个文字,否则QComboBox不会显示任何内容。这样出现的组合框样式很普通:一个文本加一个带箭头号的按钮就完了。既然主题是用QSS来定制组合框,那么我们第一件事就是新建一个.qss文件并添加到资源文件中进行编译。.qss文件的内容初步编写如下:

1
2
3
4
5
6
QComboBox {
    border1px solid gray;
    border-radius: 3px;
    padding1px 2px 1px 2px;  # 针对于组合框中的文本内容
    min-width9em;   # 组合框的最小宽度
}

  我们给组合框3个像素的圆角,边框1个像素宽并将颜色设置为灰色。看看效果:

文本框部分似乎还不错,但是右边的按钮外观实在是太丑了,和整体风格不搭。我们继续美化一下按钮。按钮是QComboBox的一个子组件,用::drop-down指代。编写如下QSS代码:

+ View Code

  可以看到,我们分别将按钮右上角和右下角设置了3个像素的圆角,这是因为我们前面给组合框的整体边框设置了圆角。如果不给按钮设置圆角,那么按钮的棱角将会遮挡住整体边框的圆角效果。另外,我们改变了按钮上的箭头图标。::down-arrow也是一个子组件,我们用image属性替换了系统默认的图标。对比一下:

嗯,整体风格上看起来协调些了。当然了,在::drop-down子组件的定制中,我们将subcontrol-position属性设置成了top, right。这样按钮就位于最右边了。如果希望将按钮置于最左边显然也很简单。只需要将subcontrol-position设置为top, left,然后改变一下QComboBox的padding值就可以达到目的了。我们再拉出下拉框看看:

有什么问题呢?显然,下拉框中的选项高度太小了,看起来挺别扭的。那么如何对下拉框进行定制呢?我们有个很好的模仿对象:

360安全卫士的登录框中的下拉框看起来就挺不错,而且还有图标出现在选项的右边。下面我们就进入高级定制部分。看看又该如何进行改进。

高级自定义

要实现上述效果,我们首先要做的就是将QComboBox设置为可以编辑的(setEditable())。这样,文本框中的内容才可以手动进行输入。另外,我们还注意到,下拉框中的选项右边还有图标出现,QQ的登录框中也出现了图标。我们最直观的想法就是用布局管理器(水平或垂直的)将所有组件组装成一个整体,然后再添加到下拉框中去。

怎么做呢?幸运的是,QComboBox内部也是Model/View框架来维护下拉框内容的。因此,最直接的方法就是定义一个QListWidget,将这个QListWidget设置为QComboBox的View,而将QListWidget的Model设置为QComboBox的Model。QListWidget只是一个View类,因此我们还得自定义View类中的Item啊。

那好,自QWidget派生一个子类,实现水平布局,将所有子组件添加到里面去:

+ View Code

  代码很简单,定义了两个标签QLabel,一个显示文本,一个显示图标。用水平布局管理器添加到QWidget中去。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
ThemeRoller::ThemeRoller(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
    m_listWidget = new QListWidget(this);
        // 设置子项目代理,否则下拉框选项周围会出现虚线框
    m_listWidget->setItemDelegate(new NoFocusFrameDelegate(this));
    ui.comboBox->setEditable(true);
    ui.comboBox->setModel(m_listWidget->model());
    ui.comboBox->setView(m_listWidget);
        // 在下拉框中添加5个选项
    for (int i = 0; i < 5; ++i)
    {
        ComboboxItem* item = new ComboboxItem(this);
        item->setLabelContent(QString("Account") + QString::number(i, 10));
        connect(item, SIGNAL(chooseAccount(const QString&)), this, SLOT(onChooseAccount(const QString&)));
        QListWidgetItem* widgetItem = new QListWidgetItem(m_listWidget);
        m_listWidget->setItemWidget(widgetItem, item);
    }
}

  我们还将ComboboxItem的chooseAccount()信号关联到了onChooseAccount()槽。这样,当用户点击了选项中的某一个选项时,能够在QComboBox的文本框中显示选中的项。那么,QSS该如何编写呢?

+ View Code

  也很简单,只是设置了选项中的高度,和QComboBox的高度保持一致,这样看起来不至于别扭。然后给选项设置了鼠标悬停背景色。至此,整个定制过程就结束了。看看效果如何:

小结

QComboBox分成三个定制部分:文本框(是否可编辑),按钮(箭头标记、边框),下拉框(选项高度、子组件布局)。由以上可见,我们利用QSS可以很好的实现出自己想要的效果,而且效果还不赖。

作者:24K纯开源

FROM:http://www.cnblogs.com/csuftzzk/p/qss_combobox.html

Qt Style Sheet实践(二):组合框QComboBox的定制相关推荐

  1. Qt Style Sheet实践(一):按钮及关联菜单

    http://www.cnblogs.com/csuftzzk/p/qss_button_menu.html 导读 正如web前端开发中CSS(Cascade Style Sheet)的作用一样,Qt ...

  2. Qt Style Sheet 翻译(中)--类似css

    //这个实在是难翻译,很多地方直译,因为我也没看懂   细微控制:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com: ...

  3. Custom Looks using Qt Style Sheets

    2019独角兽企业重金招聘Python工程师标准>>> With the introduction of Qt Style Sheets, styling Qt widgets ha ...

  4. 计算机跳转列表常用组合框,2015计算机二级VB考点复习指导:列表框和组合框

    2015计算机二级VB考点复习指导:列表框和组合框 (一)列表框 1.属性 列表框所支持的标准属性包括Enabled.FontBold.FontItalic.FontName.FontUnderlin ...

  5. Qt的皮肤设计(Style Sheet)

    Qt的皮肤设计,也可以说是对Qt应用程序的界面美化,Qt使用了一种类CSS的样式规则QSS. 一.Style Sheet的应用 1.直接在程序代码中设置样式,利用setStyleSheet()方法 w ...

  6. 第三十四章、PyQt中的输入部件:QComboBox组合框功能详解

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 一.概述 Designer中输入工具部件中的Combo Box组合框与 ...

  7. QComboBox的代理(订制QComboBox组合框)

    原文地址 导读 组合框是一个重要且应用广泛的组件,一般由两个子组件组成:文本下拉单部分和按钮部分.在许多既需要用户选择.又需要用户手动输入的应用场景下,组合框能够很好的满足我们的需求.如我们经常使用的 ...

  8. QT5.14.2 官方例子 - Qt Widgets 7: Group Box(组合框)

    组框示例展示了如何在Qt中使用不同类型的组框. 组框是容器小部件,可以在逻辑上和屏幕上将按钮组织成组.它们管理用户和应用程序之间的交互,因此您不必强制执行简单的约束. 组框通常用于将复选框和单选按钮组 ...

  9. QCombobox组合框的样式

    QComboBox { width: 400px;  //整个组合框的宽度 设置后在ui编辑器中即可用看见效果 min-width: 250px; max-width: 500px; height: ...

  10. 组合框快速输入(二)

    HI,手机边亲爱的你还好吗? 今天我们接着讲一下组合框快速输入的方法二. 之前,我们讲了第一个方法,是直接调用一个新增窗体来添加数据,这个方式的好处是可以把基础数据添加的比较完整,但比较麻烦,所以,今 ...

最新文章

  1. 总是听别人说响应式布局,原来这么简单
  2. 第一个简单的DEMO
  3. 【推荐】LSI(latent semantic indexing) 完美教程
  4. 工作56:element里面表单重置
  5. 泰山行宫碧霞元君祠_临清市泰山行宫碧霞元君祠5月4号(农历三月三十日)举行大型泰山奶奶接驾法会...
  6. 十六进制表示_教资信息技术之:十进制(正数)转二进制、八进制、十六进制...
  7. 自动驾驶面试题汇总(2022秋招题库)——持续更新
  8. 电力电子、电机控制系统的建模和仿真_电力传动控制系统:运动控制系统
  9. ArcGIS For Flex学习之Mapping---Map Extent and Mouse Coordinates
  10. 【天池竞赛系列】阿里移动推荐算法思路解析
  11. 操作系统思考 第五章 更多的位与字节
  12. java坦克大战图片素材包,坦克大战素材包
  13. 中国遥感卫星详细参数信息
  14. flutter-谷歌移动UI框架
  15. 眼科相关疾病最新研究进展(2022年3月)
  16. 实用Chrome插件
  17. js创建节点删除节点实例
  18. Hexo搭建个人博客(十五)| 酒香也怕巷子深,让百度收录你的站点
  19. Ubuntu下用shell脚本实现俄罗斯方块游戏
  20. Spark:reduceByKey与groupByKey进行对比

热门文章

  1. windows11桌面删除ie图标
  2. 2021-2027中国高效空气过滤器市场现状及未来发展趋势
  3. 图文并茂的大学生面试攻略【实用】
  4. 201871010109-胡欢欢《面向对象程序设计(java)》第四周学习总结会
  5. Qt Moc及信号-槽源代码解析
  6. 教你如何玩转豆瓣(douban) 豆瓣使用入门!
  7. 目前常用计算机配置,电脑常见主要配置、参数
  8. Java:spring Value注解用法详解
  9. 台式/笔记本无线网卡_异常问题
  10. 网络恶趣实验——二层广播风暴