Skip to main content

An image viewer for the command line

Project description

Author: Johannes Hansen

Why?

If you are like me, you spend a lot of time in command line environments. One of the few things that are hard to deal with in such an environment is images.

This little tool is meant to allow for quick viewing of image files in the command line.

The image is rendered using a combination of background color, foreground color and unicode character for each character cell to optimally represent the original pixels. The challenge is the limited color palette of 256 colors.

In the simplest case, each character cell represents one pixel. However, the resolution can be increased by printing unicode characters that better capture the structure of the image. Alternatively, the color accuracy can be improved by mixing two available colors in foreground and background, thus losing the gained resolution.

The default mode attempts to optimize the rendering by optimizing resolution in areas of high detail, and optimizing color accuracy in areas of low detail.

Installation

$ pip install vimg

Requirements

A terminal that supports 256 colors.

The script is based on curses and opencv for Python.

Usage

$ vimg path/to/image

GUI modes

Once in the GUI, you can change between different viewing modes:

Key shortcut

Mode

Description

c

color

(default) display optimal representation of image

f

fast

display image in fast mode (reduced resolution)

a

ascii

display a black-and-white representation of the image

e

edge

(experimental) edge detection based rendering

+/-

zoom in/out (by 30%)

h j k l
or arrow keys

move view (by 10%)

0

reset zoom

r

refresh the screen

q

quit

Notes

The results will be better if you use a font that correctly displays unicode block element characters with the full line height, such as DejaVu Sans.

Limitations

The script currently only supports image files that are natively supported by OpenCV (.jpg, .png, .bmp).

To Do

Future plans include:

  • Support for more image file types, e.g. .gif

  • Improvement of the edge detection mode

  • Make opencv dependency optional

  • Improve color gradients at contrast-rich edges

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

vimg-0.4.3.tar.gz (15.3 kB view details)

Uploaded Source

File details

Details for the file vimg-0.4.3.tar.gz.

File metadata

  • Download URL: vimg-0.4.3.tar.gz
  • Upload date:
  • Size: 15.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for vimg-0.4.3.tar.gz
Algorithm Hash digest
SHA256 6e050a2a31f6534a4828a8a82f16db481574c6bb9cb16f0182ddcd2258a84b0a
MD5 bc4bd456b45a4e79f382a54c790fd30d
BLAKE2b-256 bd7247a805904c0338b8529e84682223452a3c2321a16067f229157ef86de5a8

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