我正在尝试在Qt中实现类似“组合图标”的功能。
目标:我需要动态设置图标部分的颜色。
我的想法:通过两个不同的图标进行组合。其中一个图标将按所需方式进行着色(可以使用ColorizeEffect),然后将其混合在第二个作为覆盖层的图标下面。
问题:我尝试使用QIconEngine并实现其paint方法,但是ColorizeEffect似乎无法工作(即使我尝试使用临时QLabel解决这个问题——当强度设置为>0.0时,由此形成的QIcon为空)。但这不是主要问题。问题是,无论我怎么做,都会得到一些默认颜色的背景,作为这个“组合”图标的底部。
以下是我的代码片段:
这是我的paint(...)实现代码:
目标:我需要动态设置图标部分的颜色。
我的想法:通过两个不同的图标进行组合。其中一个图标将按所需方式进行着色(可以使用ColorizeEffect),然后将其混合在第二个作为覆盖层的图标下面。
问题:我尝试使用QIconEngine并实现其paint方法,但是ColorizeEffect似乎无法工作(即使我尝试使用临时QLabel解决这个问题——当强度设置为>0.0时,由此形成的QIcon为空)。但这不是主要问题。问题是,无论我怎么做,都会得到一些默认颜色的背景,作为这个“组合”图标的底部。
以下是我的代码片段:
class QComposedIconEngine: public QIconEngine
{
public:
QComposedIconEngine();
~QComposedIconEngine();
virtual void paint ( QPainter * painter, const QRect & rect, QIcon::Mode mode, QIcon::State state );
virtual QIconEngine * clone(void) const;
public:
QIcon m_qIconA;
QIcon m_qIconB;
QColor m_qColor;
};
这是我的paint(...)实现代码:
void CLxQComposedIconEngine::paint ( QPainter * painter, const QRect & rect, QIcon::Mode mode, QIcon::State state )
{
QBrush brush = painter->background();
QColor color = brush.color();
brush.setColor( Qt::transparent );
painter->setBackground( brush );
painter->eraseRect( rect );
painter->setCompositionMode( QPainter::CompositionMode_SourceOver );
m_qIconA.paint( painter, rect, Qt::AlignCenter, mode, state );
};
以下是我创建“组成”的图标的步骤:
QComposedIconEngine * qIconEngine = new QComposedIconEngine();
QIcon i1;
QIcon i2;
i1.addPixmap(...);
i2.addPixmap(...);
qIconEngine->m_qIconA = i1;
qIconEngine->m_qIconB = i2;
QIcon i3( qIconEngine );
我希望i1和i3看起来完全相同,除了可恶的背景颜色之外。但是我需要使其透明。
即使我将我的paint(...)方法留空,可恶的背景仍然存在!有谁知道如何使背景透明吗?谢谢。