Qt Style Sheet实践(二):组合框QComboBox的定制.doc

Qt Style Sheet实践(二):组合框QComboBox的定制.doc

ID:49615238

大小:182.55 KB

页数:5页

时间:2020-03-02

Qt Style Sheet实践(二):组合框QComboBox的定制.doc_第1页
Qt Style Sheet实践(二):组合框QComboBox的定制.doc_第2页
Qt Style Sheet实践(二):组合框QComboBox的定制.doc_第3页
Qt Style Sheet实践(二):组合框QComboBox的定制.doc_第4页
Qt Style Sheet实践(二):组合框QComboBox的定制.doc_第5页
资源描述:

《Qt Style Sheet实践(二):组合框QComboBox的定制.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、QtStyleSheet实践(二):组合框QComboBox的定制导读   组合框是一个重要且应用广泛的组件,一般由两个子组件组成:文本下拉单部分和按钮部分。在许多既需要用户选择、又需要用户手动输入的应用场景下,组合框能够很好的满足我们的需求。如我们经常使用的聊天软件QQ登录框,便是一个很好的应用例子:   显然,用户既可以自己手动输入新的QQ号码,也可以在列表框中选择历史输入记录。对于提高用户体验是一个不错的手段。这篇博文重点讲述如何用QSS对组合框进行定制。基本自定义   组合框的使用非常简单,为了加快叙述速度,我们直接在QtDesigner中拖一个Q

2、ComboBox控件放到主窗口中。此时,我们什么都不用做就有了一个简单的组合框,如下:   但很显然,我们得添加一个文字,否则QComboBox不会显示任何内容。这样出现的组合框样式很普通:一个文本加一个带箭头号的按钮就完了。既然主题是用QSS来定制组合框,那么我们第一件事就是新建一个.qss文件并添加到资源文件中进行编译。.qss文件的内容初步编写如下:QComboBox{    border:1pxsolidgray;    border-radius:3px;    padding:1px2px1px2px; #针对于组合框中的文本内容    min

3、-width:9em;  #组合框的最小宽度}  我们给组合框3个像素的圆角,边框1个像素宽并将颜色设置为灰色。看看效果:   文本框部分似乎还不错,但是右边的按钮外观实在是太丑了,和整体风格不搭。我们继续美化一下按钮。按钮是QComboBox的一个子组件,用::drop-down指代。编写如下QSS代码:QComboBox::drop-down{    subcontrol-origin:padding;    subcontrol-position:topright;    width:20px;     border-left-width:1px; 

4、   border-left-color:darkgray;    border-left-style:solid;/*justasingleline*/    border-top-right-radius:3px;/*sameradiusastheQComboBox*/    border-bottom-right-radius:3px;} QComboBox::down-arrow{    image:url(:/misc/down_arrow_2);}  可以看到,我们分别将按钮右上角和右下角设置了3个像素的圆角,这是因为我们前面给组合框的整体边框

5、设置了圆角。如果不给按钮设置圆角,那么按钮的棱角将会遮挡住整体边框的圆角效果。另外,我们改变了按钮上的箭头图标。::down-arrow也是一个子组件,我们用image属性替换了系统默认的图标。对比一下:   嗯,整体风格上看起来协调些了。当然了,在::drop-down子组件的定制中,我们将subcontrol-position属性设置成了top,right。这样按钮就位于最右边了。如果希望将按钮置于最左边显然也很简单。只需要将subcontrol-position设置为top,left,然后改变一下QComboBox的padding值就可以达到目的了。

6、我们再拉出下拉框看看:   有什么问题呢?显然,下拉框中的选项高度太小了,看起来挺别扭的。那么如何对下拉框进行定制呢?我们有个很好的模仿对象:   360安全卫士的登录框中的下拉框看起来就挺不错,而且还有图标出现在选项的右边。下面我们就进入高级定制部分。看看又该如何进行改进。高级自定义   要实现上述效果,我们首先要做的就是将QComboBox设置为可以编辑的(setEditable())。这样,文本框中的内容才可以手动进行输入。另外,我们还注意到,下拉框中的选项右边还有图标出现,QQ的登录框中也出现了图标。我们最直观的想法就是用布局管理器(水平或垂直的)

7、将所有组件组装成一个整体,然后再添加到下拉框中去。   怎么做呢?幸运的是,QComboBox内部也是Model/View框架来维护下拉框内容的。因此,最直接的方法就是定义一个QListWidget,将这个QListWidget设置为QComboBox的View,而将QListWidget的Model设置为QComboBox的Model。QListWidget只是一个View类,因此我们还得自定义View类中的Item啊。   那好,自QWidget派生一个子类,实现水平布局,将所有子组件添加到里面去:ComboboxItem::ComboboxItem(

8、QWidget*parent)    :QWidget(paren

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。