data:image/s3,"s3://crabby-images/9f6ab/9f6ab1110f01062191b57c2368dc85db42526beb" alt=""
To start off, I created a camera object with variables for the x, y, and z positions.
data:image/s3,"s3://crabby-images/bd6d4/bd6d4fbea5ae2dcfb41731ad58b87eb23b7487ab" alt=""
I created a box object that takes in 7 arguments (xpos, ypos, zpos, width, height, thickness/depth, and color). In the display method, I draw the box primitive with the corresponding values.
data:image/s3,"s3://crabby-images/fa0bd/fa0bda3105b8dff97dbd55b18c1c37a12b71f458" alt=""
I push 200 box objects into the array called obstacles. I randomize the x,y, and z positions, and set the color to default white. I also randomize the box dimensions as well.
data:image/s3,"s3://crabby-images/1c105/1c105c5aa4c5fb8b045dabcebaf53671d9100944" alt=""
I also created a player object, and assigned a p5.Vector to it. The vector is a random2D element, because I only want the player to be able to move in the x-y dimension.
data:image/s3,"s3://crabby-images/7f164/7f164738f8fd7c30c29197a064369f1692261063" alt=""
The player object also contains methods for movement control (according to the arrow key being pressed, I add to the velocity element to generate motion).
data:image/s3,"s3://crabby-images/6b743/6b743d952ecd28bb380d97641e3932562103c801" alt=""
This was the most difficult part of the project; figuring out how to create a 3D object collision detection method. Ultimately the method works as follows: if the player object's x and y positions are within the box's dimensions, and the box's z position is past the z position of the camera, then stop the sketch.
data:image/s3,"s3://crabby-images/e239b/e239b0cfa8e6dfb2a96acbad8343ef13c2c11cd7" alt=""
The separate timer sketch.
data:image/s3,"s3://crabby-images/5d8ac/5d8ac66ce0787594de7c34c781300ef90e11269a" alt=""
data:image/s3,"s3://crabby-images/93c86/93c86d90818ce0354e733fb2f34f88a218c3baf7" alt=""
data:image/s3,"s3://crabby-images/0a319/0a319fb7a56d6a88d36ec748521687536b4920db" alt=""