Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mjrlowe/terminal_images
A Deno module and CLI tool for printing images to the console. 🖼️
https://github.com/mjrlowe/terminal_images
cli deno deno-module image terminal typescript
Last synced: about 2 months ago
JSON representation
A Deno module and CLI tool for printing images to the console. 🖼️
- Host: GitHub
- URL: https://github.com/mjrlowe/terminal_images
- Owner: mjrlowe
- License: mit
- Created: 2020-10-25T15:15:12.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-04-03T19:42:19.000Z (over 1 year ago)
- Last Synced: 2024-09-17T15:12:01.072Z (3 months ago)
- Topics: cli, deno, deno-module, image, terminal, typescript
- Language: TypeScript
- Homepage:
- Size: 569 KB
- Stars: 51
- Watchers: 1
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-deno - terminal_images - A Deno module and CLI tool for displaying images in the terminal. (Modules / CLI utils)
README
# terminal_images
**terminal_images** is a Deno module and CLI tool, written in TypeScript, for
displaying images in the terminal.It supports PNGs, JPGs, GIFs and pixel arrays, and has support for animated GIFs
and transparent images.To install the CLI tool, run the following from the command line:
```shell
deno install --allow-read --allow-net -f -n terminal_images https://deno.land/x/[email protected]/cli.ts
```_Alternatively, terminal\_images can be installed from nest.land at the URL_
`https://x.nest.land/[email protected]/cli.ts`.Then run
```shell
terminal_images https://deno.land/images/artwork/hashrock_simple.png
```...and you should see something like this:
![basic terminal Deno image](./examples/basic_demo.png)
_Note that the size might be different, as by default it adapts to the size of
your terminal._You can also use the module, which exports two async functions:
`getImageStrings` and `printImage`, which both take in an object with the same
properties.Here is an example of how you can use it:
```ts
import { printImage } from "https://deno.land/x/[email protected]/mod.ts";printImage({
// replace this with the URL or local file path of the image you want to print out
path: "https://deno.land/images/artwork/deno_city.jpeg",// by default the size of the image is set to fit in the terminal,
// but you can override it with the width property
width: 56,
});
```This should output something like this:
![pixelated terminal image](./examples/color_terminal_output_example.png)
## API
| Property | Type | Description | Default Value | CLI Flag |
| ----------------------- | ------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------- | ------------------------------------------ |
| `path` | string | The path or URL of the input image. | No default | `--file` or `-f` or the first CLI argument |
| `rawFile` | Uint8Array | The raw data of the input image. (You can use this instead of `path`) | No default | [No CLI flag] |
| `rawPixels` | {data: Uint8Array; width: number; height: number} | The rgb(a) data (as well as the height and width) of the input image. (You can use this instead of `path` or `rawFile`) | No default | [No CLI flag] |
| `color` | boolean | Whether the output should be in color. | `true` | `--no-color` or `-n` to turn off color |
| `characterMap` | string \| string[] | See the section on character maps for more information. | By default a character map isn't used, and high-res mode is used instead. | `--character-map` or `-m` |
| `inverted` | boolean | Whether the character map should be mapped from light to dark instead of dark to light. Normally you will want to set this to true if your terminal is in a dark theme. | `false` | `--inverted` or `-i` |
| `width` | number | The number of characters wide the image should be. | The maximum value where all of the image is visible at once | `--width` or `-w` |
| `animationLoops` | number | The number of times the animation loops, if the image is animated. | 1 | `--animation-loops` or `-l` |
| `transparencyThreshold` | number | The alpha threshold for considering a pixel transparent or opaque. Set to 0 to ignore transparency and 255 to set anything with even a little transparency to be completely transparent. Note that the terminal can only display completely transparent and completely opaque colors. | 1 | `--transparency-threshold` or `-t` |_Because the size of the image automatically adapts to the size of your console,
the image produced will have a higher resolution (unless you have manually set
`width`) if the font size is smaller and the terminal window is larger, as more
can fit on the screen._## Character map?
The "character map" is the characters that are used to display the image. _If no
character map is specified, it will default to high(er) resolution mode--see the
module usage example above._The characters at the beginning of the character map should be the darkest and
the ones at the end be the lightest. You can switch this around by using the
`inverted` flag/property.If you are using the module, you can set the character map to an array of
strings, where each element will be used as a pixel color (rather than each
character of the string).### Some tips for using character maps:
- Simple images with recognisable shapes and high contrast work the best.
(Although if you aren't aiming for functionality, go wild!)
- Normally you will want to invert the character map if your terminal is in a
dark theme.
- You can generate ASCII art by using character maps such as `"@#?)l+-. "` and
blocky images using character maps like `█▓▒░`.
- Make sure you have escaped any characters you need to with a backslash (`\`).
- You don't have to sort your characters from darkest to lightest or vice versa.
Play around with what works for specfic images, and see if you can create any
interesting effects.
- Padding your character maps can be useful when brightness is not evenly
distributed. For example, if your image has mostly dark tones, then your
character map might have some extra spaces on the end, so that it is easier to
distinguish between darker colors than lighter ones.
- Try to make characters next to each other in the character map similar. For
example, don't put a `.` after a `'` as one is displayed much lower down than
the other.## Required Permissions
| Flag | R | Reason |
| :------------- | :-: | :--------------------------- |
| `--allow-net` | _ | To fetch images from the web |
| `--allow-read` | _ | To use images stored locally |Either `--allow-net` or `--allow-read` is needed when using `path` (`--file` in
the CLI tool). When using `rawFile` or `rawPixels` no permission flags are
required.## Examples
![Inverted image loaded from unsplash](./examples/unsplash_photo_with_inverted_character_map.png)
![Colored high-res image loaded from unsplash](./examples/small_high_res_colored_image.png)For more example outputs, have a look at the examples folder.
## Todo
- [x] Add some color
- [x] Publish to nest.land
- [x] Add support for using images loaded from the web (rather than just
locally)
- [x] Auto-detect file format (no need to rely on the file extension)
- [x] Allow the user to input an array of strings for the character map [added,
but user can't do this when using the cli]
- [x] Finish the documentation in README.md
- [x] Add jsdoc documentation in the code
- [x] Add support for unicode characters
- [x] Add high(er) resolution output mode
- [x] Correctly handle characters such as emojis that have a width that isn't 1
- [x] Add support for GIF images
- [x] Deal with transparency better
- [ ] Fix some images not displaying correct colors (incorrect black and white,
not displaying transparent)
- [ ] Fix some images displaying at the incorrect size (too large) by default
- [ ] Add some tests
- [ ] Don't count modifier characters (e.g. emoji skin tones) as separate
characters (unless they aren't modifying anything and are visible)
- [ ] Option for width as a percentage of terminal screen
- [ ] Detect whether terminal theme is light or dark automatically?
- [ ] Better error handling (e.g. 404 when fetching image)
- [ ] Add support for webp images
- [ ] Add support for TIFF images## Contributions
Contributions are welcome and greatly appreciated! Just pick something to do
(the todo list above is a good starting point) and let me know you want to work
on it by opening an issue or commenting on a relevant existing issue.If you think you have found a bug, or would like to make a suggestion, please
open an issue (after checking for similar issues).## License
**terminal_images** is under the open source MIT license. See the LICENSE file
for legal words.