Qt控件之自定义ComboBox样式

在Qt给的ComboBox由于没有限定下拉框的长度,数据量多时下拉框可以到达软件的底部,比较影响使用,这里可以对其样式进行修改,设置__maxPopupHeight的值即可。

ComboBox {
     id: province_company_check
     anchors.fill: parent
     model: ListModel {
             id: province_company_model
     }
    style:ComboBoxStyle {
        property Component __dropDownStyle: MenuStyle {
            __maxPopupHeight: 250
            __menuItemType: "comboboxitem"
            frame: Rectangle {              // MenuStyle background
                border.width: 1
            }
            itemDelegate.label:             // an item text
                                            Text {
                verticalAlignment: Text.AlignVCenter
                horizontalAlignment: Text.AlignHCenter
                color: styleData.selected ? "white" : "black"
                text: styleData.text
            }
            itemDelegate.background: Rectangle {  // selection of an item
                color: styleData.selected ? "#3199e8" : "transparent"
            }
            __scrollerStyle: ScrollViewStyle { }
        }
    }
    Connections {
        target: province_company_check.__popup
        onAboutToHide: {
            province_company_check.__popup.__destroyAllMenuPopups()
        }
    }
}
好的,关于qt combobox样式美化举例,我可以给您提供几个常用的方法: 1. 使用StyleSheet,例如: QComboBox {\n background-color: #F3F3F3;\n color: #333333;\n border: 1px solid #CCCCCC;\n padding: 1px;\n border-radius: 3px;\n min-width: 6em;\n }\n \n QComboBox::drop-down {\n subcontrol-origin: padding;\n subcontrol-position: top right;\n width: 20px;\n border-left-width: 1px;\n border-left-color: darkgray;\n border-left-style: solid;\n border-top-right-radius: 3px;\n }\n \n QComboBox::down-arrow {\n image: url(:/images/arrow.png);\n }\n 2. 使用QProxyStyle,继承QProxyStyle类并重写drawComplexControl方法,例如: class CustomComboBoxStyle : public QProxyStyle { public: CustomComboBoxStyle() { setObjectName("CustomComboBoxStyle"); } void drawComplexControl(ComplexControl control, const QStyleOptionComplex *option, QPainter *painter, const QWidget *widget = nullptr) const override { if (control == CC_ComboBox) { QStyleOptionComboBox opt(*option); opt.currentIcon = QPixmap(":/images/icon.png").scaledToWidth(opt.iconSize.width(), Qt::SmoothTransformation); QProxyStyle::drawComplexControl(control, &opt, painter, widget); return; } QProxyStyle::drawComplexControl(control, option, painter, widget); } }; 3. 使用QComboBox的addItem方法添加QStandardItem,通过设置QStandardItem的样式来实现,例如: QStandardItem *item = new QStandardItem(QIcon(":/images/icon.png"), "Item"); item->setFont(QFont("Arial", 12)); item->setForeground(QBrush(Qt::red)); ui->comboBox->addItem(item); 希望这些方法能够帮到您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱技术爱生活

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值