2019-02-15 16:03:38 +05:30
---
2021-03-09 19:43:53 -08:00
category: framework
2024-10-20 14:46:35 -07:00
framework: p5.js
2019-02-15 16:03:38 +05:30
contributors:
2019-03-26 13:12:59 +01:00
- ['Amey Bhavsar', 'https://github.com/ameybhavsar24']
2019-03-26 13:17:08 +01:00
- ['Claudio Busatto', 'https://github.com/cjcbusatto']
2019-02-15 16:03:38 +05:30
filename: p5.js
---
2019-03-26 13:12:59 +01:00
2020-06-01 14:56:26 -03:00
p5.js is a JavaScript library that starts with the original goal of [Processing ](https://processing.org ), to make coding accessible for artists, designers, educators, and beginners, and reinterprets this for today's web.
2024-12-09 04:21:58 -07:00
Since p5 is a JavaScript library, you should learn [JavaScript ](../javascript/ ) first.
2019-03-26 13:12:59 +01:00
2024-01-19 16:52:17 -05:00
To run p5.js code, you can go to [the online editor ](https://editor.p5js.org/ ).
2019-02-15 16:03:38 +05:30
```js
///////////////////////////////////
// p5.js has two important functions to work with.
function setup() {
2024-01-19 16:52:17 -05:00
// the setup function gets executed just once when the window is loaded
2019-02-15 16:03:38 +05:30
}
function draw() {
2024-01-19 16:52:17 -05:00
// the draw function gets called every single frame
// if the framerate is set to 30, it would get called 30 times every second
2019-02-15 16:03:38 +05:30
}
// the following code explains all features
function setup() {
2024-01-19 16:52:17 -05:00
createCanvas(640, 480); // creates a new canvas element with 640px as width as 480px as height
background(128); // sets the background color to rgb(128, 128, 128)
// background('#aaf ') // you can use hex codes and color names too
2019-02-15 16:03:38 +05:30
}
function draw() {
2024-01-19 16:52:17 -05:00
background('#f2f2fc '); // usually, you call `background` in draw to clear the screen
// creates an ellipse at 10px from the top and 10px from the left, with width and height 37
ellipse(10, 10, 37, 37);
// remember in p5.js the origin is at the top-left corner of the canvas
if (mouseIsPressed) {
// mouseIsPressed is a boolean variable that is true when the mouse is down, and false otherwise
fill(0); // fill sets the fill color, which will stay until it is changed
} else {
fill(255, 255, 255, 240); // fill(a, b, c, d) sets the fill color to rgba(a, b, c, d)
}
ellipse(mouseX, mouseY, 80, 80);
// mouseX and mouseY are the x and y position of the mouse, respectively
// the above code creates and ellipse under the mouse, and fills it with white or black
// some other 2d primitives (shapes) you can draw:
rect(9, 3, 23, 26); // x, y, width, height
noFill(); // sets the fill color to transparent
triangle(100, 400, 130, 200, 200, 300); // x1, y1, x2, y2, x3, y3
point(100, 300); // create a point at x, y
// there are more, but they are more complex.
}
2019-02-15 16:03:38 +05:30
2024-01-19 16:52:17 -05:00
/** Bouncing balls animation
* You can copy-paste this code into the online editor at
* https://editor.p5js.org/
*/
class Ball {
constructor(x, y, xvel, yvel, radius, col) {
this.position = createVector(x, y); // create a p5.Vector object which stores the x and y
this.velocity = createVector(xvel, yvel); // make a p5.Vector storing the velocity
this.radius = radius;
this.col = col; // p5 already uses the word color, so we use col instead
}
2019-02-15 16:03:38 +05:30
2024-01-19 16:52:17 -05:00
update() {
this.position.add(this.velocity); // you can add vectors with p5.Vector.add(p5.Vector)
if (this.position.x + this.radius > width) {
// flip the direction the ball is going in if it touches the edge
this.velocity.x *= -1;
2019-03-26 13:12:59 +01:00
}
2024-01-19 16:52:17 -05:00
if (this.position.x - this.radius < 0 ) {
this.velocity.x *= -1;
}
if (this.position.y + this.radius > height) {
this.velocity.y *= -1;
}
if (this.position.y - this.radius < 0 ) {
this.velocity.y *= -1;
}
}
render() {
// you can figure out what this does by now
fill(this.col);
ellipse(this.position.x, this.position.y, this.radius);
}
}
let numBalls = 23;
let balls = [];
function setup() {
createCanvas(400, 400); // width, height
for (let i = 0; i < numBalls ; i + + ) {
let r = random(255); // random number between 0 and 255
let g = random(255);
let b = random(255);
balls.push(
new Ball(
random(30, width), // x position
random(height), // y position
random(-4, 4), // x velocity
random(-4, 4), // y velocity
random(4, 10), // radius
color(r, g, b) // fill color for the ball
)
);
}
}
function draw() {
background(255);
for (let ball of balls) {
ball.update();
ball.render();
}
}
// So far, we have only seen the default rendering mode.
// This time, we will use the 'webgl' renderer
2019-03-26 13:12:59 +01:00
2024-01-19 16:52:17 -05:00
function setup() {
createCanvas(400, 400, WEBGL); // width, height, rendering mode
}
function draw() {
background(0);
2019-03-26 13:12:59 +01:00
2024-01-19 16:52:17 -05:00
stroke('#000 ');
fill('#aaf ');
// rotate around the x, y, and z axes by the frame count divided by 50
rotateX(frameCount / 50);
rotateY(frameCount / 50);
rotateZ(frameCount / 50);
// frameCount is a p5.js variable that stores the amount of frames that have passed
box(50, 50, 50); // width, height, depth
2019-03-26 13:12:59 +01:00
}
2019-02-15 16:03:38 +05:30
```
2019-03-26 13:12:59 +01:00
2019-02-15 16:03:38 +05:30
## Further Reading
2019-03-26 13:12:59 +01:00
- [p5.js | get started ](http://p5js.org/get-started/ ) The official documentation
- [Code! Programming for Beginners with p5.js - YouTube ](https://www.youtube.com/watch?v=yPWkPOfnGsw&vl=en ) Introduction and Coding challenges using Processing and p5.js by Coding Train
2024-01-19 16:52:17 -05:00
- [The Coding Train ](https://codingtra.in/ ) A website with sketches made in p5 and processing
## Source
- [p5's source code ](https://github.com/processing/p5.js )
- [p5.sound.js source ](https://github.com/processing/p5.js-sound )