cocoa-close-pixelate
data:image/s3,"s3://crabby-images/5fa22/5fa22681ca4c95db9bf247e392bf81356c39c208" 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 Android/Java version of the library.
Examples
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.diamond, resolution: 48, size: 50),
PixelateLayer(.diamond, resolution: 48, offset: 24),
PixelateLayer(.diamond, resolution: 8, size: 6))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 32),
PixelateLayer(.circle, resolution: 32, offset: 15),
PixelateLayer(.circle, resolution: 32, size: 26, offset: 13),
PixelateLayer(.circle, resolution: 32, size: 18, offset: 10),
PixelateLayer(.circle, resolution: 32, size: 12, offset: 8))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 48),
PixelateLayer(.diamond, resolution: 48, offset: 12, alpha: 0.5),
PixelateLayer(.diamond, resolution: 48, offset: 36, alpha: 0.5),
PixelateLayer(.diamond, resolution: 16, size: 8, offset: 4))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.circle, resolution: 32, size: 6, offset: 8),
PixelateLayer(.circle, resolution: 32, size: 9, offset: 8),
PixelateLayer(.circle, resolution: 32, size: 12, offset: 24),
PixelateLayer(.circle, resolution: 32, size: 9, offset: 0))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.diamond, resolution: 24, size: 25),
PixelateLayer(.diamond, resolution: 24, offset: 12),
PixelateLayer(.square, resolution: 24, alpha: 0.6))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 32),
PixelateLayer(.circle, resolution: 32, offset: 16),
PixelateLayer(.circle, resolution: 32, offset: 0, alpha: 0.5),
PixelateLayer(.circle, resolution: 16, size: 9, offset: 0, alpha: 0.5))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.circle, resolution: 24),
PixelateLayer(.circle, resolution: 24, size: 9, offset: 12))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 48, offset: 12),
PixelateLayer(.circle, resolution: 48, offset: 0),
PixelateLayer(.diamond, resolution: 16, size: 15, offset: 0, alpha: 0.6),
PixelateLayer(.diamond, resolution: 16, size: 15, offset: 8, alpha: 0.6))
Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 48),
PixelateLayer(.diamond, resolution: 12, size: 8),
PixelateLayer(.diamond, resolution: 12, size: 8, offset: 6))
Download
The library is available via cocoapods:
pod 'ClosePixelate', '1.1.2'
Usage
There are several Pixelate.create*
methods in the
Pixelate
class, allowing to create a pixelated bitmap from CGImage
:
let pixelated = Pixelate.create(pixels: bitmap,
layers: PixelateLayer(.square, resolution: 48),
PixelateLayer(.diamond, resolution: 48, offset: 12, alpha: 0.5),
PixelateLayer(.diamond, resolution: 48, offset: 36, alpha: 0.5),
PixelateLayer(.diamond, resolution: 16, size: 8, offset: 4))
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/9f27f/9f27fdd3114b1d5b0cf067dcd7bb64242e118c67" alt="jamie" |
data:image/s3,"s3://crabby-images/ccb60/ccb60d58d975f262fedac89d598255633fafc2b5" alt="simple-lo-square" |
data:image/s3,"s3://crabby-images/93727/93727d8aff2258b428a88f9a19120fea93146e9b" alt="simple-lo-diamond" |
data:image/s3,"s3://crabby-images/8100f/8100f5328cf3d06400258f8527d47770576e6295" 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/ccb60/ccb60d58d975f262fedac89d598255633fafc2b5" alt="simple-lo-square" |
data:image/s3,"s3://crabby-images/1b44f/1b44fd82d7d410660043bce23e809d11572a0445" alt="simple-hi-square" |
data:image/s3,"s3://crabby-images/5e275/5e275b755368ee14dbf249dfec8d218c3e112e45" alt="jamie-new" |
You can also combine several layers into one image:
square, resolution = 25 |
|
diamond, resolution = 10 |
|
|
data:image/s3,"s3://crabby-images/1b44f/1b44fd82d7d410660043bce23e809d11572a0445" alt="simple-hi-square" |
+ |
data:image/s3,"s3://crabby-images/93727/93727d8aff2258b428a88f9a19120fea93146e9b" alt="simple-lo-diamond" |
= |
data:image/s3,"s3://crabby-images/87598/87598c9d61729dd472426ba2749cd2a9a1405d1a" alt="sample-multilayer" |