p5.js welcomes libraries contributed by others! Check out the libraries tutorial for more specifics about how to create one. If you have created a library and would like to have it included on this page, submit a pull request on GitHub!
Drawing
data:image/s3,"s3://crabby-images/a1820/a182032cdaee094c2b0c1e8b08b307341cbe93fd" alt="The name "AnimatorJs" above a drawing of a pose manequin and duck animation and arrows indicating how they would move"
The name "AnimatorJs" above a drawing of a pose manequin and duck animation and arrows indicating how they would move
AnimatorJs
A javascript animation viewer based on a custom animation API primarily designed for p5.js and allows for dynamic, lightweight, real-time rendered browser animations controlled purely by code. By RandomGamingDev
data:image/s3,"s3://crabby-images/72d79/72d792ef1875d5c3ca12088fb9246c68a48638b6" alt="a stereoscopic anaglyph scene of 3D terrain"
a stereoscopic anaglyph scene of 3D terrain
p5.anaglyph
A library for creating 3D stereoscopic 3D scenes and images using red/cyan glasses. By Jenna deBoisblanc
data:image/s3,"s3://crabby-images/af853/af8538186c32f135d8d8c068cac28b21d75e21aa" alt="The p5.bezier text with curves of different colors."
The p5.bezier text with curves of different colors.
p5.bezier
p5.bezier helps draw Bézier curves with more than four control points and closed curves. By Peiling Jiang
data:image/s3,"s3://crabby-images/d5eeb/d5eeb922a517b24913b0b11d65166c522214b165" alt="The text 'p5.brush' surrounded by colored brush strokes."
The text 'p5.brush' surrounded by colored brush strokes.
p5.brush
Unlock custom brushes, natural fill effects and intuitive hatching in p5.js. By Alejandro Campos Uribe
data:image/s3,"s3://crabby-images/3d6cf/3d6cf6dc28e5a3d9fe96c8ecb8784130a181f0c5" alt="Three gradients (linear, radial, and conic) created using p5.fillGradient"
Three gradients (linear, radial, and conic) created using p5.fillGradient
p5.fillGradient
Fill shapes in p5.js with Linear, Radial and Conic Gradients. By Jorge Moreno
data:image/s3,"s3://crabby-images/18ac1/18ac132f0196624ea78cfa71d1f45e642e3028dd" alt="Colorful hexagonal cubes tessellation spelling "p5.grain""
Colorful hexagonal cubes tessellation spelling "p5.grain"
p5.grain
Conveniently add film grain, seamless texture overlays, and manipulate pixels to achieve nostalgic and artistic effects in p5.js sketches and artworks. By meezwhite
data:image/s3,"s3://crabby-images/c42e9/c42e9e2efca2f108b8c3718cd409ee62ebf85e53" alt="projection mapping shapes (quad, triangle, lines, bezier)"
projection mapping shapes (quad, triangle, lines, bezier)
p5.mapper
A projection mapping library for p5.js. By Jenna deBoisblanc
data:image/s3,"s3://crabby-images/d974e/d974e3ea3ef16ffcd1a62b2c6dcf25456e6a6b98" alt="A noise pattern with outlines of pixels with the same grayscale value."
A noise pattern with outlines of pixels with the same grayscale value.
p5.marching
Raster to vector conversion, isosurfaces. By JT Nimoy
data:image/s3,"s3://crabby-images/36901/3690188ac9e7af86658da830fadd1e4cf472ab9a" alt="The text 'p5.p' fileld with a checkerboard of different patterns"
The text 'p5.p' fileld with a checkerboard of different patterns
p5.pattern
A pattern drawing library for p5.js. By Taichi Sayama
data:image/s3,"s3://crabby-images/8f877/8f877cf5106b6aef9c9e0b870b13ccdb95b37d1f" alt="symmetrical geometric patterns"
symmetrical geometric patterns
p5.Polar
p5.Polar provides mathematical abstractions making it easy to create create beautiful, kaleidoscopic, radial patterns. By Liz Peng
data:image/s3,"s3://crabby-images/3d084/3d08410f905cec3ed743ba1d5ffee174780a5dc8" alt="Quadrille cells sorted by their luminance levels."
Quadrille cells sorted by their luminance levels.
p5.quadrille.js
A library for creating puzzle and board games, and for visual computing experiments. By Jean Pierre Charalambos
data:image/s3,"s3://crabby-images/81046/81046638c059b5cf44cee8d3890ffb673a994de4" alt="The name "p5.Sprite" is displayed, slanted on the top, with a sprite sheet with a character's walk cycle displayed below"
The name "p5.Sprite" is displayed, slanted on the top, with a sprite sheet with a character's walk cycle displayed below
p5.Sprite
A basic sprite library that supports both animated and static sprites for p5.js. By RandomGamingDev
data:image/s3,"s3://crabby-images/6608e/6608e99b6e9694f1af9c7e0e0575122df9f4a5c9" alt="A hexagonal grid with pink rings eminating from the center. Each pink ring is followed by pink rings of a lighter color"
A hexagonal grid with pink rings eminating from the center. Each pink ring is followed by pink rings of a lighter color
p5grid
Hexagonal Tiling Library. By Aren Davey
data:image/s3,"s3://crabby-images/7e588/7e5881b3af25ee12c5365246738dd8e24fc03817" alt="The name "Pixyp5js" written on the top an image of a pixel art computer with a smile as its screen and a projection of its face meant to demonstrate that the library is meant for easily modifying pixels during runtime"
The name "Pixyp5js" written on the top an image of a pixel art computer with a smile as its screen and a projection of its face meant to demonstrate that the library is meant for easily modifying pixels during runtime
Pixyp5js
A library for easily more easily dealing with pixels in images during runtime. By RandomGamingDev
data:image/s3,"s3://crabby-images/66c40/66c402f8b050a58ce00752804e700d2163034701" alt="A Tilemapp5js tilemap with the Tilemapp5js name in the top right"
A Tilemapp5js tilemap with the Tilemapp5js name in the top right
Tilemapp5js
A simple to use & performant tilemap p5.js library. By RandomGamingDev
data:image/s3,"s3://crabby-images/be632/be63205b05b3e397ee38b82170afe5796c112d9c" alt="A turtle and crayons shown above a fractal generated tree"
A turtle and crayons shown above a fractal generated tree
TurtleGFX
TurtleGFX allows to code with Turtle Graphics in JavaScript. Great for education and creative coding. By CodeGuppy
data:image/s3,"s3://crabby-images/d7948/d794803d3537052f1cad4621de57d6e86a5ad0c5" alt="Poster showing some of the graphics that can be drawn with this library"
Poster showing some of the graphics that can be drawn with this library
TurtleGraphics
Watch images being drawn using turtle graphics. By Peter Lager
data:image/s3,"s3://crabby-images/df5b0/df5b015f06acfd40b4a56dece37faca3205f2242" alt="A framebuffer with "WebGL2 Framebuffer" in regular text being rendered onto the display where its enhanced with a blue gradient fill and yellow gradient outline"
A framebuffer with "WebGL2 Framebuffer" in regular text being rendered onto the display where its enhanced with a blue gradient fill and yellow gradient outline
WebGL2FBO
A simple library for OOP encapsulation and abstraction of some of WebGL2 Framebuffers and the Renderbuffers they rely on. By RandomGamingDev
data:image/s3,"s3://crabby-images/e406e/e406e488167646023e0d6cd79c6d2b35b8d8c749" alt="A checkboard pattern with the name WebGL2Tex in the center"
A checkboard pattern with the name WebGL2Tex in the center
WebGL2Tex
A simple library for OOP encapsulation and abstraction of some of the different WebGL2 textures while still giving full control over them. By RandomGamingDev
data:image/s3,"s3://crabby-images/61fe7/61fe7d6656cc3429ffb1cccda5ded07376aa8efe" alt="The name of the library "Zoomp5js" with a magnifying glass magnifying the word "Zoom""
The name of the library "Zoomp5js" with a magnifying glass magnifying the word "Zoom"
Zoomp5js
A simple library for adding the zooming functionality to your p5.js project. By RandomGamingDev
Color
data:image/s3,"s3://crabby-images/c5ad8/c5ad86454eb18956dad42ce3fe88c0daaa69cac2" alt="A grid of square pattern showcasing a multitude of colors."
A grid of square pattern showcasing a multitude of colors.
p5.cmyk
CMYK color for p5.js. By JT Nimoy
data:image/s3,"s3://crabby-images/6baa0/6baa0b929c71e955cd2acc8946963ed8890fe0c1" alt="Waves coloured using different tints of yellow"
Waves coloured using different tints of yellow
p5.colorGenerator
p5.colorGenerator generates harmonious color schemes by starting from a given base color or selecting a random color as a starting point. By Alex Codes Art
data:image/s3,"s3://crabby-images/44d07/44d0722dbe8e7c315018ad12b638f7ada34e8ec6" alt="Color palettes in p5.js"
Color palettes in p5.js
p5.palette
A library to manage color palettes in p5.js. By Remistura Studio
User Interface
data:image/s3,"s3://crabby-images/14bae/14baec267ddd845f10cfd4472da0fc84356666d0" alt="Various controls shown on a canvas"
Various controls shown on a canvas
canvasGUI
Create GUI controls directly on your canvas. By Peter Lager
data:image/s3,"s3://crabby-images/78d8a/78d8a4ad859b036c67fa3c09bf24ceab41fdc0fd" alt="Screenshot of p5.5.js"
Screenshot of p5.5.js
p5.5
Add UI to p5.js and other goodies. By Kris HEYSE
data:image/s3,"s3://crabby-images/33a51/33a5111e3c5f66e9c2a0b79ba08b886c93ce6e68" alt="a rectangle on a black background with a green outline with the text p5.Modbuttons inside, there are multiple dials and sliders around the central rectangle"
a rectangle on a black background with a green outline with the text p5.Modbuttons inside, there are multiple dials and sliders around the central rectangle
p5.Modbuttons
a simple and modular button system for p5js. By 7vector
data:image/s3,"s3://crabby-images/e66c4/e66c431011be4bd6ab06e305d6f4987b7958f2c2" alt="A grid of buttons and sliders created by the library."
A grid of buttons and sliders created by the library.
p5.touchgui
p5.touchgui is intended to extend p5.js and make it easy to add buttons, sliders, and other GUI (graphical user interface) objects to your p5.js sketches, enabling you to focus on quickly iterating ideas with easily created GUI objects that work with both mouse and multi-touch input. By Carlos L05 Garcia
data:image/s3,"s3://crabby-images/e63ca/e63ca8033bba1cc4274a5262feecae3fbb56e93b" alt="The cover image for the ui renderer library. Depicts a typical ui"
The cover image for the ui renderer library. Depicts a typical ui
UI Renderer
Create a UI within your sketch, including utilities for different layouts and interactive sliders. By Amit Kumar Sah
Math
![The text [MatrixJs] with a long shadow and a bit of bloom](/_astro/MatrixJs.BfTvPsLy_4yaF1.webp)
The text [MatrixJs] with a long shadow and a bit of bloom
MatrixJs
A basic javascript library for dynamic and powerful matrices based on lists wrapped around with a powerful class. By RandomGamingDev
data:image/s3,"s3://crabby-images/7bd61/7bd61a0d9394d2aee9d450a2eaaa492868f0fd21" alt="A matrix and a vector both filled with asterisks. The math is written in white on a red background."
A matrix and a vector both filled with asterisks. The math is written in white on a red background.
número
A friendly and intuitive math library for p5.js. By Nick McIntyre
data:image/s3,"s3://crabby-images/16c5e/16c5eab7fe7c38f74783fc4bc27142c5f01dc7d0" alt="Various colored shaped overlapping and colliding representing the functions of the p5.collide2d library"
Various colored shaped overlapping and colliding representing the functions of the p5.collide2d library
p5.collide2d
p5.collide2D provides tools for calculating collision detection for 2D geometry with p5.js. By Ben Moren
data:image/s3,"s3://crabby-images/f38f0/f38f0d56b065ce1491538b35791cb30165909c45" alt="An image of 2 vectors, a large red one, and a smaller blue one, with the VecJs name on the red one"
An image of 2 vectors, a large red one, and a smaller blue one, with the VecJs name on the red one
VecJs
A basic javascript library for dynamic vectors (e.g. vec2 & vec3) based on lists. By RandomGamingDev
Physics
data:image/s3,"s3://crabby-images/0a3d5/0a3d5f6357906f8642a9e27289d13bc5c289dfed" alt="The text 'made with p5play' on top of a collage of projects"
The text 'made with p5play' on top of a collage of projects
p5play
JS game engine that uses p5.js for graphics and Box2D for physics. By Quinton Ashley and Paolo Pedercini
Algorithms
data:image/s3,"s3://crabby-images/e2a28/e2a282cf446c35cc77cc3196bffba928aa9f12b3" alt="The name BasicECSJs on the top and an image of a duck (named duk) and a mannequin lying down on top of it, as well as a torch in the bottom right corner, titled Entity 0 to 2 in the respective order."
The name BasicECSJs on the top and an image of a duck (named duk) and a mannequin lying down on top of it, as well as a torch in the bottom right corner, titled Entity 0 to 2 in the respective order.
BasicECSJs
A basic javascript ECS system, with SceneManagers, Scenes and GameObjects with their own Start and Update functions. By RandomGamingDev
data:image/s3,"s3://crabby-images/890bb/890bb969bc4ccb05f1550ba12c678ed31021e10f" alt="Limited Voronoi"
Limited Voronoi
c2.js
c2.js is a JavaScript library for creative coding based on computational geometry, physics simulation, evolutionary algorithm and other modules. By Ren Yuan
data:image/s3,"s3://crabby-images/119dc/119dc9ad7cadce3b477db2c2c24fcf9d5eb773ca" alt="A line showing an outline of points"
A line showing an outline of points
concaveHull
Calculate a Concave Hull from a set of points in 2D space. By Mark Roland
data:image/s3,"s3://crabby-images/66752/667526daaaec43284f938b79a6c7bd567e741ce7" alt="A logo displaying a double linked list with the name "DoubleLinkedListLibJs" displayed in the center of the one of the nodes"
A logo displaying a double linked list with the name "DoubleLinkedListLibJs" displayed in the center of the one of the nodes
DoubleLinkedListLibJs
A simple double linked list that stores the head, tail and length of the list. By RandomGamingDev
data:image/s3,"s3://crabby-images/56273/56273942dad2ff95047ddd8fef06d47b48451203" alt="A logo displaying a linked list with the name "OneWayLinkedListLibJs" displayed in the center of the one of the nodes"
A logo displaying a linked list with the name "OneWayLinkedListLibJs" displayed in the center of the one of the nodes
OneWayLinkedListLibJs
A simple one way linked list that stores the head, tail and length of the list. By RandomGamingDev
data:image/s3,"s3://crabby-images/68f3b/68f3bbffd3f87c2f17b66326617d46fdcaa591a3" alt="9 video effects of the author's face in a 3x3 grid"
9 video effects of the author's face in a 3x3 grid
p5videoKit
A dashboard for mixing video in the browser. By John Henry Thompson
data:image/s3,"s3://crabby-images/e7e82/e7e828511153cce602ab84ebec07caad3d69f0bd" alt="A colorful image of circles and squares generated with procedural functions like a cellular automaton, fibonacci sequence and drunk randomness from this library."
A colorful image of circles and squares generated with procedural functions like a cellular automaton, fibonacci sequence and drunk randomness from this library.
Total Serialism
A toolbox full of methods for procedurally generating and transforming arrays mainly focused on algorithmic composition. Includes methods like markov-chain, cellular automaton, lindenmayer system, euclidean distribution and much more! Generate the array with your desired method and easily iterate over them in a for-loop to draw the results. By Timo Hoogland
3D
data:image/s3,"s3://crabby-images/0a00f/0a00f4bf8dc12da73fe273eb9d7a0fa9bf5fca4f" alt="An egg cut up into slices"
An egg cut up into slices
p5.csg
A library for constructive solid geometry. Do Boolean operations on your p5.Geometry to make new shapes! By Dave Pagurek
data:image/s3,"s3://crabby-images/40ff5/40ff536be384e00fdab7a26d4189ad8c2ecd051e" alt="A ladder looking up a shaft towards some light, going progressively more out of focus as it goes into the distance"
A ladder looking up a shaft towards some light, going progressively more out of focus as it goes into the distance
p5.filterRenderer
A library for rendering 3D scenes with depth-of-field blur and with ambient occlusion shadows. By Dave Pagurek
data:image/s3,"s3://crabby-images/eac72/eac72c146e5f65afbaa169f63c11f30ae1a81744" alt="A logo and description of 'p5.simpleAR' library are placed in the center."
A logo and description of 'p5.simpleAR' library are placed in the center.
p5.simpleAR
A simple JavaScript library that easily converts existing p5.js sketches to AR. By Tetsunori Nakayama
data:image/s3,"s3://crabby-images/26133/26133c023009830dd67b11c088d04772479fe205" alt="Four images of a 3D airplane twisting upside-down"
Four images of a 3D airplane twisting upside-down
p5.warp
Fast 3D domain warping using shaders. By Dave Pagurek
data:image/s3,"s3://crabby-images/d6d3e/d6d3ef426c386b35e82b9578ee804287234ae0b1" alt="A crying face"
A crying face
p5.xr
A library for creating VR and AR sketches with p5. By Stalgia Grigg
AI, ML, and CV
data:image/s3,"s3://crabby-images/c4f69/c4f69f126f93235cd41d612c192ef8c6f704207a" alt="Text "Friendly machine learning for the web with ml5.js" on top of a light grey ml5.js logo"
Text "Friendly machine learning for the web with ml5.js" on top of a light grey ml5.js logo
ml5.js
Friendly machine learning for the web—a neighborly approach to creating and exploring artificial intelligence in the browser. By NYU's Interactive Telecommunications/Interactive Media Arts Program and NYU Shanghai's Interactive Media Arts Program
data:image/s3,"s3://crabby-images/0ed88/0ed8808367d7e080efb674556c15a15b1d50c883" alt="Screenshot of two browser windows - one, running an instance of ComfyUI, the other running a p5.js sketch"
Screenshot of two browser windows - one, running an instance of ComfyUI, the other running a p5.js sketch
p5.comfyui-helper
A library for interfacing with ComfyUI. By Gottfried Haider
Animation
data:image/s3,"s3://crabby-images/a226a/a226a52c09b3d8e816ec311c1fbcc49c86182be4" alt="People represented by circles and lines are walking in various directions. A logo and description of 'BMWalker.js' library are placed in the center."
People represented by circles and lines are walking in various directions. A logo and description of 'BMWalker.js' library are placed in the center.
BMWalker.js
A simple JavaScript library for drawing the biological motion 'Walker'. By Tetsunori Nakayama
data:image/s3,"s3://crabby-images/01c3c/01c3c760311f2390a7a70abf9c126b558118b61b" alt="p5.js spheres with texture from hydra and 'HY5' text, processed a second time with hydra."
p5.js spheres with texture from hydra and 'HY5' text, processed a second time with hydra.
HY5
hydra 🙏 p5.js ~ share visuals between both frameworks! By Ted Davis
data:image/s3,"s3://crabby-images/8ec19/8ec190eefb52e3114db3a3e7586a8ca3259a8a20" alt="A circle and a Bézier curve animated with p5.animS"
A circle and a Bézier curve animated with p5.animS
p5.animS
Animates p5.js shapes by rendering their drawing processes. By wixette
data:image/s3,"s3://crabby-images/2e392/2e392b53e5ce642976d8a3a23aa91475d0db9274" alt="Three cascading waves created using p5.createLoop"
Three cascading waves created using p5.createLoop
p5.createLoop
Create animation loops with noise and GIF exports in one line of code. By mrchantey
data:image/s3,"s3://crabby-images/4cfef/4cfeff7d9a84dba79986ac983ce7f7901c489e73" alt="p5.glitch logo glitching as a webp file"
p5.glitch logo glitching as a webp file
p5.glitch
p5.js library for glitching images and binary files in the web browser. By Ted Davis
data:image/s3,"s3://crabby-images/d13e6/d13e65691c2868c4d7b2d3f443304621aa9886a4" alt="Two circles in different colors and sizes and an arrow from left to right that stylizes a transition."
Two circles in different colors and sizes and an arrow from left to right that stylizes a transition.
p5.tween
With p5.tween you can create easily animations as tween in a few keyframes. By Nick Müller
Shaders
data:image/s3,"s3://crabby-images/60a02/60a02036b4a4ecd5cc3585a1088b578680040c19" alt="Different property materials and color adjustments applied to Standford Dragon geometry, using LYGIA's reusable functions"
Different property materials and color adjustments applied to Standford Dragon geometry, using LYGIA's reusable functions
lygia
LYGIA is a shader library of reusable functions that will let you prototype, port or ship a project in just few minutes. It's very granular, flexible and efficient. Support multiple shading languages and can easily be added to any project, enviroment or framework of your choice. By Patricio Gonzalez Vivo
data:image/s3,"s3://crabby-images/68861/688615311e82b53d87c6f4dba61f15ac01f2b881" alt="A grid of ASCII characters representing perlin noise, with a centered logo reading "p5.asciify"."
A grid of ASCII characters representing perlin noise, with a centered logo reading "p5.asciify".
p5.asciify
Apply real-time ASCII conversion to your favourite WebGL p5.js sketches to create unique, text-based visuals instantly. By humanbydefinition
data:image/s3,"s3://crabby-images/113b2/113b27c50b2649e586ee5676b545f514e32a83d6" alt="The cover image for the p5.FIP library. Depicts a collage of three photos created using the filters in p5.FIP."
The cover image for the p5.FIP library. Depicts a collage of three photos created using the filters in p5.FIP.
p5.FIP
Real-time image processing library - add filters and post-processing to your p5.js sketches. By Darragh Nolan
data:image/s3,"s3://crabby-images/d0df0/d0df0358507e11b746f5e0326ab34a3fbc4b566c" alt="A non-Euclidean geometry cube with faces showcasing teapot, bunny, and Buddha models."
A non-Euclidean geometry cube with faces showcasing teapot, bunny, and Buddha models.
p5.treegl
Shader development and space transformations WEBGL p5.js library. By Jean Pierre Charalambos
data:image/s3,"s3://crabby-images/bb2b5/bb2b5dac688e9d14fcf72fbd7183b998161ec972" alt="An abstract 3D shape made of a few partial spherical shells organically joined together."
An abstract 3D shape made of a few partial spherical shells organically joined together.
Shader Park
Explore shader programming through a JavaScript interface without the complexity of GLSL. Quickly script shaders using a P5.js style language. By Torin Blankensmith and Peter Whidden
Language
data:image/s3,"s3://crabby-images/65e6d/65e6dd7cbeada2f29019006b83f1a8b315052010" alt="The text 'i hear you' above the text 'you hear me'"
The text 'i hear you' above the text 'you hear me'
p5.speech
p5.speech provides simple, clear access to the Web Speech and Speech Recognition APIs, allowing for the easy creation of sketches that can talk and listen. By R. Luke DuBois
data:image/s3,"s3://crabby-images/a143d/a143d276aa05f370bae0d5e4c9b71350dba4600f" alt="rita.js logo"
rita.js logo
rita.js
tools for natural language and generative writing. By Daniel C Howe
Hardware
data:image/s3,"s3://crabby-images/e92f1/e92f1beeec30a1e44b22e746c40532dca102552c" alt="A browser window and a chip with an LED and a Bluetooth icon exchanging information via arrows back and forth"
A browser window and a chip with an LED and a Bluetooth icon exchanging information via arrows back and forth
p5.ble
A Javascript library that enables communication between your BLE devices and your p5.js sketch. By Yining Shi, Jingwen Zhu, and Tom Igoe
data:image/s3,"s3://crabby-images/3528a/3528a0cf62741a7a74abc443b069259a9c459216" alt="An image of 3D printed vase made with p5.fab, next to lines of G-Code overlayed with the title 'p5.fab'."
An image of 3D printed vase made with p5.fab, next to lines of G-Code overlayed with the title 'p5.fab'.
p5.fab
p5.fab controls digital fabrication machines from p5.js! By Blair Subbaraman
data:image/s3,"s3://crabby-images/24398/243989de1b898e07867df3a6ff539037fed3453e" alt="A radiating polar grid of concentric circles and lines, like a radar screen."
A radiating polar grid of concentric circles and lines, like a radar screen.
p5.geolocation
p5.geolocation provides techniques for acquiring, watching, calculating, and geofencing user locations for p5.js. By Ben Moren
data:image/s3,"s3://crabby-images/65058/650584a7e28e3e75d94f09b1ee0d8beef2a490a1" alt="Joystick image"
Joystick image
p5.joystick
Connect and play with physical joysticks. By Vamoss
data:image/s3,"s3://crabby-images/87f66/87f66bb683a1980b7e9d9455ed454dabbc7bb364" alt="A stylized serial port"
A stylized serial port
p5.serialserver
p5.serialserver is a p5.js library that enables communication between your p5.js sketch and a serial enabled device, for example, an Arduino microcontroller. By aarón montoya-moraga
data:image/s3,"s3://crabby-images/2379b/2379b8f42d65730df6ed9e05b05839fc3090e595" alt="A logo and cube-shaped symbol of 'p5.toio' library are placed in the center."
A logo and cube-shaped symbol of 'p5.toio' library are placed in the center.
p5.toio
A JavaScript library for controlling toio™Core Cube from p5.js sketches. By Tetsunori Nakayama
data:image/s3,"s3://crabby-images/1819e/1819eb4c7a69cc038a803dc0af7d938e098b28b6" alt="Fingers resting on an acrylic cube sporting buttons to control a game unfolding on a laptop screen visible in the background"
Fingers resting on an acrylic cube sporting buttons to control a game unfolding on a laptop screen visible in the background
p5.webserial
A library for interacting with Serial devices from within the browser, based on Web Serial API (available on Chrome and Edge). By Gottfried Haider
Sound
data:image/s3,"s3://crabby-images/1ac05/1ac05b664fdd6eeacaede4b8d81e1949b7193a0d" alt="Kickstart your JavaScript MIDI projects!"
Kickstart your JavaScript MIDI projects!
WEBMIDI.js
A user-friendly library to send and receive MIDI messages with ease. By Jean-Philippe Côté
Teaching
data:image/s3,"s3://crabby-images/b18e8/b18e8ba8c6faa8dc2a9af7de45bfa1f55a1888da" alt="Wave equation on the upper left corner and right upper corner has a graph of cosine function plus some polynomial terms. A logo and description of 'p5.teach.js' library are placed in the center."
Wave equation on the upper left corner and right upper corner has a graph of cosine function plus some polynomial terms. A logo and description of 'p5.teach.js' library are placed in the center.
p5.teach.js
A beginner friendly math animation library for p5.js. By Aditya Siddheshwar, Nick McIntyre, and Jithin KS
data:image/s3,"s3://crabby-images/8d559/8d5596fbd43963b8f78e6f18c7b8d81471954f68" alt="simple.js logo"
simple.js logo
simple.js
Helper functions and defaults for young and new coders. By Tariq Rashid
Networking
data:image/s3,"s3://crabby-images/b7938/b7938f1ac85b65ebb675938bcfcd1dfe06c2fb45" alt="p5.party logo. cheerful pastel block letters spelling "p5.party""
p5.party logo. cheerful pastel block letters spelling "p5.party"
p5.party
quickly prototype networked multiplayer games and apps. By Justin Bakse
Export
data:image/s3,"s3://crabby-images/4a2cd/4a2cdf803db87408e2b253823d32bbd91a4e1112" alt="p5.capture: Record your p5.js sketches effortlessly!"
p5.capture: Record your p5.js sketches effortlessly!
p5.capture
Record your p5.js sketches effortlessly! By tapioca24
data:image/s3,"s3://crabby-images/1babd/1babdbb89e1fdb9555ba87b6fca11f9ad1841b04" alt="a grid of wobbly circles of ink of different riso colors overlapping and blending"
a grid of wobbly circles of ink of different riso colors overlapping and blending
p5.Riso
p5.Riso is a library for generating files suitable for Risograph printing. It helps turn your sketches into multi-color prints. By Sam Lavigne and Tega Brain
data:image/s3,"s3://crabby-images/86d00/86d002ef757cb7d43f5e1d8bcae01439e1fb787f" alt="An abstract VHS tape"
An abstract VHS tape
p5.videorecorder
Record your canvas as a video file with audio. By Caleb Foss
data:image/s3,"s3://crabby-images/19ffd/19ffd34ef6fadf8b006a3f0d6955783ef1453741" alt="An image of text that says "p5snap" next to a grid of frames from an animated sketch"
An image of text that says "p5snap" next to a grid of frames from an animated sketch
p5snap
a command-line interface to create snapshots of sketches. By Zach Krall
Utilities
data:image/s3,"s3://crabby-images/b1c34/b1c34729e65e12a0776a85cf6391116bcce576b1" alt="An image of the word "BasicUnitTesterJs" with "Basic" on the side of and "UnitTesterJs" being on a test paper with a check and x as well as an exclamation mark on the right and a little bit of text on the left saying "Error!""
An image of the word "BasicUnitTesterJs" with "Basic" on the side of and "UnitTesterJs" being on a test paper with a check and x as well as an exclamation mark on the right and a little bit of text on the left saying "Error!"
BasicUnitTesterJs
BasicUnitTesterJs is a basic javascript unit tester designed to work on all JS platforms and be small and streamlined for the best developer experience. By RandomGamingDev
data:image/s3,"s3://crabby-images/87838/87838449c07945b7f5e67415c05d1bb93b5904dd" alt="p5.flex preview image"
p5.flex preview image
p5.flex
p5 container with responsive canvas feature. By Zaron Chen
data:image/s3,"s3://crabby-images/604ef/604efe09df9dd4cfca65f523fe782344ae041b43" alt="Two rounded rectangles with ellipses between. connecting lines give the effect of messages being sent between the rectangles via the ellipses."
Two rounded rectangles with ellipses between. connecting lines give the effect of messages being sent between the rectangles via the ellipses.
p5.localessage
p5.localmessage provides a simple interface to send messages locally from one sketch to another. By Ben Moren
data:image/s3,"s3://crabby-images/0d17b/0d17b01846cada97ed879e8db538c9f98ab709ea" alt="The cover image for the library. Displays the name of the library on a deep pink background."
The cover image for the library. Displays the name of the library on a deep pink background.
p5.qol
Extend p5 with Quality of Life utilities. By Jens Bachmayer
data:image/s3,"s3://crabby-images/4e30c/4e30cff68223a37f2359a4591af3fffd04b4737b" alt="There are two concentric rectangles. From smaller inside rectangle's corners, dotted lines with arrows point to the inside corners of the larger outside rectangle."
There are two concentric rectangles. From smaller inside rectangle's corners, dotted lines with arrows point to the inside corners of the larger outside rectangle.
p5.scaler
Smart scaling of p5.js sketches in a variety of ways (to fit the browser's inner dimensions, to fit the canvas DOM container, to a specific ratio, etc). By Rodjun and Monica Rizzolli
data:image/s3,"s3://crabby-images/7e499/7e4990cf3a23a0d26aa45802413ce09a5e9dc6cb" alt="Game states shown above an arcade game"
Game states shown above an arcade game
p5.SceneManager
p5.SceneManager helps you create sketches with multiple states / scenes. Each scene is a like a sketch within the main sketch. By CodeGuppy
data:image/s3,"s3://crabby-images/788e7/788e7ec8be3346ec7ed217ef2c4ff1fbdaeb32db" alt="The cover image for p5Utils library. Depicts the ruler on a yellow background with p5.Utils text in the center."
The cover image for p5Utils library. Depicts the ruler on a yellow background with p5.Utils text in the center.
p5.Utils
p5.Utils is a tool collection for my coding class, featuring a pixel ruler, gradient fill color bindings, and other helpful shortcuts for beginners. By Alp Tuğan
data:image/s3,"s3://crabby-images/adc66/adc6664e43c3f5cbb45e04868b113bcccac4e9b4" alt="An image of a wireframe platform with the 3d word "p5jsDebugCam" floating on top of it and a debug camera pointed and looking at both"
An image of a wireframe platform with the 3d word "p5jsDebugCam" floating on top of it and a debug camera pointed and looking at both
p5jsDebugCam
A basic keyboard only debug camera for p5.js. By RandomGamingDev
data:image/s3,"s3://crabby-images/74616/74616d41d31af5dbdf81147907fca66043eaba16" alt="a handdrawn infinity symbol"
a handdrawn infinity symbol
p5mirror
A library to download your editor.p5js sketches into a git repo or locally. By John Henry Thompson
data:image/s3,"s3://crabby-images/2f8d0/2f8d07ed333590de68b31193efbf989529214147" alt="Six examples showing different grid structures created with the pretty-grid library"
Six examples showing different grid structures created with the pretty-grid library
pretty-grid
Create and manipulate grids with Javascript. By Vadim Gouskov