Navigation Simulation
3D rendering path planning using ThreeJS.
Video Demonstration
Features
data:image/s3,"s3://crabby-images/926f0/926f07219335ee52e54bf984280bcd0a65406799" alt=""
3D Rendering & Camera
Navigation simulation rendered in 3D using ThreeJS and TypeScript. Orbital camera that focuses around the navigation agent.
data:image/s3,"s3://crabby-images/e268c/e268c416d65893bbaecf241a448b75f5680ec39b" alt=""
Improved Agent & Scene
Agent rendered with a crash dummy model. Collision Objects rendred as explosive barrels. Rigged and animated using Adobe Mixamo. All models free for project use under CC0 License.
data:image/s3,"s3://crabby-images/84e1c/84e1c61d1276bd9bae3cbef57ce3725ec30c55cb" alt=""
Orientation Smoothing
Rotation smoothing using vector math. Model walks facing the correct direction, and rotates smoothly between angles instead of snapping.
Technologies Used
data:image/s3,"s3://crabby-images/b797f/b797f42fddf8ee44aaf160c414fcf9ba919f4e67" alt=""
data:image/s3,"s3://crabby-images/5cdec/5cdec7f26e7d564ffefe72300885a98c51b26d2c" alt=""
data:image/s3,"s3://crabby-images/0bf5c/0bf5cea73de5302ea182133e35fdaee8fc028a04" alt=""
data:image/s3,"s3://crabby-images/3ad07/3ad075c5416d2fa07d1d41a72cd92e534747449a" alt=""
TypeScript ThreeJS Vite Github Pages
Challenges We Encountered
One of the most difficult aspects of this project was implementing the pathing algorithms. We had a encountered a lot of bugs trying to move our Processing code over to TypeScript, so we took a step back and started writing the functions one by one. We also visualized the graph using ThreeJS objects, which really helped us understand what was going wrong with our algorithms and make the fixes that we needed to.
Another challenge we faced was importing the animated model into the simulation. Rigging and animating was done very easily using Adobe's Mixamo, but we faced some trouble getting the model imported using ThreeJS.
Art Contest
data:image/s3,"s3://crabby-images/5c3e8/5c3e81b9575b8d0b8c2cdb7e09d3e3fed23affab" alt=""