Dithor

Metadata
creation year: 2022

What is this library

Basic principles

This library rewrite an image given as input using only two colors a la dithering.

The image is spit in many squares of 5x5 pixels for high resolution mode, or 15x15 pixels for low resolution mode. For each of those squares the average relative luminance is calculated.

This luminance is then used to assign a level to the square. The level is between 0 and 9, 0 for completely bright and 9 fully dark.

High resolution

The content of the square is then filled with the following pattern (depending on the level):

dithor gradiant for levels

Here's a picture showing the same patterns on a bigger surface:

dithor gradiant big surface

Finally here's an example using the painting "The swan, no 1" from Hilma af Klint:

dithor version of the swan

Low resolution

The content of the square is then filled with the following pattern (depending on the level):

dithor gradiant for level

And here's the same example in low res:

dithor version of the swan in low res

Using colors

When the third parameter is true the output will be in color, the brightest and darkest colors from the 25 or 225 pixels are used to fill the patterns showed above.

Example in high res:

dithor version of the swan in colors

Example in low res:

dithor version of the swan in colors and low res

How to use it

Crate.io

To use this library you can simply call it using:

dithor::dithor("input.jpg", "output.jpg", true, true, true);

Params