Here's a gallery of pictures showing what can be achieved with some of Chafa's numerous command-line options. Enjoy!
Color modes (-c)
This option controls what kind of palette to use, and indirectly, which ANSI color codes to emit. "Full" is an alias for 24-bit color, which is only supported by the most modern terminal emulators. "240" uses a fixed 240-color palette that is a bit more common. "16" uses control codes popularized by AIXterm and should work with most terminal emulators and some older terminals. "2" relies on the terminal's default foreground and background colors only, with control codes to invert the colors. "none" allows no color control codes whatsoever.
Do take note of the appropriate use of thin line characters, especially diagonals, in this example!
Color spaces (--color-space)
data:image/s3,"s3://crabby-images/0a6f4/0a6f45c21bd3503c49c5b3ecd4a74f60a6eeb52e" alt="Input image"
data:image/s3,"s3://crabby-images/12f8d/12f8db587f1c894809c73fdc89ecc00d852929f1" alt="Terminal graphics with 240 RGB colors"
data:image/s3,"s3://crabby-images/9bd5b/9bd5bc4755d0d405c775d7f91ef4167e2a11dab4" alt="Terminal graphics with 240 DIN99d colors"
data:image/s3,"s3://crabby-images/6bbae/6bbae5660b4a2d091bee6e218d7daf5633891c00" alt="Terminal graphics with 16 RGB colors"
data:image/s3,"s3://crabby-images/b29a2/b29a2455f3ee127d76072c78d29fbb4a2f4ed268" alt="Terminal graphics with 16 DIN99d colors"
The color space is relevant to color modes with restricted palettes (which is every mode except for the "full" 24-bit mode). It governs how the approximate colors are picked. DIN99d yields a more accurate color representation. However, the conversions involved are costly, so RGB is the default.
Dithering (--dither)
data:image/s3,"s3://crabby-images/be9f7/be9f72df4903c167ecdff25b3e34b816b3bde673" alt="Input image"
data:image/s3,"s3://crabby-images/1df83/1df8321db63bf0d335e1de08afd90d8ce8ff6933" alt="Terminal graphics, undithered"
data:image/s3,"s3://crabby-images/249d2/249d28b54250b3c1ec9b0d8ec418371f15266b6b" alt="Terminal graphics with ordered dithering"
data:image/s3,"s3://crabby-images/c99a5/c99a5c19db708543fe65bfd2a701168ad09b6de8" alt="Terminal graphics with error diffusion dihering"
Images can be dithered to produce perceptually smoother gradients. Two strategies are supported: "ordered" aka "bayer", which applies a uniform intensity-modulating pattern, and "diffusion" aka "fs" (Floyd-Steinberg), which calculates the color deviance at each pixel and compensates by spreading a correction factor to its neighbors.
Dithering grain shape (--dither-grain)
data:image/s3,"s3://crabby-images/28449/2844956716c82fcb64bda42055811853503f542c" alt="Input image"
data:image/s3,"s3://crabby-images/4bc93/4bc93d8d67e3573e6a66988250c9185bed64c60c" alt="Terminal graphics dithered with 4x4 grain"
data:image/s3,"s3://crabby-images/28504/28504c5d1e5eb5b50806f22b2ef72fbd7893a98c" alt="Terminal graphics dithered with 8x4 grain"
data:image/s3,"s3://crabby-images/fa61b/fa61b8098d475cdf5143842c9ada268f30c00360" alt="Terminal graphics dithered with 8x8 grain"
Dithering works on rectangles that can be bigger than a single pixel. This enables you to align the dithered grid with the virtual resolution of the output symbols. Chafa's character cells correspond to 8x8 pixel rectangles. 4x4 grains will thus correspond to "quad" block symbols, 8x4 grains will match up with "vhalf" symbols, and 8x8 grains will modulate entire character cells.
Dithering intensity (--dither-intensity)
data:image/s3,"s3://crabby-images/289c1/289c1661386af5f83789c13c2493f793d1456d0a" alt="Input image"
data:image/s3,"s3://crabby-images/f81b1/f81b184b2f69dc1f99efc05e1607ade72827067e" alt="Terminal graphics with 0.5 intensity ordered dithering"
data:image/s3,"s3://crabby-images/e1f84/e1f84568ab191e45d843a20681ee172ff88d6500" alt="Terminal graphics with 1.0 intensity ordered dithering"
data:image/s3,"s3://crabby-images/3a371/3a371b14a0078ff254e5be1d135580460785ceae" alt="Terminal graphics with 2.0 intensity ordered dithering"
data:image/s3,"s3://crabby-images/c9243/c924375802def38121267314e71cf4ee5463a180" alt="Terminal graphics with 1.0 intensity Floyd-Steinberg dithering"
data:image/s3,"s3://crabby-images/0874f/0874f896e83e2525eb12bb2716cbda67f48285a4" alt="Terminal graphics with 2.0 intensity Floyd-Steinberg dithering"
When enabled, dithering can be made more or less aggressive with this factor. 1.0 is neutral.
Fill symbols (--fill)
Some images will produce a lot of flat space with no symbols in it. This
option allows you to fill these spaces with symbols that modulate the
perceptual color. It can also be used together with --symbols none
to
create a very old-school look. It supports the same symbol classes as
--symbols
does.
Preprocessing (-p)
This option automatically boosts contrast and saturation in reduced-color
modes. This makes most images more legible and can improve color accuracy.
It's on by default, but if you are doing your own preprocessing or want to
use a different approach (e.g. with a different color space or dithering),
you can turn it off with -p off
.
Work factor (-w)
The work factor is a measure of how much CPU time and memory to spend refining the output. The factor ranges from 1 to 9. Lower values are fast, but produce rougher output, while the highest values are slower but more precise. The default factor is 5.
Some images are more affected than others. In the above example, the difference is most noticeable along the plant's stalks and other high-contrast edges.