Webp 批量替换图片 gradle 插件 WebpConvert_Gradle_Plugin

码农软件 · 软件分类 · 多媒体处理 · 2019-09-12 21:41:52

软件介绍

webp插件介绍

webp转换插件可批量转换 build时 /build/intermediates/res/${flavorName}/${buildType}目录下的图片为webp格式, 打包出的apk就包含webp的图片了。

其搜索目标文件的规则如下

  1. res下以drawable为开头的目录

  2. 后缀为png,jpg的文件

  3. 不包含.9图片

webp插件的运行时机是在 processXXXResource Task前 添加一个名为webpConvertPlugin的 task并执行

局限性

Android 从4.0开始对webp格式的文件都有原生支持,所以如果你apk 的minSdkVersion 是 15以上 你不需要修改任何关于图片使用的java代码。

但请注意,如果你的项目里的jpg图片包含alpha值的设置,转换后的webp图片是不能再4.2.1以下正常运行的。

请参考:http://developer.android.com/guide/appendix/media-formats.html

pic

安装webp命令行工具

  1. homebrew 安装方法:

    装了brew 工具的同学可以用brew install webp

  2. macports 安装方法:

    http://distfiles.macports.org/MacPorts/中寻找对应你系统的最新版MacPorts安装包下载并安装在终端依次运行以下命令

  3. export PATH=$PATH:/opt/local/bin
    sudo port selfupdate
    sudo port install webp

通过在终端键入 cwebp判断是否安装成功

安装遇到问题请参考:https://developers.google.com/speed/webp/docs/precompiled#installing_cwebp_and_dwebp_on_os_x_with_macports

webp插件的使用方法如下:

  1. 在外层的build.gradle文件中(即与settings.gradle同级的文件)添加如下代码

    classpath 'com.mogujie.gradle:webpConvertPlugin:1.1.34'

  2. 在内层build.gradle文件中(即与src同级的文件)添加如下代码

  3. apply plugin: 'webpConvert'
    webpinfo {
        //是否在debug时跳过webp转换
        skipDebug = true
        //是否显示log
        isShowLog = false
    }
  4. 在与src同级的目录下添加名为webp_white_list.txt的文件 此文件提供白名单功能 可以设置哪些文件不会被转换为webp文件,配置时,一个文件名为一行,如

  5. bill_footer_sitepro_arrow.png
    cart_checkbox_false.png

好了,万事具备,只要你clean后  assemble一发,png,jpg就替换成功了,打包出的apk就包含webp的图片了.so easy

gradle clean
gradle assembleDebug

本文地址:https://codercto.com/soft/d/14467.html

零基础学Java Web开发

零基础学Java Web开发

刘聪 编 / 机械工业出版社 / 2008-1 / 59.00元

《零基础学Java Web开发:JSP+Servlet+Sfruts+Spring+Hibernte》全面讲解Java Web应用开发的编程技术,并详细介绍Java Web开发中各种常用的技术,可作为Java Web开发技术的学习指南。 《零基础学Java Web开发:JSP+Servlet+Sfruts+Spring+Hibernte》共17章,分为3篇,其中第1~12章是基础篇,讲解了......一起来看看 《零基础学Java Web开发》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码