ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Qt样式表:QComboBox的弹出列表样式

2021-04-19 13:00:48  阅读:313  来源: 互联网

标签:Qt color comboBox QComboBox 6px 样式表 background border


QComboBox的弹出列表的类型是QAbstractItemView。这是个抽象类,无法创建对象,如果QComboBox自定义弹出列表类型使用的是它的子类,一般是QListView。当然用其他子类也行,如:

    ui->comboBox->setView(new QTreeView());

就是看起来怪怪的。

弹出列表参考样式:

QComboBox{
    border-radius: 6px;
    border: 1px solid #00bcd4;
    padding:6px 10px 6px 10px;
    color: #000000;
}
QComboBox::drop-down{
    border:none;
}
QComboBox::down-arrow{
    image: url(:xiala_black.png);border: none;
}
QComboBox:disabled{
    background: #d8d8d8;
}
QComboBox QAbstractItemView{
    background-color: #FFFFFF;
    color:#000000;
    border:1px solid #00bcd4;
    border-radius:6px;
    outline:none;
}
QComboBox QAbstractItemView::item{
    selection-background-color: #00bcd4;
    color:#000000;
    height:40px;
    border-radius:6px;
}
QComboBox QAbstractItemView::item:selected{
    background-color: #00bcd4;
    color:#FFFFFF;
}
QComboBox QScrollBar::vertical{
    width:10px;
    background-color:transparent;
    border:none;
    border-radius:6px;
}
QComboBox QScrollBar::handle::vertical{
    border-radius:6px;
    width: 10px;
    background:#00bcd4;
}
QComboBox QScrollBar::handle::vertical::hover{
    background:#24d4e0;
}
QComboBox QScrollBar::add-line::vertical{
    border:none;
}
QComboBox QScrollBar::sub-line::vertical{
    border:none;
}

QComboBox要设置setView()弹出列表样式才会起作用:

    ui->comboBox->setView(new QListView());

设置弹出菜单圆角:

    QListView * list_combox = new QListView();
    ui->comboBox->setView(list_combox);
    ui->comboBox->view()->window()->setWindowFlags(Qt::Popup|Qt::FramelessWindowHint|Qt::NoDropShadowWindowHint);
    ui->comboBox->view()->window()->setAttribute(Qt::WA_TranslucentBackground);
    ui->comboBox->view()->window()->setCursor(Qt::PointingHandCursor);

效果:

标签:Qt,color,comboBox,QComboBox,6px,样式表,background,border
来源: https://blog.csdn.net/kenfan1647/article/details/115841584

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有