Coding Challenge 11: 3D Terrain Generation with Perlin Noise in Processing
In this coding challenge, I create a 3D procedural terrain using Perlin Noise and the beginShape() function in Processing. Code: https://thecodingtrain.com/challenges/11-3d-terrain-generation-with-perlin-noise š¹ļø p5.js Web Editor Sketch: https://editor.p5js.org/codingtrain/sketches/OPYPc4ueq š„ Previous video: https://youtu.be/HyK_Q5rrcr4?list=PLRqwX-V7Uu6ZiZxtDDRCi6uhfTH4FilpH š„ Next video: https://youtu.be/f0lkz2gSsIk?list=PLRqwX-V7Uu6ZiZxtDDRCi6uhfTH4FilpH š„ All videos: https://www.youtube.com/playlist?list=PLRqwX-V7Uu6ZiZxtDDRCi6uhfTH4FilpH References: š¾ beginShape() reference: https://processing.org/reference/beginShape_.html š¾ noise() reference: https://processing.org/reference/noise_.html Videos: š What is Perlin Noise?: https://thecodingtrain.com/tracks/the-nature-of-code-2/noc/perlin/perlin-noise-and-p5js-tutorial-intro š“ Coding Train Live 37: https://youtu.be/ELpZW62HGVs?t=1735s Related Coding Challenges: š #18 3D Fractal Trees: https://youtu.be/JcopTKXt8L8 š #24 Perlin Noise Flow Field: https://youtu.be/BjoM9oKOAKY š #112 3D Rendering with Rotation and Projection: https://youtu.be/p4Iz0XJY-Qk Timestamps: 00:00 Introduction to the Challenge 00:46 What do we need to do? 02:14 Draw a rectangular grid! 04:13 Create a flat triangle strip mesh! 06:51 Rotate the surface in 3D! 08:47 Set the z-values of the vertices randomly! 11:04 Create a 2D array to store the z values! 13:31 How do we make the terrain infinite? What is Perlin Noise? 17:03 How do we make the terrain smooth? 17:43 Reduce offsets to get smoother z values 19:17 How do we make it appear as if we are moving over the terrain? 20:30 Change y-offset per frame to create the illusion of flying! 22:05 Thanks for watching! Editing by Mathieu Blanchette Animations by Jason Heglund Music from Epidemic Sound š Website: http://thecodingtrain.com/ š¾ Share Your Creation! https://thecodingtrain.com/guides/passenger-showcase-guide š© Suggest Topics: https://github.com/CodingTrain/Suggestion-Box š” GitHub: https://github.com/CodingTrain š¬ Discord: https://discord.gg/hPuGy2g š Membership: http://youtube.com/thecodingtrain/join š Store: https://standard.tv/codingtrain šļø Twitter: https://twitter.com/thecodingtrain šø Instagram: https://www.instagram.com/the.coding.train/ š„ Coding Challenges: https://www.youtube.com/playlist?list=PLRqwX-V7Uu6ZiZxtDDRCi6uhfTH4FilpH š„ Intro to Programming: https://www.youtube.com/playlist?list=PLRqwX-V7Uu6Zy51Q-x9tMWIv9cueOFTFA š p5.js: https://p5js.org š p5.js Web Editor: https://editor.p5js.org/ š Processing: https://processing.org š Code of Conduct: https://github.com/CodingTrain/Code-of-Conduct This description was auto-generated. If you see a problem, please open an issue: https://github.com/CodingTrain/thecodingtrain.com/issues/new #perlinnoise #terraingeneration #procedural #processing