有关libpng warning: iCCP: known incorrect sRGB profile警告的原因



  • 问题

    有些PNG图片加载时会打印警告,如下:
    libpng warning: iCCP: known incorrect sRGB profile

    影响

    程序运行时打印过多警告信息,虽然功能没有影响,但是不仅拖慢启动速度而且也不美观

    原因

    仔细查阅PNG图片的文件结构及对图片进行二进制(十六进制)分析,如下:

    1. libpng 1.6及以上版本对PNG图片的字段检查更加严格,诸如PhotoShop或者GIMP处理图片时“模式”选择不对就会出现这个警告

    2. PNG图片的原始文件由8个字节的文件标识,4个标准(关键)数据块(必须包含),16个辅助数据块(可选包含)组成
      Screenshot from 2016-11-03 11-37-37.png
      出问题的是16个辅助数据块中的iCCP数据块和sRGB数据块,这两个都是设置图片颜色模式的数据块,而且是“或”的关系,也就是每个PNG图片如果包含那就是能是“二选一”

    3. 经过检测,我们程序出的问题是,使用iCCP数据块的必然出错,使用sRGB数据块的就没问题
      使用GIMP很快就看出来我们使用的iCCP数据块是sRGB IEC61966-2.1标准,sRGB数据块使用的是sRGB built-in的 另外iCCP数据块的的标准除了上述之外,其它还有很多,我们的图片我倒是没见到。

    检测

    1. 本来打算直接分析图片原始文件的十六进制值,提取iCCP数据块的类型码,如果检测到则提示错误,但是很奇怪我每张图片都没发现这串十六进制值

    2. 使用ImageMagick提供的工具,执行如下命令:

    $ find ./ -type f -name "*.png" 2>/dev/null -exec identify -verbose {} ; | grep png:iCCP:

    只要有结果输出就可以知道有图片出问题了

    1. 目前没找到纯C/C++语言写的程序可以检测

    解决

    1. 类似@jiangcaiyang 提供的方法,很多Qt写的程序都是一样,使用QImage转换一下,相当于做一个“匹配”就好了
    2. Gimp PhotoShop图片处理软件本身也可以
    3. 使用ImageMagick提供的工具,执行如下命令:
      $ convert -strip mile.png mileTmp.png


  • 如果使用最简单的办法来检测某个图片是否会报PNG的警告,可以写一个非常简单的Qt程序:

    #include <QCoreApplication>
    #include <QProcess>
    #include <QImage>
    
    int main(int argc, char *argv[])
    {
        QImage image( "/home/jiangcaiyang/下载/background2.png" );
        Q_UNUSED( image );
    }
    

    使用这个命令运行该程序:

    ./TestPNGWarning 2>&1 | tee output.txt

    如果output.txt有输出,那么程序就会报PNG警告,否则不会报PNG的警告。非常简单。还有很多变种,可以检测出PNG的警告。



  • 怎么会拖慢速度。。。profile不能用就直接弃用了啊

    再来个
    libpng warning: iCCP: profile 'Photoshop ICC profile': 'RGB ': RGB color space not permitted on grayscale PNG



  • @MidoriYakumo 报这个错误的时候,会将字符串输出到stderr,要访问IO,所以会比较慢。有一个现象就是,输出stderr的话,会拖慢程序的启动时间,对于启动时间非常苛刻的程序来说,还是尽量避免为好。


Log in to reply
 

最近的回复

  • E

    是不是好久都没有人了,站主找到工作了,还是说划水了

    read more
  • 请问一下如果原Qt桌面软件支持拖拽外部文件进去(比如把在用资源管理器里的一张图片拖拽到软件界面上就会显示这张图片),转成Webassembly之后这种拖拽操作还是否有效?劳烦大佬帮我试试看,可以的话我就学QML了

    read more
  • H
    Toou 2D 拿来即用,为简单而生。

    简称T2D,是一款采用自身模块规范编写的轻量级UI框架,遵循Qt书写与组织形式门槛极低无需深入学习简单易用可拿来即用,丰富的控件模块适合界面的快速开发,让程序人员拥有更多的精力来实现业务逻辑与算法。

    统一交互规范,丰富的Ui控件几十种常用控件放弃了Qt Controls 及 Controls 2 来提高性能。

    完善的主题系统,业务逻辑与界面主题设计分离,可通过简单修改变量自定义主题皮肤。灵活的多主题皮肤绑定机制、在不需要重启App即实现一键换肤

    ini皮肤配置规则与每一个控件融合。可在应用内配置也可在应用外动态扩展配置。

    框架自动化安装支持动态库、静态库多模式编译。使用方便更安全更自由。

    提供丰富Demo、全面的帮助文档,Api查阅快速方便。项目必备开源框架!

    已经集成最新版 Font Awesome 4.7

    开源地址:https://github.com/ShowFL/Toou-2D

    read more
  • 刚刚毕业,工作用QT开发,以后有问题多多请教各位前辈😬 抱拳了。

    read more

关注我们

微博
QQ群