11 releases (6 stable)

1.4.0 Dec 18, 2021
1.3.0 Dec 13, 2020
1.2.1 Oct 28, 2020
1.1.0 Sep 18, 2020
0.1.1 May 2, 2019

#753 in Command line utilities

Download history 93/week @ 2022-10-15 88/week @ 2022-10-22 96/week @ 2022-10-29 102/week @ 2022-11-05 126/week @ 2022-11-12 119/week @ 2022-11-19 106/week @ 2022-11-26 100/week @ 2022-12-03 81/week @ 2022-12-10 110/week @ 2022-12-17 80/week @ 2022-12-24 109/week @ 2022-12-31 90/week @ 2023-01-07 94/week @ 2023-01-14 95/week @ 2023-01-21 142/week @ 2023-01-28

440 downloads per month

MIT and LGPL-3.0-or-later

341 lines


A small command-line application to view images from the terminal written in Rust. It is basically the front-end of viuer. It uses either iTerm or Kitty graphics protocol, if supported. If not, lower half blocks (▄ or \u2584) are displayed instead.

Based on the value of $TERM, viuer decides which protocol to use. For half blocks, $COLORTERM is inspected. If it contains either truecolor or 24bit, truecolor (16 million colors) will be used. If not, it will fallback to using only ansi256. A nice explanation can be found in this gist.


  • Native iTerm and Kitty support
  • Animated GIF support
  • Accept media through stdin
  • Custom dimensions
  • Transparency


Installation from source requires a local Rust environment.

git clone https://github.com/atanunq/viu.git

# Build & Install
cd viu/
cargo install --path .

# Use
viu img/giphy.gif

Or without cloning:

cargo install viu


A precompiled binary can be downloaded from the release page. GPG fingerprint is B195BADA40BEF20E4907A5AC628280A0217A7B0F.



Available in brew.

brew install viu

Arch Linux

Available in community/viu.

pacman -S viu


Available in graphics/viu.



On a Kitty terminal:


On a Mac with iTerm:


Using half blocks (Kitty protocol and tmux do not get along):




Ctrl-C was pressed to stop the GIFs.

When viu receives only one file and it is GIF, it will be displayed over and over until Ctrl-C is pressed. However, when couple of files are up for display the GIF will be displayed only once.

iTerm note

iTerm can handle GIFs by itself with better performance, but configuration through --once and --frame-rate will have no effect there.

Aspect Ratio

If no flags are supplied to viu it will try to get the size of the terminal where it was invoked. If it succeeds it will fit the image and preserve the aspect ratio. The aspect ratio will be changed only if both options -w and -h are used together.

Command line options

    viu [FLAGS] [OPTIONS] [FILE]...
    When FILE is -, read standard input.

    -b, --blocks         Force block output
    -m, --mirror         Display a mirror of the original image
    -n, --name           Output the name of the file before displaying
    -1, --once           Only loop once through the animation
    -r, --recursive      Recurse down directories if passed one
    -s, --static         Show only first frame of gif
    -t, --transparent    Display transparent image with transparent background

    -f, --frame-rate <frames-per-second>    Play gif at the given frame rate
    -h, --height <height>    Resize the image to a provided height
    -w, --width <width>      Resize the image to a provided width

    <FILE>...    The image to be displayed


~178K SLoC