summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordusoleil <howcansocksbereal@gmail.com>2022-09-19 06:28:21 -0400
committerdusoleil <howcansocksbereal@gmail.com>2022-09-19 06:28:21 -0400
commit9bc2a0767e15d4dde7fd6231b07882d6456af71e (patch)
tree1cc9b88eadf86c7df16ed01418cf64d0c8b92d3b
parent354287265bda1448935c05e76455cff18d57f5da (diff)
downloadgodot_wildjam_49-9bc2a0767e15d4dde7fd6231b07882d6456af71e.tar.gz
godot_wildjam_49-9bc2a0767e15d4dde7fd6231b07882d6456af71e.zip
Use MultiMesh to dramatically increase performance of generated world
-rw-r--r--world/World.gd2
-rw-r--r--world/chunk/Chunk.gd1
-rw-r--r--world/chunk/ChunkGen.gd36
-rw-r--r--world/chunk/ChunkLoader.gd13
-rw-r--r--world/obstacles/Rock.tscn33
-rw-r--r--world/obstacles/Rock_mat.tres21
-rw-r--r--world/obstacles/Rock_mesh.tres4
7 files changed, 66 insertions, 44 deletions
diff --git a/world/World.gd b/world/World.gd
index af2ba6a..2c8d822 100644
--- a/world/World.gd
+++ b/world/World.gd
@@ -33,7 +33,7 @@ func _on_ChunkRenderClose_area_entered(area:Area):
area.lod_update()
func _on_ChunkRenderDistance_area_exited(area:Area):
- area.queue_free()
+ ChunkLoader.free_chunk(chunk_coords(v2_coords(area.transform.origin)))
func _on_ChunkRenderMid_area_exited(area:Area):
area.lod = area.LOD.DISTANCE
diff --git a/world/chunk/Chunk.gd b/world/chunk/Chunk.gd
index 7c5c1c3..1860c84 100644
--- a/world/chunk/Chunk.gd
+++ b/world/chunk/Chunk.gd
@@ -4,6 +4,7 @@ enum LOD {DISTANCE,MID,CLOSE}
var lod = -1
func lod_update():
+ return
for obj in $"gen_tree".get_children():
match lod:
LOD.CLOSE:
diff --git a/world/chunk/ChunkGen.gd b/world/chunk/ChunkGen.gd
index d60b2e5..75d3736 100644
--- a/world/chunk/ChunkGen.gd
+++ b/world/chunk/ChunkGen.gd
@@ -12,8 +12,9 @@ onready var rng = RandomNumberGenerator.new()
var _seed
func _ready():
- randomize()
- self._seed = randi()
+ #randomize()
+ #self._seed = randi()
+ self._seed = 0
self.noise.seed = self._seed
self.noise.seed = 0
self.noise.period = 16
@@ -27,7 +28,7 @@ func gen_chunk(chunk):
var gen_tree = Spatial.new()
gen_tree.name = "gen_tree"
chunk.add_child(gen_tree)
- iterate_chunk(chunk, Vector2(10.0,10.0), funcref(self,"gen_rocks"))
+ gen_rocks(chunk)
func v2_coords(coords:Vector3):
return Vector2(coords.x,coords.z)
@@ -41,14 +42,9 @@ func iterate_chunk(chunk,step:Vector2,cb:FuncRef):
for y in range(-chunk_size_rounded.y,chunk_size_rounded.y,step.y):
cb.call_func(chunk,Vector2(x,y))
-onready var Rock = preload("res://world/obstacles/Rock.tscn")
-const rock_size = 5.0
-func make_rock(chunk,xform:Transform):
- var rock = Rock.instance()
- rock.transform = xform
- chunk.get_node("gen_tree").add_child(rock)
-
-func gen_rocks(chunk,chunk_coords:Vector2):
+var rock_mesh = preload("res://world/obstacles/Rock_mesh.tres")
+var rock_mat = preload("res://world/obstacles/Rock_mat.tres")
+func make_rock(chunk,chunk_coords:Vector2):
var coords = v3_coords(chunk_coords)
var basis = Basis()
var world_coords = chunk_coords + v2_coords(chunk.transform.origin)
@@ -64,4 +60,20 @@ func gen_rocks(chunk,chunk_coords:Vector2):
noise_val = lerp(1.0,4.0,noise_val)
basis = basis.scaled(Vector3.ONE*noise_val)
coords.y += (noise_val*5.0)-5.0
- make_rock(chunk,Transform(basis,coords))
+ var gen_tree = chunk.get_node("gen_tree")
+ var rocks = gen_tree.get_node("rocks").multimesh
+ rocks.visible_instance_count += 1
+ rocks.set_instance_transform(rocks.visible_instance_count-1, Transform(basis,coords))
+
+func gen_rocks(chunk):
+ var multi_inst = MultiMeshInstance.new()
+ multi_inst.name = "rocks"
+ var multi = MultiMesh.new()
+ multi_inst.multimesh = multi
+ chunk.get_node("gen_tree").add_child(multi_inst)
+ multi.transform_format = MultiMesh.TRANSFORM_3D
+ multi.instance_count = 1000
+ multi.visible_instance_count = 0
+ multi.mesh = rock_mesh
+ rock_mesh.material = rock_mat
+ iterate_chunk(chunk, Vector2(10.0,10.0), funcref(self,"make_rock"))
diff --git a/world/chunk/ChunkLoader.gd b/world/chunk/ChunkLoader.gd
index 9f1d9b3..2e01bca 100644
--- a/world/chunk/ChunkLoader.gd
+++ b/world/chunk/ChunkLoader.gd
@@ -24,6 +24,14 @@ func _exit_tree():
func add_chunk(coords:Vector2):
chunks[coords] = coords.length()
+func free_chunk(coords:Vector2):
+ if !loaded_chunks.has(coords):
+ return
+ var c = loaded_chunks[coords].get_ref()
+ if c != null:
+ c.queue_free()
+ loaded_chunks.erase(coords)
+
func chunk_update():
var closest_unloaded_chunk = null
var closest_len = 0.0
@@ -40,10 +48,7 @@ func chunk_update():
mtx.unlock()
for chunk in loaded_chunks.keys():
if !chunks.has(chunk):
- var c = loaded_chunks[chunk].get_ref()
- if c != null:
- c.queue_free()
- loaded_chunks.erase(chunk)
+ free_chunk(chunk)
chunks = {}
func chunk_loader():
diff --git a/world/obstacles/Rock.tscn b/world/obstacles/Rock.tscn
index 3b50ff3..819e9a8 100644
--- a/world/obstacles/Rock.tscn
+++ b/world/obstacles/Rock.tscn
@@ -1,34 +1,13 @@
-[gd_scene load_steps=10 format=2]
+[gd_scene load_steps=7 format=2]
[ext_resource path="res://world/obstacles/Rock.gd" type="Script" id=1]
[ext_resource path="res://world/chunk/helper/ChunkedMeshInstance.gd" type="Script" id=2]
+[ext_resource path="res://world/obstacles/Rock_mesh.tres" type="PrismMesh" id=3]
+[ext_resource path="res://world/obstacles/Rock_mat.tres" type="Material" id=4]
[sub_resource type="ConvexPolygonShape" id=2]
points = PoolVector3Array( 2.5, -5, 2.5, 2.5, -5, -2.5, -2.5, -5, -2.5, -2.5, -5, 2.5, 0, 5, 2.5, 0, 5, -2.5 )
-[sub_resource type="OpenSimplexNoise" id=3]
-octaves = 4
-period = 32.0
-
-[sub_resource type="NoiseTexture" id=4]
-noise = SubResource( 3 )
-
-[sub_resource type="NoiseTexture" id=5]
-seamless = true
-as_normalmap = true
-bump_strength = 32.0
-noise = SubResource( 3 )
-
-[sub_resource type="SpatialMaterial" id=6]
-albedo_color = Color( 0.231373, 0.231373, 0.231373, 1 )
-albedo_texture = SubResource( 4 )
-normal_enabled = true
-normal_scale = 1.0
-normal_texture = SubResource( 5 )
-
-[sub_resource type="PrismMesh" id=1]
-size = Vector3( 5, 10, 5 )
-
[sub_resource type="CubeMesh" id=9]
size = Vector3( 5, 10, 5 )
@@ -42,12 +21,12 @@ shape = SubResource( 2 )
[node name="MeshInstance" type="MeshInstance" parent="."]
visible = false
-material_override = SubResource( 6 )
+material_override = ExtResource( 4 )
script = ExtResource( 2 )
-_mesh = SubResource( 1 )
+_mesh = ExtResource( 3 )
[node name="MeshInstance2" type="MeshInstance" parent="."]
visible = false
-material_override = SubResource( 6 )
+material_override = ExtResource( 4 )
script = ExtResource( 2 )
_mesh = SubResource( 9 )
diff --git a/world/obstacles/Rock_mat.tres b/world/obstacles/Rock_mat.tres
new file mode 100644
index 0000000..8547487
--- /dev/null
+++ b/world/obstacles/Rock_mat.tres
@@ -0,0 +1,21 @@
+[gd_resource type="SpatialMaterial" load_steps=4 format=2]
+
+[sub_resource type="OpenSimplexNoise" id=3]
+octaves = 4
+period = 32.0
+
+[sub_resource type="NoiseTexture" id=4]
+noise = SubResource( 3 )
+
+[sub_resource type="NoiseTexture" id=5]
+seamless = true
+as_normalmap = true
+bump_strength = 32.0
+noise = SubResource( 3 )
+
+[resource]
+albedo_color = Color( 0.231373, 0.231373, 0.231373, 1 )
+albedo_texture = SubResource( 4 )
+normal_enabled = true
+normal_scale = 1.0
+normal_texture = SubResource( 5 )
diff --git a/world/obstacles/Rock_mesh.tres b/world/obstacles/Rock_mesh.tres
new file mode 100644
index 0000000..bced5b6
--- /dev/null
+++ b/world/obstacles/Rock_mesh.tres
@@ -0,0 +1,4 @@
+[gd_resource type="PrismMesh" format=2]
+
+[resource]
+size = Vector3( 5, 10, 5 )