• Qt加载SVG图片以及改变SVG图片颜色


    1 Qt加载SVG图片

    QTreeWidgetItem *item = new QTreeWidgetItem;
    //svg_path为SVG图片路径
    QSvgRenderer *svg_render = new QSvgRenderer(svg_path);
    QPixmap *pixmap = new QPixmap(32, 32);
    pixmap->fill(Qt::transparent);
    QPainter painter(pixmap);
    svg_render->render(&painter);
    QIcon ico(*pixmap);
    item->setIcon(1, ico);

    2 Qt改变SVG图片颜色

    QTreeWidgetItem *item = new QTreeWidgetItem;
    QString path = svg_path;
    QFile file(path);
    file.open(QIODevice::ReadOnly);
    QByteArray data = file.readAll();
    QDomDocument doc;
    doc.setContent(data);
    file.close();
    
    QString color = "blue";
    
    SetSVGBackColor(doc.documentElement(), "path", "fill", color);
    
    QByteArray svg_content = doc.toByteArray();
    QSvgRenderer *svg_render = new QSvgRenderer(svg_content);
    QPixmap *pixmap = new QPixmap(32, 32);
    pixmap->fill(Qt::transparent);
    QPainter painter(pixmap);
    svg_render->render(&painter);
    QIcon ico(*pixmap);
    item->setIcon(0, ico);
    void SetSVGBackColor(QDomElement &elem, QString strtagname, QString strattr, QString strattrval);
    
    void SetSVGBackColor(QDomElement &elem, QString strtagname, QString strattr, QString strattrval)
    {
        if (elem.tagName().compare(strtagname) == 0)
        {
            QString before_color = elem.attribute(strattr);
            elem.setAttribute(strattr, strattrval);
            QString color = elem.attribute(strattr);
        }
        for (int i = 0; i < elem.childNodes().count(); i++)
        {
            if (!elem.childNodes().at(i).isElement())
            {
                continue;
            }
            SetSVGBackColor(elem.childNodes().at(i).toElement(), strtagname, strattr, strattrval);
        }
    }
  • 相关阅读:
    html css div img垂直居中
    jquery 多选框 checkbox 获取选中的框
    css 滚动条样式
    css 翻牌 翻转 3d翻转 特效
    css强制不换行 多出的字省略号
    jquery获取元素坐标获取鼠标坐标
    鸡汤 咯咯
    <bean> 中配置详解 </bean>
    正则表达式的囧
    我的天$删除注册表$安装mysql最后一步不能启动服务的解决办法
  • 原文地址:https://www.cnblogs.com/LuckCoder/p/11171666.html
Copyright © 2020-2023  润新知