chenenyu/img-optimizer-gradle-plugin


一款用于优化png图片的gradle插件,有效减少APK体积,支持极限压缩和无损压缩。

Download


Step 1. Add the JitPack repository to your build file

Add it in your root settings.gradle at the end of repositories:

	dependencyResolutionManagement {
		repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
		repositories {
			mavenCentral()
			maven { url 'https://jitpack.io' }
		}
	}

Add it in your settings.gradle.kts at the end of repositories:

	dependencyResolutionManagement {
		repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
		repositories {
			mavenCentral()
			maven { url = uri("https://jitpack.io") }
		}
	}

Add to pom.xml

	<repositories>
		<repository>
		    <id>jitpack.io</id>
		    <url>https://jitpack.io</url>
		</repository>
	</repositories>

Add it in your build.sbt at the end of resolvers:

 
    resolvers += "jitpack" at "https://jitpack.io"
        
    

Add it in your project.clj at the end of repositories:

 
    :repositories [["jitpack" "https://jitpack.io"]]
        
    

Step 2. Add the dependency

	dependencies {
		implementation 'com.github.chenenyu:img-optimizer-gradle-plugin:1.2.0'
	}
	dependencies {
		implementation("com.github.chenenyu:img-optimizer-gradle-plugin:1.2.0")
	}
	<dependency>
	    <groupId>com.github.chenenyu</groupId>
	    <artifactId>img-optimizer-gradle-plugin</artifactId>
	    <version>1.2.0</version>
	</dependency>

                            
    libraryDependencies += "com.github.chenenyu" % "img-optimizer-gradle-plugin" % "1.2.0"
        
        

                            
    :dependencies [[com.github.chenenyu/img-optimizer-gradle-plugin "1.2.0"]]
        
        

Readme


maven License Android Arsenal GitHub stars

中文版

img-optimizer-gradle-plugin

A gradle plugin for optimizing PNGs, effectively reducing APK size. Both extreme compression and lossless compression are available.

Available OS

Tested on macOSwindows10Ubuntu16.04LTS(amd64). If you have any questions, plz open issues.

How to use

Add the following Gradle configuration to your build.gradle:

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        ...
        classpath 'com.chenenyu:img-optimizer:latestVersion'
    }
}

Then in your moudle's build.gradle:

apply plugin: 'img-optimizer'

Now you can see the tasks in task tree:
Task
Double click to execute the task.

Configuration

You can add the following options to custom the task:

optimizerOptions {
    triggerSize 5
    type "lossy"
    suffix "_opt"
}
  1. triggerSize Used for filtering pictures. Picture whose size is less than this option will be ignored. Defaults to 0.
  2. type Now supports"lossy" and "lossless""lossy" means extreme compression(recommend, default, fast, effective),"lossless" means loseless compression(slow, inefficient)。
  3. suffix The suffix of the picture which has been optimized. If "_opt",the optimizer will generate a new picture orignal_opt.png for original.png. Defaults to null.

Preview

|Original png|Extreme compression(lossy)|Loseless compression(lossless)| |:---:|:---:|:---:| |526K|195K(reduce 63%)|473K(reduce 10%)| |原图|极限压缩|无损压缩|

Note

If there are multiple modules in your project, please add the optimizer in where you want to execute optimization since each module is independent. The optimizer will generate log file in the root directory of current module.

License

Apache 2.0