chb
Finally, the solution to the problem everyone has: how to display high quality images over text mode connections like ssh!
libchb is a library that converts images to a half block unicode representation with ANSI coloring: Colored Half Blocks. It supports color bit depths of: 3, 4, 8, and 24.
Download
A beta version of the API and implementation is available: libchb.0.9.tar.gz. The library itself has no build dependencies other than standard C99, but does need a terminal that support ANSI escape codes and Unicode to work correctly. The viewer needs ImageMagick in Linux, GDI+ in Windows, and Cacoa on MacOS. Use CMake to build and check out thetest_image.c
for example usage.
Beta API reference
This is an early interface- minor changes should be expected as the library approaches 1.0. Seechb.h
and test_image.h
for details and use.
Print an image with best guesses for all parameters.
void chb_print_image(unsigned int width, unsigned int height, unsigned char const * rgb_image);Print an image, supplying parameters to configure depth and output character options.
void chb_print_image_opt(unsigned int CHB_DEPTH, unsigned int CHB_CHAR, unsigned int width, unsigned int height, unsigned char const * rgb_image);Prepare and free a frame state object for use in tracking frame data over time.
void chb_init_frame(unsigned int width, unsigned int height, chb_frame_state* state); void chb_free_frame(chb_frame_state * state);Print a single frame of a multiframe sequence, supplying parameters to configure depth and output character options.
void chb_print_frame(chb_frame_state * state, unsigned int width, unsigned int height, unsigned char const * rgb_image);Print a single frame of a multiframe sequence, supplying parameters to configure depth, output character, palette, and frame replace options.
void chb_print_frame_opt(chb_frame_state * state, unsigned int CHB_DEPTH, unsigned int CHB_CHAR, unsigned int CHB_PALETTE, unsigned int CHB_REPLACE, unsigned int width, unsigned int height, unsigned char const * rgb_image);
Examples images
Input image
data:image/s3,"s3://crabby-images/55582/555829cbd52c6799caf03e8441ab43e817fd736d" alt=""
chblib 24bit
data:image/s3,"s3://crabby-images/c907b/c907b7bb08d92470a0b803bcb66546c0b65e3d4a" alt=""
chblib 8bit
data:image/s3,"s3://crabby-images/5c4e3/5c4e3d148090fd8ca2ee4875c0a96c751ce8cd4b" alt=""
chblib 4bit
data:image/s3,"s3://crabby-images/68096/68096f04a504b44e944f82da76c74559c8b1b073" alt=""
chblib 3bit
data:image/s3,"s3://crabby-images/8ba00/8ba00bcab02ea68e56a6f488bf01f488ab3df364" alt=""