Skip to main content

Display images in the terminal

Project description

Term-Image

Display images in the terminal with Python

📖 Docs ║ 🏫 Tutorial

Documentation Status

Contents

⚠️ NOTICE!!! ⚠️

The image viewer (CLI and TUI) has been moved to termvisage.

Installation

Requirements

  • Operating System: Unix / Linux / Mac OS X / Windows (limited support, see the FAQs)

  • Python >= 3.7

  • A terminal emulator with any of the following:

    Plans to support a wider variety of terminal emulators are in motion (see Planned Features).

Steps

The latest stable version can be installed from PyPI with:

pip install term-image

The development version can be installed with:

pip install git+https://github.com/AnonymouX47/term-image.git

Supported Terminal Emulators

See here for a list of tested terminal emulators.

If you've tested this library on any other terminal emulator that meets the requirements for any of the render styles, please mention the name (and version) in a new thread under this discussion.

Also, if you have any issue with terminal support, you may report or check information about it in the discussion linked above.

Features

  • Multiple image formats (basically all formats supported by PIL.Image.open())
  • Multiple image source types: PIL image instance, local file, URL
  • Multiple image render styles (with automatic support detection)
  • Support for multiple terminal graphics protocols: Kitty, iTerm2
    • Exposes various features of the protocols
  • Transparency support (with multiple options)
  • Animated image support (including transparent ones)
    • Multiple formats: GIF, WEBP, APNG (and possibly more)
    • Fully controllable iteration over rendered frames of animated images
    • Image animation with multiple parameters
  • Integration into various TUI / terminal-based output libraries.
  • Terminal size awareness
  • Automatic and manual image sizing
  • Horizontal and vertical alignment
  • Automatic and manual font ratio adjustment (to preserve image aspect ratio)
  • and more... 😁

Demo

Check out this image viewer based on this library.

Quick Start

Creating an instance

  1. Initialize with a file path:

    from term_image.image import from_file
    
    image = from_file("path/to/image.png")
    
  2. Initialize with a URL:

    from term_image.image import from_url
    
    image = from_url("https://www.example.com/image.png")
    
  3. Initialize with a PIL (Pillow) image instance:

    from PIL import Image
    from term_image.image import AutoImage
    
    img = Image.open("path/to/image.png")
    image = AutoImage(img)
    

Drawing/Displaying an Image

There are two basic ways to draw an image to the terminal screen:

  1. Using the draw() method:

    image.draw()
    

    NOTE: draw() has various parameters for render formatting.

  2. Using print() with an image render output:

    print(image)  # without formatting
    # OR
    print(f"{image:>200.^100#ffffff}")  # with formatting
    

For animated images, only the former animates the output, the latter only draws the current frame.

See the tutorial for a more detailed introduction.

Usage

🚧 Under Construction - There will most likely be incompatible changes between minor versions of version zero!

If you want to use this library in a project while it's still on version zero, ensure you pin the dependency to a specific minor version e.g >=0.4,<0.5.

See the docs for the User Guide and API Reference.

Contribution

Please read through the guidelines.

For code contributions, you should also check out the Planned Features. If you wish to work on any of the listed features/improvements, please click on the linked issue or go through the issues section and join in on an ongoing discussion about the task or create a new issue if one hasn't been created yet, so that the implementation can be discussed.

Hint: You can filter issues by label or simply search using the features's description.

Thanks! 💓

Planned Features

See here.

Known Issues

See here.

FAQs

See the FAQs section of the docs.

Credits

The following projects have been (and are still) crucial to the development of this project:

The logo was composed using resource(s) from the following source(s):

Sponsor This Project

Buy Me A Coffee

Any amount will go a long way in aiding the progress and development of this project. Thank you! 💓

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

term_image-0.7.2.tar.gz (63.9 kB view details)

Uploaded Source

Built Distribution

term_image-0.7.2-py3-none-any.whl (64.7 kB view details)

Uploaded Python 3

File details

Details for the file term_image-0.7.2.tar.gz.

File metadata

  • Download URL: term_image-0.7.2.tar.gz
  • Upload date:
  • Size: 63.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.11.5

File hashes

Hashes for term_image-0.7.2.tar.gz
Algorithm Hash digest
SHA256 07320573baa667dcde145d55e94769cbaafeea43b61245245153ff5075b55ffb
MD5 52e6da90ead41557532f6f7d81c5142e
BLAKE2b-256 39877e8ba20702294ee8b750427c2600308c20f39ddf3b0f73250dc43ef13038

See more details on using hashes here.

File details

Details for the file term_image-0.7.2-py3-none-any.whl.

File metadata

  • Download URL: term_image-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 64.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.11.5

File hashes

Hashes for term_image-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 97d9dba5afcf3989a23b1868adc5b2de3126d1ef915df2a7859f67fbdd613e15
MD5 bb767c037bf754daa0991385c28cf140
BLAKE2b-256 8f51986c06467bb274f7c8d5bdb7a60bfb628b2cdf20ee30bc28ce6c4190f0ba

See more details on using hashes here.

Supported by

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