我正在尝试QComboBox
用一些颜色选项来做一个简单的。到目前为止,我发现的最简单的方法是QPixmap
为每个项目制作一个,用颜色填充它并将其用作项目的图标:
this->colorComboBox = new QComboBox;
this->colorComboBox->setIconSize(QSize(100, 15));
QPixmap colorIcon(100, 15);
this->colorList.push_back(QColor(255, 255, 255, 255));
this->colorList.push_back(QColor(194, 169, 160, 255));
this->colorList.push_back(QColor(235, 206, 157, 255));
this->colorList.push_back(QColor(254, 121, 5, 255));
this->colorList.push_back(QColor(255, 195, 78, 255));
this->colorList.push_back(QColor(111, 203, 172, 255));
for(unsigned int i = 0; i < this->colorList.size(); ++i)
{
colorIcon.fill(this->colorList.at(i));
this->colorComboBox->addItem(colorIcon, QString(""));
}
问题是,即使颜色矩形在当前选定项目的按钮上显示良好:
对于弹出列表中的项目,它显示很小:
似乎像素图本身总是缩小到大约 15px 的宽度,无论我选择什么尺寸setIconSize
。
我觉得这应该很容易解决,但我已经尝试了几件事,但似乎没有任何效果......提前感谢您的帮助。
编辑:
QSS
具有以下内容QComboBox
。我尝试将QComboBox::drop-down
' 的宽度更改为 100px 并且框本身变大了,图标仍然很小。
QComboBox
{
border: 1px solid #101010;
background-color: #808080;
color: #d0d0d0;
border-radius: 4px;
selection-color: #f58113;
selection-background-color: #808080;
show-decoration-selected: 0;
}
QComboBox:on
{
padding-top: -10px;
padding-left: 4px;
}
QComboBox::drop-down
{
subcontrol-origin: padding;
subcontrol-position: top right;
width: 15px;
border-left-width: 0px;
border-left-color: #000000;
border-left-style: solid;
border-top-right-radius: 3px;
border-bottom-right-radius: 3px;
}