mirror of
https://github.com/Relintai/broken_seals.git
synced 2025-01-04 13:39:36 +01:00
Implemented a teleporter, it has a test cube mesh with the brick texture for now, and made the dungeon spawn it. Also work on setting up the dungeon generation.
This commit is contained in:
parent
4084debdad
commit
f96a66300b
@ -43,6 +43,9 @@ func _generate_chunk(chunk: VoxelChunk, spawn_mobs: bool) -> void:
|
|||||||
|
|
||||||
# generate_terrarin(chunk, spawn_mobs)
|
# generate_terrarin(chunk, spawn_mobs)
|
||||||
|
|
||||||
|
for i in range(get_dungeon_count()):
|
||||||
|
get_dungeon(i).generate_chunk(chunk, spawn_mobs)
|
||||||
|
|
||||||
generate_simple_terrarin(chunk, spawn_mobs)
|
generate_simple_terrarin(chunk, spawn_mobs)
|
||||||
|
|
||||||
if not Engine.editor_hint and chunk.position_y == 0 and spawn_mobs and randi() % 4 == 0:
|
if not Engine.editor_hint and chunk.position_y == 0 and spawn_mobs and randi() % 4 == 0:
|
||||||
|
40
game/modules/planets/test_planet/dungeons/dung_teleporter.gd
Normal file
40
game/modules/planets/test_planet/dungeons/dung_teleporter.gd
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
extends StaticBody
|
||||||
|
|
||||||
|
export(Color) var default_albedo : Color = Color(0.494118, 0.494118, 0.494118)
|
||||||
|
export(Color) var hover_albedo : Color = Color(0.65098, 0.65098, 0.65098)
|
||||||
|
|
||||||
|
var teleport_to : Vector3 = Vector3()
|
||||||
|
|
||||||
|
func _ready():
|
||||||
|
connect("mouse_entered", self, "on_mouse_entered")
|
||||||
|
connect("mouse_exited", self, "on_mouse_exited")
|
||||||
|
|
||||||
|
var mat = $MeshInstance.get_surface_material(0)
|
||||||
|
mat.albedo_color = default_albedo
|
||||||
|
|
||||||
|
func on_mouse_entered():
|
||||||
|
var mat = $MeshInstance.get_surface_material(0)
|
||||||
|
mat.albedo_color = hover_albedo
|
||||||
|
|
||||||
|
Input.set_default_cursor_shape(Input.CURSOR_POINTING_HAND)
|
||||||
|
|
||||||
|
func on_mouse_exited():
|
||||||
|
var mat = $MeshInstance.get_surface_material(0)
|
||||||
|
mat.albedo_color = default_albedo
|
||||||
|
|
||||||
|
Input.set_default_cursor_shape(Input.CURSOR_ARROW)
|
||||||
|
|
||||||
|
func _input_event(camera: Object, event: InputEvent, click_position: Vector3, click_normal: Vector3, shape_idx: int):
|
||||||
|
if event is InputEventMouseButton && !event.pressed:
|
||||||
|
teleport()
|
||||||
|
|
||||||
|
if event is InputEventScreenTouch && !event.pressed:
|
||||||
|
teleport()
|
||||||
|
|
||||||
|
func teleport():
|
||||||
|
var world = get_node("..")
|
||||||
|
|
||||||
|
if world && world._player:
|
||||||
|
var p : Entity = world._player
|
||||||
|
|
||||||
|
p.get_body().transform.origin = teleport_to
|
@ -0,0 +1,27 @@
|
|||||||
|
[gd_scene load_steps=6 format=2]
|
||||||
|
|
||||||
|
[ext_resource path="res://modules/planets/test_planet/dungeons/dung_teleporter.gd" type="Script" id=1]
|
||||||
|
[ext_resource path="res://modules/planets/test_planet/voxel_library/textures/test_brick_albedo.png" type="Texture" id=2]
|
||||||
|
|
||||||
|
[sub_resource type="CubeMesh" id=1]
|
||||||
|
size = Vector3( 1, 1, 1 )
|
||||||
|
|
||||||
|
[sub_resource type="SpatialMaterial" id=3]
|
||||||
|
flags_vertex_lighting = true
|
||||||
|
albedo_color = Color( 0.494118, 0.494118, 0.494118, 1 )
|
||||||
|
albedo_texture = ExtResource( 2 )
|
||||||
|
|
||||||
|
[sub_resource type="BoxShape" id=2]
|
||||||
|
extents = Vector3( 0.5, 0.5, 0.5 )
|
||||||
|
|
||||||
|
[node name="DungeonTeleporter" type="StaticBody"]
|
||||||
|
script = ExtResource( 1 )
|
||||||
|
default_albedo = Color( 0.521569, 0.521569, 0.521569, 1 )
|
||||||
|
hover_albedo = Color( 0.65098, 0.65098, 0.65098, 1 )
|
||||||
|
|
||||||
|
[node name="MeshInstance" type="MeshInstance" parent="."]
|
||||||
|
mesh = SubResource( 1 )
|
||||||
|
material/0 = SubResource( 3 )
|
||||||
|
|
||||||
|
[node name="CollisionShape" type="CollisionShape" parent="."]
|
||||||
|
shape = SubResource( 2 )
|
@ -26,11 +26,15 @@ export(int) var min_room_dimension : int = 5
|
|||||||
export(int) var max_room_dimension : int = 8
|
export(int) var max_room_dimension : int = 8
|
||||||
export(int) var enemy_count : int = 14
|
export(int) var enemy_count : int = 14
|
||||||
|
|
||||||
|
export(MeshDataResource) var dung_entrance_mdr : MeshDataResource = null
|
||||||
|
export(PackedScene) var dung_entrance_scene : PackedScene = null
|
||||||
|
|
||||||
var map : Array = []
|
var map : Array = []
|
||||||
var rooms : Array = []
|
var rooms : Array = []
|
||||||
var enemies : Array = []
|
var enemies : Array = []
|
||||||
#var nav_graph : AStar2D
|
#var nav_graph : AStar2D
|
||||||
var entrance_position : Transform = Transform()
|
var entrance_position : Transform = Transform()
|
||||||
|
var inner_entrance_position : Vector3 = Vector3()
|
||||||
|
|
||||||
enum Tile { None, Floor, Wall, Door }
|
enum Tile { None, Floor, Wall, Door }
|
||||||
|
|
||||||
@ -39,6 +43,9 @@ func _setup():
|
|||||||
print("Dungeon size is 0!")
|
print("Dungeon size is 0!")
|
||||||
return
|
return
|
||||||
|
|
||||||
|
entrance_position.origin = Vector3(7, 5, 7)
|
||||||
|
inner_entrance_position = Vector3(10,10,10)
|
||||||
|
|
||||||
# if data.get_dungeon_start_room_data_count() == 0:
|
# if data.get_dungeon_start_room_data_count() == 0:
|
||||||
# return
|
# return
|
||||||
#
|
#
|
||||||
@ -54,18 +61,37 @@ func _setup():
|
|||||||
# dung.setup()
|
# dung.setup()
|
||||||
#
|
#
|
||||||
# add_dungeon_start_room(dung)
|
# add_dungeon_start_room(dung)
|
||||||
# build()
|
|
||||||
pass
|
|
||||||
|
|
||||||
func _setup_library(library):
|
build()
|
||||||
._setup_library(library)
|
#
|
||||||
|
#func _setup_library(library):
|
||||||
for i in range(get_dungeon_start_room_count()):
|
# ._setup_library(library)
|
||||||
get_dungeon_start_room(i).setup_library(library)
|
#
|
||||||
|
# for i in range(get_dungeon_start_room_count()):
|
||||||
|
# get_dungeon_start_room(i).setup_library(library)
|
||||||
|
|
||||||
func _generate_chunk(chunk, spawn_mobs):
|
func _generate_chunk(chunk, spawn_mobs):
|
||||||
for i in range(get_dungeon_start_room_count()):
|
var aabb : AABB = AABB(Vector3(posx, posy, posz) * chunk.get_voxel_scale(), Vector3(sizex, sizey, sizez) * chunk.get_voxel_scale())
|
||||||
get_dungeon_start_room(i).generate_chunk(chunk, spawn_mobs)
|
var chunk_aabb : AABB = AABB(chunk.get_position() * Vector3(chunk.size_x, chunk.size_y, chunk.size_z) * chunk.get_voxel_scale(), Vector3(chunk.size_x, chunk.size_y, chunk.size_z) * chunk.get_voxel_scale())
|
||||||
|
|
||||||
|
# if dung_entrance_mdr && chunk_aabb.has_point(entrance_position.origin):
|
||||||
|
#todo chunk needs an add func that takes global coords
|
||||||
|
# chunk.add_mesh_data_resource(entrance_position, dung_entrance_mdr)
|
||||||
|
|
||||||
|
if dung_entrance_scene && chunk_aabb.has_point(entrance_position.origin):
|
||||||
|
call_deferred("spawn_teleporter_scene", dung_entrance_scene, entrance_position, chunk, inner_entrance_position)
|
||||||
|
|
||||||
|
if !aabb.intersects(chunk_aabb):
|
||||||
|
return
|
||||||
|
|
||||||
|
# for i in range(get_dungeon_start_room_count()):
|
||||||
|
# get_dungeon_start_room(i).generate_chunk(chunk, spawn_mobs)
|
||||||
|
|
||||||
|
func spawn_teleporter_scene(scene : PackedScene, transform : Transform, chunk : VoxelChunk, teleports_to : Vector3):
|
||||||
|
var s = scene.instance()
|
||||||
|
chunk.get_voxel_world().add_child(s)
|
||||||
|
s.transform = transform
|
||||||
|
s.teleport_to = teleports_to
|
||||||
|
|
||||||
func build():
|
func build():
|
||||||
# randomize()
|
# randomize()
|
||||||
@ -76,6 +102,7 @@ func build():
|
|||||||
# var player_x = start_room.position.x + 1 + randi() % int(start_room.size.x - 2)
|
# var player_x = start_room.position.x + 1 + randi() % int(start_room.size.x - 2)
|
||||||
# var player_y = start_room.position.y + 1 + randi() % int(start_room.size.y - 2)
|
# var player_y = start_room.position.y + 1 + randi() % int(start_room.size.y - 2)
|
||||||
|
|
||||||
|
#inner_entrance_position!
|
||||||
# entrance_position.origin = Vector2(player_x * tile_size + tile_size / 2, player_y * tile_size + tile_size / 2)
|
# entrance_position.origin = Vector2(player_x * tile_size + tile_size / 2, player_y * tile_size + tile_size / 2)
|
||||||
# _player = ESS.entity_spawner.load_player(_player_file_name, pos, 1) as Entity
|
# _player = ESS.entity_spawner.load_player(_player_file_name, pos, 1) as Entity
|
||||||
#Server.sset_seed(_player.sseed)
|
#Server.sset_seed(_player.sseed)
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
[gd_resource type="Dungeon" load_steps=2 format=2]
|
[gd_resource type="Dungeon" load_steps=4 format=2]
|
||||||
|
|
||||||
[ext_resource path="res://modules/planets/test_planet/dungeons/dungeon.gd" type="Script" id=1]
|
[ext_resource path="res://modules/planets/test_planet/dungeons/dungeon.gd" type="Script" id=1]
|
||||||
|
[ext_resource path="res://modules/species/Human/Female/character_models/huf_calf_left.gltf" type="MeshDataResource" id=2]
|
||||||
|
[ext_resource path="res://modules/planets/test_planet/dungeons/dung_teleporter.tscn" type="PackedScene" id=3]
|
||||||
|
|
||||||
[resource]
|
[resource]
|
||||||
sizex = 40
|
sizex = 40
|
||||||
@ -11,3 +13,5 @@ level_room_count = 9
|
|||||||
min_room_dimension = 5
|
min_room_dimension = 5
|
||||||
max_room_dimension = 8
|
max_room_dimension = 8
|
||||||
enemy_count = 14
|
enemy_count = 14
|
||||||
|
dung_entrance_mdr = ExtResource( 2 )
|
||||||
|
dung_entrance_scene = ExtResource( 3 )
|
||||||
|
@ -49,7 +49,7 @@ var rc : int = 0
|
|||||||
|
|
||||||
func _enter_tree():
|
func _enter_tree():
|
||||||
if generate_on_ready and not Engine.is_editor_hint():
|
if generate_on_ready and not Engine.is_editor_hint():
|
||||||
# This crases pretty reliably, when duplicatiog BiomeBase, not yet sure why exactly
|
# This crashes pretty reliably, when duplicatiog BiomeBase, not yet sure why exactly
|
||||||
# call_deferred("generate")
|
# call_deferred("generate")
|
||||||
generate()
|
generate()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user