android-close-pixelate
data:image/s3,"s3://crabby-images/18f58/18f58fb70f906139ea0ab37f28e8923149651549" alt="Bintray"
This simple library allows you to easily create and combine various pixelation effects.
Based on a wonderful script by David DeSandro: close-pixelate.desandro.com.
You may be also be interested in the iOS/Swift version of the library.
Examples
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(48)
.setSize(50)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(48)
.setOffset(24)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(8)
.setSize(6)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(32)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setOffset(15)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(26)
.setOffset(13)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(18)
.setOffset(10)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(12)
.setOffset(8)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(48)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(48)
.setOffset(12)
.setAlpha(0.5f)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(48)
.setOffset(36)
.setAlpha(0.5f)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(16)
.setSize(8)
.setOffset(4)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(6)
.setOffset(8)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(9)
.setOffset(16)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(12)
.setOffset(24)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setSize(9)
.setOffset(0)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(24)
.setSize(25)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(24)
.setOffset(12)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(24)
.setAlpha(0.6f)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(32)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setOffset(16)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(32)
.setOffset(0)
.setAlpha(0.5f)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(16)
.setSize(9)
.setOffset(0)
.setAlpha(0.5f)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(24)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(24)
.setSize(9)
.setOffset(12)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(48)
.setOffset(24)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Circle)
.setResolution(48)
.setOffset(0)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(16)
.setSize(15)
.setOffset(0)
.setAlpha(0.6f)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(16)
.setSize(15)
.setOffset(8)
.setAlpha(0.6f)
.build());
Pixelate.render(bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(48)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(12)
.setSize(8)
.build(),
new PixelateLayer.Builder(PixelateLayer.Shape.Diamond)
.setResolution(12)
.setSize(8)
.setOffset(6)
.build());
Download
The library is available at jcenter:
repositories {
jcenter()
}
dependencies {
compile 'io.uuddlrlrba:close-pixelate:1.2.0'
}
Usage
There are several Pixelate.from*
methods in the
Pixelate
class, allowing to create a pixelated bitmap from other bitmaps, resources, input streams, etc:
Bitmap pixelated = new Pixelate.fromBitmap(
bitmap,
new PixelateLayer.Builder(PixelateLayer.Shape.Square)
.setResolution(48)
.setSize(50)
.build()
);
You also can draw directly on a bitmap or on a canvas, using Pixelate.render*
methods.
There are three basic layer types:
Original |
Square |
Diamond |
Circle |
data:image/s3,"s3://crabby-images/2bc7b/2bc7b9fb380fce69a62e7be67e481de21a5c2821" alt="jamie" |
data:image/s3,"s3://crabby-images/56d3b/56d3bf98b51d0561fd9d5100e6203c14315e50ef" alt="simple-lo-square" |
data:image/s3,"s3://crabby-images/4e8b3/4e8b34138e5291631de7f450a489f255480bd5e6" alt="simple-lo-diamond" |
data:image/s3,"s3://crabby-images/a42b7/a42b762344e71bd14f6dfcb7c1e5ed00c7be5fe3" alt="simple-lo-circle" |
You can change size, resolution, offset and alpha parameters of each layer:
resolution = 10 |
resolution = 25 |
resolution = 20, size = 50, alpha = 0.5 |
data:image/s3,"s3://crabby-images/56d3b/56d3bf98b51d0561fd9d5100e6203c14315e50ef" alt="simple-lo-square" |
data:image/s3,"s3://crabby-images/dbf90/dbf902b853177c96a44f1caa0a4d94e9c14356ff" alt="simple-hi-square" |
data:image/s3,"s3://crabby-images/cd502/cd502e1fff9ac7b5631b9a7c7c4650a2a6d7b932" alt="jamie-new" |
You can also combine several layers into one image:
square, resolution = 25 |
|
diamond, resolution = 10 |
|
|
data:image/s3,"s3://crabby-images/dbf90/dbf902b853177c96a44f1caa0a4d94e9c14356ff" alt="simple-hi-square" |
+ |
data:image/s3,"s3://crabby-images/4e8b3/4e8b34138e5291631de7f450a489f255480bd5e6" alt="simple-lo-diamond" |
= |
data:image/s3,"s3://crabby-images/66f75/66f75b4fe21b8a3d1a50194c8345ed3e5c164edb" alt="sample-multilayer" |