Monday, September 23, 2024
Google search engine
HomeLanguagesJavascriptp5.js camera() Method

p5.js camera() Method

The camera() function in p5.js is used to set the virtual camera’s position on a 3D sketch. This can be used to simulate the position of the camera as it would move around the scene making it possible to view objects from various angles.

The parameters of this function include setting the position for the camera, the center of the camera, and the vector which is pointing upside. 

Syntax:

camera([x], [y], [z], [centerX], [centerY], [centerZ],
            [upX], [upY], [upZ])

Parameters: This function accept nine parameters as mentioned above and described below:

  • x: This is a number that denotes the camera position on x-axis.
  • y: This is a number that denotes the camera position on y-axis.
  • z: This is a number that denotes the camera position on z-axis.
  • centerX: This is a number that denotes the x coordinate of the center of the sketch. 
  • centerY: This is a number that denotes the y coordinate of the center of the sketch.
  • centerZ: This is a number that denotes the z coordinate of the center of the sketch.
  • upX: This is a number that denotes the x component of direction ‘up’ from camera. 
  • upY: This is a number that denotes the y component of direction ‘up’ from camera.
  • upZ: This is a number that denotes the z component of direction ‘up’ from camera.

Below examples illustrates the camera() function in p5.js:

Example 1: Set the view of the camera on the x-axis.

Javascript




function setup() {
    
  createCanvas(600, 400, WEBGL);
}
  
function draw() {
    
  background(175);
    
  // Map the coordinates of the mouse
  // to the variable
  let cX = map(mouseX, 0,
               width, -200, 200);
    
  // Set the camera to the given coordinates
  camera(cX, 0, (height/2) / tan(PI/6),
         cX, 0, 0, 0, 1, 0);
    
  ambientLight(255);
    
  rotateZ(frameCount * 0.01);
  rotateX(frameCount * 0.03);
  rotateY(frameCount * 0.06);
  noStroke();
  normalMaterial();
    
  box(100, 100, 100);
}


Output:

Example 2: Set the view of the camera in a random direction every frame.

Javascript




function setup() {
    
  frameRate(5);
  createCanvas(600, 400, WEBGL);
}
  
function draw() {
    
  background(175);
    
  let cX = random(-10,10);
  let cY = random(-10,10);
  let cZ = random(-10,10);
    
  camera(cX, cY,
         cZ+(height/2) / tan(PI/6),
         cX, 0, 0, 0, 1, 0);
    
  ambientLight(255);
    
  rotateX(frameCount * 0.1);
  rotateY(frameCount * 0.1);
    
  noStroke();
  normalMaterial();
    
  box(100, 100, 100);
}


Output:


Reference:https://p5js.org/reference/#/p5.Camera

Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!

RELATED ARTICLES

Most Popular

Recent Comments