Skip to main content

A CLI tool to render unicode art in the terminal

Project description

CliRenderer

A text renderer that renders unicode art from images to the terminal

Installation

Install the latest version with: pip install CliRenderer

Usage

See clirender --help for a list of options and arguments.

Notice when reading output

Linux

cat the contents like this cat outfile

Windows Powershell

cat the contents like this Get-Content outfile -encoding UTF8

This is because the contents of the output files will be encoded in utf-8. powershell defaults to utf-7 for some reason.


Example Outputs:

img.png Original image from pexels

img.png Original image from pexels

How It Works

Disclaimer

I am terrible at explaining things.


This program mainly relies on unicode braille characters to represent pixels.

Braille characters are basically a 2x4 grid of dot(s).

First, I grayscale the image, this is important for later,

then I basically divided the image into many cells of 2x4 pixels width and height.

After because each image cell consists of 2x4 pixels that is grayscale, I can easily find the middle color. Cycling through the cell, we can now convert the pixels into binary. Pixel in the cell that are darker than the middle will be False Pixels that are lighter wil be True Now we have a boolean array representing bits.

The table below represent how each pixel in the cell correspond to its position in the array.

1 5
2 6
3 7
4 8

Coincidentally, braille characters are ordered the similarly in unicode.

1 4
2 5
3 6
7 8

However, for some reason, 7 is inserted before 4.

So we can just account for that by rearranging the array before converting it into binary like so:

#pixels is the boolean array
converted = [pixels[7], pixels[3], pixels[6], pixels[5], pixels[4], pixels[2], pixels[1], pixels[0]]

After converting the array into binary, the binary is the index of the character in the string we need.

Coloring

During the process above, another image is generated, we call this a mask,

where it is white, the pixel will be represented by the braille character.

where it is black, the pixel will be represented by the background color.

We once again divide the image up into cells,

iterating through the pixels in the cells, we set 2 colors for each cell: fore and back.

The fore color is calculated by averaging the color from the image where pixel in the mask is white.

The back color is calculated by similarily but using where the pixel in the mask is black.

Then using rich.py, we can color the foreground and background of each character using the fore and back character of each cell.

More characters

braille characters unfortunately do not really take up the entire character space given to them.

This makes less noticeable, however we can subsitute some of the braille characters to give them more "weight".

For example, I replaced "⣀" with "▂".

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

CliRenderer-0.1.6.post4.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

CliRenderer-0.1.6.post4-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file CliRenderer-0.1.6.post4.tar.gz.

File metadata

  • Download URL: CliRenderer-0.1.6.post4.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for CliRenderer-0.1.6.post4.tar.gz
Algorithm Hash digest
SHA256 772b99e39a7ef444a94c3bcd9a0d594d2513ef7bad77a02e535de03ecd2bce98
MD5 81123d1bbdb98d2183ea49dbc5733654
BLAKE2b-256 10122caaba7cb84adb6a571a69384da361187042aaf22197d5af257c5947d278

See more details on using hashes here.

File details

Details for the file CliRenderer-0.1.6.post4-py3-none-any.whl.

File metadata

File hashes

Hashes for CliRenderer-0.1.6.post4-py3-none-any.whl
Algorithm Hash digest
SHA256 ae5d201b25a170e2925b4321b893074f74849d479b7f7e9a4f36bd02e408ed08
MD5 67336b49a7ae6c63098f713b9d232484
BLAKE2b-256 0c43ef5c21faf628c293a1d14c7639eb3d94960d2176c8f63117ae892ec774e2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page