Home

Awesome

Android Arsenal

Drawable Optimizer

Gradle plugin to optimize png files and reduce resultant apk size within an Android project.

How it works ?

With this plugin you will be able to optimize the png files size inside your AndroidStudio project. It works over the folder in which the resource merging was executed, by default in a Mac OSX system is app\build\intermediates\res\merged.

By doing this, all original png files are kept under /res folder and this optimization could be undone just cleaning the project.

In order to perform an optimization task, this plugin offers 2 different ways of file compression:

Why should I use this plugin ?

You can find an explanation from Colt McAnlis about why you should optimize your pngs Reducing PNG file Size and Smaller PNGs, and Android’s AAPT tool

Taste

OriginalOptimized
525.51k473.20k
Original ImageOptimized Image

Usage

Just click on Sync project with gradle files button

Download & Installation

In build.gradle

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'org.fabiomsr:drawable-optimizer-gradle-plugin:1.0.4'
    }
}

And in app\build.gradle

// Make sure this line comes *after* you apply the Android plugin (apply plugin: 'com.android.application')
apply plugin: 'org.fabiomsr.drawableoptimizer'

Configuration

No configuration is needed by default, but if you want you can configure the following parameters. Every time the configuration changes the project must be cleaned.

In app\build.gradle

drawableOptimizer {
    optimizer = 'zopfli'
    compressionLevel = 9
    iterations = 15
    onlyOnRelease = true
    logLevel = 'info'
}
ParameterDescriptionValuesDefault Value
optimizerCompressor to usezopfli or pngtasticzopfli
compressionLevelCompression level (useful for pngtastic compressor)0-9 allowedBrute forces with every allowed value
iterationsCompression iterations number (useful for zopfli)> 015
onlyOnReleaseOnly release signed optimizationtrue or falsefalse
logLevelOutput Logging levelnone, debug, info or errorinfo

License

Copyright 2016 Fabio Santana (fabiomsr)

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.