-
Notifications
You must be signed in to change notification settings - Fork 3
00_Home
Welcome to the p5.asciify
wiki! ʕっ•ᴥ•ʔっ
p5.asciify
is a p5.js
add-on library for converting the main canvas in WEBGL
mode into a grid of ASCII characters in real-time, allowing you to bring a retro, text-based aesthetic to your visualizations, adding a unique touch to your creative coding projects.
The main goal of p5.asciify
is to provide an easy-to-use, customizable solution for converting the main p5.js
canvas into ASCII characters in real-time, offering a wide range of settings and effects to adjust the appearance of the ASCII grid to specific needs and artistic vision.
To see p5.asciify
in action, check out the example sketches in the provided collection on the p5.js web editor:
p5.asciify examples
.
p5.asciify
is actively developed and maintained by @humanbydefinition, with new features and improvements being added regularly. The library is open-source and available here, where you can contribute to its development, report issues, or suggest new features. I highly value your feedback and contributions, so feel free to reach out!
I would love to see your creations using p5.asciify
! Feel free to tag me on social media or use the hashtag #p5asciify
so I can enjoy and share your amazing work too.
(ノ◕ヮ◕)ノ*:・゚✧
Special thanks to @davepagurek
for helping me learn how to create a p5.js addon library! (✿◠‿◠)
p5.asciify
features a customizable rendering pipeline which is being executed every time the user's draw()
function is finished executing, currently consisting of up to 4 different layers of ASCII conversion, each with its own set of parameters that can be adjusted at any time.
p5.asciify
currently offers up to 3 different layers of ASCII conversion, each with its own set of parameters that can be adjusted at any time. The ASCII conversion is done using shaders, which allows for real-time conversion of the main WebGL
canvas into a grid of ASCII characters.
The first layer of ASCII conversion affects the entire canvas based on one of currently two methods. The brightness-based conversion uses the brightness of the pixels to determine the ASCII character, while the accurate ascii conversion attempts to recreate the image as accurately as possible using the given set of characters.
The second layer is a gradient/pattern-based conversion, where a brightness range from 0-255 is mapped to a specific string of characters, and a customizeable gradient/pattern attached to it. Only the grid cells that fall within the specified brightness range will be converted to ASCII characters, which are drawn using the dynamic gradient/pattern.
The third layer is an edge-based conversion, which uses a Sobel filter to detect edges in the image and convert them into ASCII characters.
The currently last layer is a text-based conversion, which writes the result of the previous layers as copyable text onto a <div>
element on top of the canvas. As all the other layers, fully responsive!
All ASCII conversion layers share the following settings:
Setting | Description |
---|---|
font |
The font used for the ASCII conversion. |
fontSize |
The size of the font used for the ASCII conversion. |
gridDimensions |
The number of grid cells used for the ASCII conversion. |
All ASCII conversion layers individually have the following settings:
Setting | Description |
---|---|
enabled |
Enables or disables the ASCII conversion. |
characterColorMode |
The color mode used for the ASCII conversion. |
characterColor |
The color used for the ASCII conversion. |
backgroundColorMode |
The color mode used for the background of the ASCII conversion. |
backgroundColor |
The color used for the background of the grid cells. |
invertMode |
A mode used for swapping the character and background colors. |
rotationAngle |
Rotate the ASCII characters by a specified angle. |
Setting | Description |
---|---|
renderMode |
The method used for the ASCII conversion. |
characters |
The characters used for the ASCII conversion. |
No additional settings are available for this layer. This layer is populated by adding individual customizeable gradient/pattern objects to the sketch, which is done using addAsciiGradient()
, which is described in this Wiki through the given link.
Setting | Description |
---|---|
characters |
The characters used for the ASCII conversion. Consists of 8 characters, each representing a different edge direction. |
sobelThreshold |
The threshold used for the Sobel edge detection algorithm. |
sampleThreshold |
The threshold used for sampling the sobel filter output to a smaller size. |
Contains all settings from the common settings minus the backgroundColorMode
and rotationAngle
settings.