mirror of
https://github.com/Relintai/broken_seals_roguelike.git
synced 2025-01-11 23:51:08 +01:00
Proper mob spawning.
This commit is contained in:
parent
8d34206fe3
commit
ae86236870
@ -217,7 +217,7 @@ func spawn_player(class_id : int, position : Vector3, name : String, node_name
|
|||||||
return createinfo.created_entity
|
return createinfo.created_entity
|
||||||
|
|
||||||
|
|
||||||
func spawn_mob(class_id : int, level : int, position : Vector3) -> void:
|
func spawn_mob(class_id : int, level : int, position : Vector3) -> Entity:
|
||||||
var createinfo : EntityCreateInfo = EntityCreateInfo.new()
|
var createinfo : EntityCreateInfo = EntityCreateInfo.new()
|
||||||
|
|
||||||
var cls : EntityData = ESS.get_resource_db().get_entity_data(class_id)
|
var cls : EntityData = ESS.get_resource_db().get_entity_data(class_id)
|
||||||
@ -230,7 +230,9 @@ func spawn_mob(class_id : int, level : int, position : Vector3) -> void:
|
|||||||
createinfo.entity_player_type = EntityEnums.ENTITY_PLAYER_TYPE_AI
|
createinfo.entity_player_type = EntityEnums.ENTITY_PLAYER_TYPE_AI
|
||||||
createinfo.transform2d.origin = Vector2(position.x, position.y)
|
createinfo.transform2d.origin = Vector2(position.x, position.y)
|
||||||
|
|
||||||
ESS.request_entity_spawn_deferred(createinfo)
|
ESS.request_entity_spawn(createinfo)
|
||||||
|
|
||||||
|
return createinfo.created_entity
|
||||||
|
|
||||||
# print("Mob spawned " + str(createinfo))
|
# print("Mob spawned " + str(createinfo))
|
||||||
|
|
||||||
|
@ -41,9 +41,11 @@ export(Vector2) var level_size : Vector2 = Vector2(40, 40)
|
|||||||
export(int) var level_room_count : int = 9
|
export(int) var level_room_count : int = 9
|
||||||
export(int) var min_room_dimension : int = 5
|
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
|
||||||
|
|
||||||
var map : Array = []
|
var map : Array = []
|
||||||
var rooms : Array = []
|
var rooms : Array = []
|
||||||
|
var enemies : Array = []
|
||||||
|
|
||||||
onready var tile_map : TileMap = $Terrarin
|
onready var tile_map : TileMap = $Terrarin
|
||||||
onready var visibility_map : TileMap = $VisibilityMap
|
onready var visibility_map : TileMap = $VisibilityMap
|
||||||
@ -58,8 +60,8 @@ func load_character(file_name: String) -> void:
|
|||||||
randomize()
|
randomize()
|
||||||
build_level()
|
build_level()
|
||||||
|
|
||||||
if spawn_mobs:
|
# if spawn_mobs:
|
||||||
generate()
|
# generate()
|
||||||
|
|
||||||
#Place player
|
#Place player
|
||||||
var start_room = rooms.front()
|
var start_room = rooms.front()
|
||||||
@ -69,6 +71,27 @@ func load_character(file_name: String) -> void:
|
|||||||
_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)
|
||||||
|
|
||||||
|
#Place enemies
|
||||||
|
for i in range(enemy_count):
|
||||||
|
var room = rooms[1 + randi() % (rooms.size() - 1)]
|
||||||
|
var x = room.position.x + 1 + randi() % int (room.size.x - 2)
|
||||||
|
var y = room.position.y + 1 + randi() % int (room.size.y - 2)
|
||||||
|
|
||||||
|
var blocked = false
|
||||||
|
for enemy in enemies:
|
||||||
|
var body = enemy.get_body()
|
||||||
|
var bp = body.get_tile_position()
|
||||||
|
if bp.x == x && bp.y == y:
|
||||||
|
blocked = true
|
||||||
|
break
|
||||||
|
|
||||||
|
if !blocked:
|
||||||
|
var t = tile_to_pixel_center(x, y)
|
||||||
|
var enemy = ESS.entity_spawner.spawn_mob(1, 1, Vector3(t.x, t.y, 0))
|
||||||
|
|
||||||
|
enemies.append(enemy)
|
||||||
|
|
||||||
|
|
||||||
tile_map.update_dirty_quadrants()
|
tile_map.update_dirty_quadrants()
|
||||||
|
|
||||||
call_deferred("update_visibility")
|
call_deferred("update_visibility")
|
||||||
@ -112,6 +135,11 @@ func is_position_walkable(x : int, y : int) -> bool:
|
|||||||
elif type == Tile.Stone:
|
elif type == Tile.Stone:
|
||||||
return false
|
return false
|
||||||
|
|
||||||
|
for e in enemies:
|
||||||
|
var pos : Vector2 = e.get_body().get_tile_position()
|
||||||
|
if pos.x == x && pos.y == y:
|
||||||
|
return false
|
||||||
|
|
||||||
return true
|
return true
|
||||||
|
|
||||||
func build_level():
|
func build_level():
|
||||||
@ -119,6 +147,11 @@ func build_level():
|
|||||||
map.clear()
|
map.clear()
|
||||||
tile_map.clear()
|
tile_map.clear()
|
||||||
|
|
||||||
|
for e in enemies:
|
||||||
|
e.queue_free()
|
||||||
|
|
||||||
|
enemies.clear()
|
||||||
|
|
||||||
for x in range(level_size.x):
|
for x in range(level_size.x):
|
||||||
map.append([])
|
map.append([])
|
||||||
for y in range(level_size.y):
|
for y in range(level_size.y):
|
||||||
|
Loading…
Reference in New Issue
Block a user