plutonem
plutonem copied to clipboard
A C, C++, Rust and COBOL library to draw graphics with pixels in the terminal
data:image/s3,"s3://crabby-images/2fcd7/2fcd7323b66146bf8d7866b6c63ccc69fc3f432e" alt=""
A library to draw graphics with pixels in the terminal
Who needs a GUI when you have a terminal ?
Building
To generate libpluto.a
, run:
$ make
To install it so that your compiler can use it directly, run:
# make install
To compile some examples, run:
$ make exp
Pre-compiled library files are available in the releases tab (only for Linux x86-64)
Using the library
- Include the pluto header in your source file
#include <path to pluto.h> // do #include <pluto.h> if the lib is already installed
- Write your source code. An example program which draws a line: Documentation for the library is in src/pluto.h where functions and structures have been commented
#include <stdlib.h>
#include "pluto.h" /* Change path if needed */
int main()
{
pluto_init_window(); /* Initialize pluto */
pluto_save_screen(); /* Save screen */
for (;;)
{
for (int i = 0; i < _pluto_canvas.cheight; i++)
{
for (int j = 0; j < _pluto_canvas.cwidth; j++)
{
pluto_set_cpix(j, i, rand() % 256, rand() % 256, rand() % 256); /* Set pixel with random colours */
}
}
pluto_write_out(); /* Write to output buffer */
pluto_render(); /* Render the output buffer */
}
pluto_deinit();
return 0;
}
- Link the library generated, for example:
$ gcc -o program program.c -lpluto # install it before or use -L<lib_folder_path>
- You're done! Just run your program now!
Comments in the pluto.h file describe what each function/data structure does
Perlin noise using plutonem
data:image/s3,"s3://crabby-images/f6c09/f6c0978550b16059a13a319fef9741b796f70a06" alt=""
Mandelbrot (examples/mandelbrot.c)
data:image/s3,"s3://crabby-images/60a8f/60a8fbf277a4c61e34afc257c109c535cc16e7d5" alt=""
Image rendered using plutonem
data:image/s3,"s3://crabby-images/2d5d4/2d5d42ede96d85dd98957eba15863b673182f839" alt=""
A raycaster written with plutonem
data:image/s3,"s3://crabby-images/9ac0c/9ac0ccecf3b307552dd6e45499e3834dc7c4681f" alt=""
Plutonem is tested and works on:
- [x] Operating systems: Linux, BSD, MacOS, (idk windows cuz cringe)
- [x] Terminal emulators: XTerm, Termite, Konsole, GNOME-terminal, Alacritty (best performance) and Kitty
Contributing:
- Bug fixes
- Features (don't pull request too many files at once)
- Issue (GitHub issues tab) fixing
Troubleshooting
- Check if proper fonts are installed. Pluto uses Unicode characters from
U+10240(10)
toU+10495(10)
. I recommend theCascadia Mono
font. - Check if your terminal supports Unicode
- Check your locale, lang (pluto only supports UTF-8 currently). I have my locale set to
en_US.UTF-8
. On Arch Linux, which I use, I would use this command to set it:
# localectl set-locale LANG=en_US.UTF-8
- Open an issue in the issues tab, provide your terminal name, what locale it is set to, and your font