繁体   English   中英

QImage :: pixel()无法正确返回透明度

[英]QImage::pixel() not returning transparency properly

这就是我想要做的。 我有一个.svg图像,该图像具有透明背景,否则为完全白色。 我希望将图像渲染为QImage,然后调整图像的色相,以便可以随时更改颜色以匹配界面,然后只要将鼠标悬停在其上,就可以调整饱和度和值。点击。 我已经成功将图像渲染为QImage,如下所示:

QSvgRenderer renderer(TAG_DELETE_ICON_PATH);
m_TagDeleteImage = QImage(m_Metric.height(), m_Metric.height(), QImage::Format_ARGB32);
m_TagDeleteImage.fill(0x00000000);

QPainter painter(&m_TagDeleteImage);
painter.setRenderHint(QPainter::Antialiasing);
renderer.render(&painter);

其中,m_TagDeleteImage是QImage,TAG_DELETE_ICON_PATH是图标的有效路径,而m_Metric是对有效字体的字体度量。 是的,高度和宽度都应该是字体的高度。 这一切都发生在构造函数中,然后绘制到paint函数中的小部件上。 如果我将其保留在此处,则可以正确地绘制具有适当透明度的白色图像。 现在,我只需要更改图像的色相,值和饱和度即可。 该文档似乎非常详尽(尽管显然缺少一些关键细节),所以我尝试像这样调整图像中的每个像素:

QSvgRenderer renderer(TAG_DELETE_ICON_PATH);
m_TagDeleteImage = QImage(m_Metric.height(), m_Metric.height(), QImage::Format_ARGB32);
m_TagDeleteImage.fill(0x00000000);

QPainter painter(&m_TagDeleteImage);
painter.setRenderHint(QPainter::Antialiasing);
renderer.render(&painter);

for(int x = 0; x < m_TagDeleteImage.width(); x++)
{
    for(int y = 0; y < m_TagDeleteImage.height(); y++)
    {
        QColor current(m_TagDeleteImage.pixel(x, y));
        QRgb newPixel = qRgba(TAG_DELETE_ICON_COLOR.red(), TAG_DELETE_ICON_COLOR.green(),
                              TAG_DELETE_ICON_COLOR.blue(), current.alpha());

        m_TagDeleteImage.setPixel(x, y, newPixel);
    }
}

其中TAG_DELETE_ICON_COLOR是已经设置为我想要的hsv的有效QColor。 现在,在另一个小部件的蓝色背景下它是白色的,因此非常明显。 当我执行这些操作时,即使您看到我试图保留当前的Alpha值并且仅更改该值,我得到的只是我的图像所在的完全白色的正方形,而Alpha显然被完全忽略了。 由于它是一个非常小的QImage,例如16 x 16,因此我决定像这样打印每个像素的值:

for(int x = 0; x < m_TagDeleteImage.width(); x++)
{
    for(int y = 0; y < m_TagDeleteImage.height(); y++)
    {
        QColor current(m_TagDeleteImage.pixel(x, y));
        qDebug() << "pixel: " << (m_TagDeleteImage.width() * x) + y << " "
                 << current.red() << " " << current.green() << " "
                 << current.blue() << " " << current.alpha();
    }
}

并明确显示图像中的所有像素均为白色且完全不透明(255,255,255,255)。 为了确保我正确获取了当前像素,我执行了相同的打印语句,但是在清除图像后立即像这样:

QSvgRenderer renderer(TAG_DELETE_ICON_PATH);
m_TagDeleteImage = QImage(m_Metric.height(), m_Metric.height(), QImage::Format_ARGB32);
m_TagDeleteImage.fill(0x00000000);

for(int x = 0; x < m_TagDeleteImage.width(); x++)
{
    for(int y = 0; y < m_TagDeleteImage.height(); y++)
    {
        QColor current(m_TagDeleteImage.pixel(x, y));
        qDebug() << "pixel: " << (m_TagDeleteImage.width() * x) + y << " "
                 << current.red() << " " << current.green() << " "
                 << current.blue() << " " << current.alpha();
    }
}

然后我发现了问题。 即使此时所有像素都应该是完全透明的(rgba 0、0、0、0),但每个像素都在向后报告(rgba 0、0、0、255)。 图像格式设置为QImage :: Format_ARGB32,因此它一定要尊重Alpha通道。 我已验证m_TagDeleteImage.hasAlphaChannel()确实返回true。 谁能告诉我发生了什么事?

如果您需要更多代码,我将粘贴。

编辑:更改行:

m_TagDeleteImage.fill(0x0000000);

m_TagDeleteImage.fill(QColor(0, 0, 0, 0));

没变。

好吧,我在Qt上摆弄了更多随机函数,并仔细阅读了大量文档,在QColor文档页面上找到了有关QColor :: QColor(QRgb color)构造函数的一些相关知识:

'使用值color构造颜色。 Alpha分量将被忽略并设置为固体。”

为什么会这样,我不知道。 修改了代码,使其仅停留在QRgb及其辅助功能上,并且工作正常。

QSvgRenderer renderer(TAG_DELETE_ICON_PATH);
m_TagDeleteImage = QImage(m_Metric.height(), m_Metric.height(), QImage::Format_ARGB32);
m_TagDeleteImage.fill(QColor(0, 0, 0, 0));

QPainter painter(&m_TagDeleteImage);
painter.setRenderHint(QPainter::Antialiasing);
renderer.render(&painter);

for(int x = 0; x < m_TagDeleteImage.width(); x++)
{
    for(int y = 0; y < m_TagDeleteImage.height(); y++)
    {
        QRgb current = m_TagDeleteImage.pixel(x, y);
        QRgb newPixel = qRgba(TAG_DELETE_ICON_COLOR.red(), TAG_DELETE_ICON_COLOR.green(),
                              TAG_DELETE_ICON_COLOR.blue(), qAlpha(current));

        m_TagDeleteImage.setPixel(x, y, newPixel);
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM