2022-10-09 10:06:04 +00:00
|
|
|
# aarty: A simple CLI tool to convert images to ASCII art with Rust 🦀
|
2022-10-03 21:14:50 +00:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f1e02/f1e02e39d89f2eac8ce9b2ed067b1fa1444b2baa" alt="srceenshots/anime_2_colored_scale_4.gif"
|
|
|
|
data:image/s3,"s3://crabby-images/020a5/020a5915b3aede19430c7c3ce0a80f0eb0ac0161" alt="money mouth face colored scale 2"
|
|
|
|
data:image/s3,"s3://crabby-images/40340/40340ef38bd3490d390b4e7516e532fe19303780" alt="money mouth face normal scale 2"
|
|
|
|
|
|
|
|
<details>
|
|
|
|
<summary>More screenshots</summary>
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c0214/c0214f1bb6b8f2cc1818f96fc4a651800c251634" alt="crab colored scale 1"
|
|
|
|
[Original image](./images/crab.png)
|
|
|
|
data:image/s3,"s3://crabby-images/33521/335210add613075ce9e76f759e2cd9c2875d4cc4" alt="crap colored scale"
|
|
|
|
[Original image](./images/crab.png)
|
|
|
|
data:image/s3,"s3://crabby-images/2c0c6/2c0c646ca216b880198597377dfaf85227da49b3" alt="nerd face colored scale"
|
|
|
|
[Original image](./images/nerd_face.png)
|
|
|
|
data:image/s3,"s3://crabby-images/67250/6725034e17f48fe3bd031329a1fa4de608d1b6c5" alt="nerd face normal scale"
|
|
|
|
[Original image](./images/nerd_face.png)
|
|
|
|
data:image/s3,"s3://crabby-images/f1e02/f1e02e39d89f2eac8ce9b2ed067b1fa1444b2baa" alt="srceenshots/anime_2_colored_scale_4.gif"
|
|
|
|
[Original image](./images/anime_2.jpg)
|
|
|
|
data:image/s3,"s3://crabby-images/6bce2/6bce27c1117d514cd849c7c9645fa38b913045f0" alt="anime colored scale 3"
|
|
|
|
[Original image](./images/anime.jpg)
|
|
|
|
|
|
|
|
</details>
|
|
|
|
|
|
|
|
```
|
|
|
|
~~~~~~~!!!!~!!~ ~!!!!!!!!!~~~~~
|
|
|
|
~~~~!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!~~~~
|
|
|
|
~~~~~!!!!!!!!!!!!!!!!!!~ !!!!!!!!!!!!!!!!!!!!~~~~
|
|
|
|
~~~~~~!!!!!!!!!!!!!!!!!!!~ ~!!!!!!!!!!!!!!!!!!!!!!~~~~
|
|
|
|
~~~~~~~!!!!!!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!!!!!!!!!~~~~~
|
|
|
|
~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!~!!!!!!!!!!!!!!!!!!!!!!!!~~~~~
|
|
|
|
~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~
|
|
|
|
~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~
|
|
|
|
~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~
|
|
|
|
~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~
|
|
|
|
~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~
|
|
|
|
~~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~
|
|
|
|
~~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~
|
|
|
|
~~~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~~
|
|
|
|
~~~~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~!!!!!!!!!!!!!!!!!!!!!!!!!!~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~!!!!!!!!!!!!!!!!!!!~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~!!!~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
~~~~~~~~~~
|
|
|
|
~~~~~
|
|
|
|
```
|
|
|
|
|
|
|
|
## Install
|
|
|
|
|
|
|
|
- from crates.io
|
|
|
|
```bash
|
2022-10-09 10:03:38 +00:00
|
|
|
cargo install aarty
|
2022-10-03 21:14:50 +00:00
|
|
|
```
|
|
|
|
- From aur:
|
|
|
|
```shell
|
|
|
|
yay -S aarty
|
|
|
|
```
|
|
|
|
|
|
|
|
## Options and arguments
|
|
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
aarty --help
|
|
|
|
```
|
|
|
|
```
|
|
|
|
A simple CLI tool to convert the images to ASCII art
|
|
|
|
|
|
|
|
Usage: aarty [OPTIONS] <IMAGE>
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
<IMAGE>
|
|
|
|
The image to convert to ASCII art
|
|
|
|
|
|
|
|
Options:
|
|
|
|
-m, --mode <MODE>
|
|
|
|
The art mode to use
|
|
|
|
|
|
|
|
[default: normal-ascii]
|
|
|
|
|
|
|
|
Possible values:
|
|
|
|
- normal-ascii: Normal ASCII art
|
|
|
|
- colored: Colored ASCII art, the colors are based on the terminal colors
|
|
|
|
|
|
|
|
--output-method <OUTPUT_METHOD>
|
|
|
|
[default: stdout]
|
|
|
|
|
|
|
|
Possible values:
|
|
|
|
- file: Save the ascii art to a file
|
|
|
|
- stdout: Print the ascii art to the terminal
|
|
|
|
|
|
|
|
-c, --characters <CHARACTERS>
|
|
|
|
The character to use for drawing the image (lighter to darker) You can user one character if you uses the color mode
|
|
|
|
|
|
|
|
[default: " .,-~!;:=*&%$@#"]
|
|
|
|
|
|
|
|
-s, --scale <SCALE>
|
|
|
|
The output scale (1 is the original size)
|
|
|
|
|
|
|
|
[default: 4]
|
|
|
|
|
2022-10-25 19:07:22 +00:00
|
|
|
-w, --width <WIDTH>
|
2022-10-26 17:52:58 +00:00
|
|
|
Enstablish how much wide is the output images, in columns. Overrides `scale`
|
2022-10-25 19:07:22 +00:00
|
|
|
|
2022-10-03 21:14:50 +00:00
|
|
|
-b, --background <BACKGROUND>
|
|
|
|
The background color to use
|
|
|
|
|
|
|
|
-o, --output <OUTPUT>
|
|
|
|
The output file to write to (if output_method is file)
|
|
|
|
|
|
|
|
[default: ascii_image.txt]
|
|
|
|
|
|
|
|
-h, --help
|
|
|
|
Print help information (use `-h` for a summary)
|
|
|
|
|
|
|
|
-V, --version
|
|
|
|
Print version information
|
|
|
|
```
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -m images/airplane.png
|
|
|
|
```
|
|
|
|
```
|
|
|
|
:=:**
|
|
|
|
=***:*
|
|
|
|
~~!!!~~~~~~~ ~~~ =*****=
|
|
|
|
~~~!!!!!!!!=*****=
|
|
|
|
~:*****=
|
|
|
|
:===**:!~
|
|
|
|
;======~!!~~
|
|
|
|
;:===:: ~!~
|
|
|
|
;:;~::: ~!!~~
|
|
|
|
~~!!;~~:; !!~
|
|
|
|
~~!!~ ~!~
|
|
|
|
~!~ !~
|
|
|
|
~~ ~~
|
|
|
|
```
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -m colored images/airplane.png
|
|
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/80e9e/80e9e09a5cb5db407a5e9277ee7afda190d136f3" alt="airplane colored scale 4"
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -m colored images/airplane.png -s 2
|
|
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/f3bf6/f3bf6e9cc2bf8b64dc93d1bf9a056a494b8b60a7" alt="airplane colored scale 2"
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -c " ~okOK#\$%" images/ok_hand.png
|
|
|
|
```
|
|
|
|
```
|
|
|
|
|
|
|
|
$$$#
|
|
|
|
#$$$$#
|
|
|
|
K#KO#$$$$#
|
|
|
|
k###O#$$$$#
|
|
|
|
kK#OK$$$$#K
|
|
|
|
OKKO#$$$#
|
|
|
|
O#$$#O KKK$$$$#
|
|
|
|
K$$$$$$$$$$$$$#OOk#$$$#K
|
|
|
|
K$$$$$$$$$$$$$$$$##K#$$#K
|
|
|
|
#$K OO OK#$$$$$$$$$$###
|
|
|
|
#$$$$# OO##$$$$$$$$$#
|
|
|
|
O#$$$$# #$$$$$$$$$$KO
|
|
|
|
K#$$$$# K#$$$$$$$$$$KO
|
|
|
|
O#$$$$$$#KK####$$$$$$$$$##K
|
|
|
|
K#$$$$$$$$$$$$$$$$$$$$#KO
|
|
|
|
K##$$$$$$$$$$$$$$$$$##O
|
|
|
|
kK###$$$$$$$$$$$$###K
|
|
|
|
OK######$$######KO
|
|
|
|
OOKKKKKKKKOO
|
|
|
|
```
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -c " ~okOK#\$%" images/ok_hand.png -m colored
|
|
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/4c0e2/4c0e25b17095cc16ce0a5bd0cf15dec212a5b3e6" alt="ok hand colored scale 4 custome chars"
|
|
|
|
|
|
|
|
```shell
|
|
|
|
aarty -c " ~okOK#\$%" images/ok_hand.png -m colored --output-method file -o ok_ascii.txt
|
|
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/f40b2/f40b28326d567c32c2786d9d7ab6489f78e96bb1" alt="ok hand colored scale 4 custome chars in file"
|
|
|
|
|
|
|
|
> If you get here, don't forget the star yooo ⭐
|
|
|
|
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/a6d36/a6d36c750f205f1b0294ad766af3fb3737f99c6f" alt="License MIT"](https://spdx.org/licenses/MIT.html)
|