• 爱情文章
  • 亲情文章
  • 友情文章
  • 生活随笔
  • 校园文章
  • 经典文章
  • 人生哲理
  • 励志文章
  • 搞笑文章
  • 心情日记
  • 英语文章
  • 范文大全
  • 作文大全
  • 新闻阅读
  • 当前位置: 山茶花美文网 > 爱情文章 > 正文

    【nodejs修复ipa处理过的png图片】 修复ipa精灵

    时间:2020-03-28来源:山茶花美文网 本文已影响 山茶花美文网手机站

    最近做项目遇到一个需求:解析apk和ipa包,然后把里面的icon上传到服务器。

    问题

    解析上传过程比较简单,我使用JSZip对apk和ipa进行解压,然后把找到里面的icon上传到服务器。但是,当我在网页中使用图片时,问题出现了。对于apk中的icon,没有任何问题,但是对于ipa中解析出来的图片,在safari中可以正常显示,在其他任何浏览器去无法显示。

    原因

    Google后发现,是苹果对png图片进行了优化处理,具体看这篇文章(查看),在文章中我们可以了解到一些有用信息:

    Apple uses PNGCursh open source library to crush png images inside iPA files。

    解决方案

    作为一个前端工程师,我希望用javascript解决这个问题。其实之前国外已经有人去解决了,NodeJS-PNGDefry就是可以,可惜这个太久没维护,已经跑不起来。

    找不到可用的,我只能自己动手丰衣足食,自己写一个。因此有了node-pngdefry。node-pngdefry的功能很明确,就是用Javascript来还原被苹果处理过的png图片。

    node-pngdefry用法很简单,支持命令行和常规的Node.js:

    命令行用法

    install:

    $ npm install -g pngdefry

    then run:

    $ pngdefry -i icon.png -o icon.new.png

    在Node.js中使用

    $ npm install pngdefry --save-dev var pngdefry = require("pngdefry"); var path = require("path"); var input = path.join(__dirname, "icon.png"); var output = path.join(__dirname, "icon.new.png"); pngdefry(input, output, function(err) { if (err) { return; } console.log("success"); });

    Test

    $ npm test

    项目地址

    node-pngdefry

    • 【nodejs修复ipa处理过的png图片】 修复ipa精灵 相关文章:
    • 爱情文章
    • 亲情文章
    • 友情文章
    • 随笔
    • 哲理
    • 励志
    • 范文大全