1.0.0 • Published 3 years ago

@danielcodex/asciidance v1.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
3 years ago

Asciidance

This project is inpired from parrot.live.

Basically i wanted to make any gifs to ascii and make it dance on terminal hence the name asciidance.

So The process of getting this result for any gifs is:

  1. you need a gif
  2. we have to extract frames from gifs
  3. at last we have to turn those frames to ascii

All of this will happen behind the secene when you use asciidance

Here is the quick example
quick example

Install

npm install asciidance

Before running examples

  1. You have to install jp2a on your computer
    1. For installing on Windows use wsl
    2. For installing on Mac use brew
    3. For installing on Ubuntu use sudo apt-get install jp2a
  2. You have to put your gifs on a gifs folder
  3. Everytime you run the code again (as you can see in a quick example above) you have to delete both ascii and frames folder

Example

background

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { bg: "light" });

bg

Custom characters

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { chars: "!@#$%^&()_+" });

custom-chars

Border example

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { border: "border" });

boder

Flip-horizontal

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { flipx: "flipx" });

flipx

Flip-vertical

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { flipy: "flipy" });

flipy

Size

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { size: "100x100" });

size

Width

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { width: "20" });

width

Frame-Rate

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { frameRate: "10" });

frame-rate

Custom-colors

const asciidance = require("asciidance");

asciidance("snoopdog.gif", { customColor: ["green"] });

custom-color

everthing together

const asciiDance = require("asciidance");

asciiDance("snoop.gif", {
  bg: "dark",
  chars: "danielcodex",
  flipy: "flipy",
  flipx: "flipx",
  border: "border",
  frameRate: "100",
  customColor: ["green", "red", "cyan"]
});

everything


API

asciidance(gifFile, asciiConfig?)

gifFile

Type: string
Your gif file name

asciiConfig

Type: object
Default: undefined

Options for how you ascii should look like.

bg

Type: string
Default: dark

The other option is light

Here is the example

chars

Type: string
Default: ...',;:clodxkO0KXNWM

Here is the example

Border

Type: string
Default: undefined

You can set it to border
Here is the example

flipx

Type: string
Default: undefined

You can flip the ascii in the x axis
Here is the example

flipy

Type: string
Default: undefined

you can flip the ascii in the y axis
Here is the example

size

Type: string
Default: The default is the largest image dimension that fits on your terminal link

The format which you write is NxN. That's x in the middle.

Here is the example

frameRate

Type: string
Default: 70

This default rate is originally from parrot.live source code.

But you can change it to any number you want

The rules of thumb is this:
the lower the number the faster the animation/dancing and the higher the number the slower the animation/dancing 😂

Here is the example

customColor

Type: array
Default: ["red", "yellow", "green", "blue", "magenta", "cyan", "white"]

You can give choose any color from default array.
This colors come from colors npm package.

Here is the example


Buggy behaviour

Intentionally i run one code after 2s. Here is the link

For some reason which i don't know yet, if we remove this delay and run the code for the first time, the moment we run curl localhost:3000 we won't get any result in terminal.

So i suspect that the reason for that is because the ascii folder is not populated yet the moment the makeItDance() is called.

That's why i delay the called for makeItDance() function.

If you used a gifs which was really long (i haven't seen a long gifs myself 🤔😂) you might not see anything on terminal the moment you run curl localhost:3000.

In order for that to work just run the your code again and then run curl localhost:3000 (it will works, i promise)

Happy coding 🤗