在Mac OSX中设置QComboBox样式

时间:2015-05-09 21:54:36

标签: c++ macos qt qtstylesheets

我在Mac OSX中使用Qt5的组合框弹出样式设置了一些问题

我的QComboBox样式表

QComboBox {
    font-size: 11px;
    height: 16px;
    padding: 1px 5px 1px 5px;
    border: 2px groove #4B4F4F;
    border-bottom: 2px ridge #424545;
    border-right: 2px ridge #424545;
    border-radius: 3px;
    color: #DEDEDE;
    background: qlineargradient(x1:0, x2:0, y1:0, y2:1, stop:0 #6B6E6E, stop:1 #595B5B);
}
QComboBox::drop-down {
    subcontrol-origin: padding;
    subcontrol-position: top right;
    width: 14px;
    border-left-width: 1px;
    border-left-color: #999999;
    border-left-style: solid; /* just a single line */
    border-top-right-radius: 3px; /* same radius as the QComboBox */
    border-bottom-right-radius: 3px;
}
QComboBox::down-arrow {
    height: 8px;
    width: 8px;
    image: url(:/resources/images/downarrow.png);
}
QComboBox:on {
    border: 1px solid #00A7CC;
    padding-left: 6px;
}
QComboBox QAbstractItemView {
    min-width: 100px;
    outline: 1px solid #808A8A;
    border: 1px solid #373838;
    selection-background-color: #808A8A;
    background-color: #4A4C4F;
}
QComboBox:!enabled {
    color: #909090;
}

Mac OSX上的结果如下所示:

我想改变以下事项:

  • 摆脱弹出窗口顶部和底部的空白区域
  • 隐藏左侧的勾号或更改其大小

修改

我可以解决白色空间的问题但不能解决问题。它看起来仍然很难看。

我将QComboBox的填充更改为:

QComboBox {
        padding: 0px 5px 0px 5px;
....

我的左上角还有一个小点,不知道我怎么能隐藏这个

4 个答案:

答案 0 :(得分:0)

我有同样的问题,但仍然没有找到解决方案,所以我改变了样式工厂:

#if defined(Q_OS_MAC)
    ui->cb_action->setStyle(QStyleFactory::create("Windows"));
#endif

答案 1 :(得分:0)

我也想隐藏刻度线,但是QStyleFactory的解决方案效果不佳。因此,我变通了,发现了另一个对我有用的解决方案:

ui->comboBox->setItemDelegate(new QStyledItemDelegate());

答案 2 :(得分:0)

它适用于:

ui->cb_action->setStyle(QStyleFactory::create("Windows"));

...由vic-lin建议。

答案 3 :(得分:0)

在 SetStyleSheet 中添加下面这行可能会解决您的问题,我遇到了同样的问题,但现在解决了。

combobox-popup: 0;