data:image/s3,"s3://crabby-images/17e0f/17e0f1f4331faeda51970280efcfeff20435bfff" alt="IntentionBackground_edited.jpg"
data:image/s3,"s3://crabby-images/c7b0d/c7b0de90ee6b3d5277b819a1a4c84edf9b20b989" alt="IntentionBackground_edited.jpg"
Intention - 2018
Survival, RPG
Survive the Darkness, Learn What it Means to Become Omnipotent...
Intention is an exploration, boss-rush, RPG, survival game, set in a world where all hope is lost.
data:image/s3,"s3://crabby-images/51c09/51c09728c376e008c9219b7b757210679ea23bcb" alt="unity icon_dark.png"
data:image/s3,"s3://crabby-images/7683b/7683b2d6bcb099eb870e10d9e1b0429e6e8d1808" alt="c#icon_dark.png"
About
Intention, is my main side project. I started making Intention back in 2018 and it has served as a large part of my learning process. Intention is by far my largest scoped game and also my most documented. Set out to be a survival RPG, the core gameplay is focused on fighting bosses whilst telling a subtle but meaningful story through boss dialogue and item descriptions.
Terrain
All the terrain in Intention is procedually generated using a mixture of noise algorithms, all blended together, to make more natural looking terrain. The terrain is generated on a chunk by chunk basis on a seperate CPU thread. It is calculated by first getting the ground height to create hills and mountains. Then to create caves, any voxels below the hill height are cut out using another noise set. Using another noise set, ores are placed in clumps throughout the cave system.
Marching Cubes
Once a chunk receives its terrain data it uses another algorithm called marching cubes to form a mesh. This works by deviding the whole chunk into smaller cubes (cells). Then for each cell we calculate what triangles need to be added to the mesh. To do this, each corner of the cell is checked if its inside of the terrain or outside, then we insert this value into the corresponding bit of a byte. Once all corners are checked, we have a byte where each bit represents whether the voxel is empty or not. We then use that byte in a lookup table containing all 256 possible triangulation formations. All triangles are then added to the chunk mesh.
Octree Algorithm
Because a lot of chunks will contain groups of the same voxel, a lot of cells wont get drawn because they are either empty or hidden underground. Therefore the marching cube algorithm can be optimised by storing the chunk data in an octree data structure. A recursive loop goes down each branch in the octree. If a node is reached with all voxels being the same type, then the search won't continue down any child branches, saving the ray marching algorithm from having to calculate what would be nothing.
Terrain Modification
Because the terrain is stored as a bunch of points, we can actually modify the voxels at runtime, resulting in fully destructable terrian. To allow the player to place and remove voxels, we raycast into the scene until a point is hit. Then we calculate what voxel is the closest and that voxel is modified. The chunk mesh is then recalculated.
Features
-
Fully destructible terrain
-
Procedural terrain generation
-
Chunk loading and saving
-
Marching cubes
-
Multi threading
Screenshots
data:image/s3,"s3://crabby-images/3ee6a/3ee6a8f4e1c38c39ea7b3eac701038b75ea869dd" alt="intention"
data:image/s3,"s3://crabby-images/a4b4a/a4b4af35e2c759391dba1513d4f2a20f80488d09" alt=""
data:image/s3,"s3://crabby-images/d967a/d967a9bf156c1de2096d0fc25093d7384ca636ef" alt="biomes"
data:image/s3,"s3://crabby-images/1d67f/1d67f48583d7b0ced3fc3eb3d384f9f28b67a65c" alt="cave3.jpg"
data:image/s3,"s3://crabby-images/1dfc6/1dfc65b0f782d3bf518d8e1a8d4d711b312b3286" alt="cave1.jpg"
data:image/s3,"s3://crabby-images/45505/455056bb988464cd68cc9b99918c50bc83bc9cf3" alt="cave2.jpg"
data:image/s3,"s3://crabby-images/6392d/6392d3947e61f4b29a6893b175981f2b851887e3" alt="titlescreen.jpg"
data:image/s3,"s3://crabby-images/87fe8/87fe82f8a4ca73a010351f8c33e5656ce44fe5b5" alt="hills.jpg"