By default, p5 runs in Global Mode, which means that all p5 functions are in the global scope, and all canvas-related functions apply to a single canvas. p5 can also run in Instance Mode, in which those same functions are methods of an instance of the p5 class. Each instance of p5 may have its own canvas.
To use instance mode, a function must be defined with a parameter representing the p5 instance (labeled p in this example). All the p5 functions and variables that are typically global will belong to this parameter within this function’s scope. Passing the function into the p5 constructor, runs it.
Multiple Canvases by p5.js Contributors and the Processing Foundation is licensed under CC BY-NC-SA 4.0.
Related Examples
data:image/s3,"s3://crabby-images/6b336/6b3368836b2c1c96e4227bf48244467035342755" alt="Black canvas with a very dark grey rectangle in the middle. A white circle is at the edge of the rectangle."
Black canvas with a very dark grey rectangle in the middle. A white circle is at the edge of the rectangle.
Create Graphics
Draw imagery off-screen.
data:image/s3,"s3://crabby-images/fa8d5/fa8d5ce467fc3ad21cdc9deb2dfee10136b1196f" alt="Two curving lines made of repeating white circles and squares with black outlines, on a black and white background."
Two curving lines made of repeating white circles and squares with black outlines, on a black and white background.
Multiple Canvases
Use Instance Mode to put multiple canvases on the page.
data:image/s3,"s3://crabby-images/653e7/653e7ee3a16d25843ac34fa2f5a51974d6ce6f66" alt="Two spheres broken up into a square grid with a gradient in each grid."
Two spheres broken up into a square grid with a gradient in each grid.
Shader as a Texture
Generate a texture for a 3D shape using a shader.