data:image/s3,"s3://crabby-images/052e8/052e8c3bea2ca84da6ebcd881965bf6ec9a9d802" alt=""
Adding lighting to the scene to give the perception of depth using shadows
data:image/s3,"s3://crabby-images/3a962/3a962d0cfac643f308ff4d65af8b61f9aa29ec08" alt=""
Originally, I had planned to keep the cube shape for the player. However, because I couldn't really 'roll' a cube forward, it didn't give the motion I wanted. By switching to a spherical mesh, I could have the dynamic movement I was looking for.
data:image/s3,"s3://crabby-images/d1017/d10176b4b6fa43e978defdaf8e5b69fc6804bf50" alt=""
To make it seem like the player was indeed rolling forward, I created another spherical object that acted as the ground. The ground sphere would roll 'backwards' relative to the player.
data:image/s3,"s3://crabby-images/cdcc4/cdcc47f665941f96d4a6196daaf818c72e808a2d" alt=""
Laning logic for the player being applied to the arrow keys.
data:image/s3,"s3://crabby-images/2afa5/2afa5f242efbb82b69b08a3e1f8e9b18f54cf80b" alt=""
If a collision has occurred, stop the three.js clock, stop the ground sphere rotation, and stop the player rotation as well. Gravity is increased to make the ball 'melt' into the floor.
data:image/s3,"s3://crabby-images/c833f/c833f566669012dbad68d2b4dbbf1fff4becd280" alt=""
Going back to the vector basics from the first week of class!
data:image/s3,"s3://crabby-images/7acd6/7acd61862dc15cfd62c64691141267521dbe81aa" alt=""
Setting the ground rotation speed, as well as the player rotation speed. A bounce value is introduced to add some dynamic up and down motion to the player sphere.
data:image/s3,"s3://crabby-images/96345/96345e0966131b7c4b5985bd3af85e05a25d1f84" alt=""
data:image/s3,"s3://crabby-images/8c4b9/8c4b99764092620623fdcaea6960754ff7135684" alt=""
data:image/s3,"s3://crabby-images/58de4/58de45816f52a463b6a1708e5ea93c451030eff3" alt=""
data:image/s3,"s3://crabby-images/f88e0/f88e05f791574eb57de7aaa261edf9e0724e3ece" alt=""