WIP - world generation
This commit is contained in:
parent
d2902ac4aa
commit
83415745ec
5 changed files with 53 additions and 54 deletions
|
@ -63,6 +63,11 @@ _global_script_classes=[ {
|
||||||
"class": "TrapTiles",
|
"class": "TrapTiles",
|
||||||
"language": "GDScript",
|
"language": "GDScript",
|
||||||
"path": "res://assets/Tiles/TrapTiles.gd"
|
"path": "res://assets/Tiles/TrapTiles.gd"
|
||||||
|
}, {
|
||||||
|
"base": "Area2D",
|
||||||
|
"class": "WarpZone",
|
||||||
|
"language": "GDScript",
|
||||||
|
"path": "res://src/Scripts/WarpZone.gd"
|
||||||
} ]
|
} ]
|
||||||
_global_script_class_icons={
|
_global_script_class_icons={
|
||||||
"CameraGame": "",
|
"CameraGame": "",
|
||||||
|
@ -75,7 +80,8 @@ _global_script_class_icons={
|
||||||
"Level": "",
|
"Level": "",
|
||||||
"Player": "",
|
"Player": "",
|
||||||
"Spike": "",
|
"Spike": "",
|
||||||
"TrapTiles": ""
|
"TrapTiles": "",
|
||||||
|
"WarpZone": ""
|
||||||
}
|
}
|
||||||
|
|
||||||
[application]
|
[application]
|
||||||
|
|
|
@ -26,14 +26,14 @@ var _levels = [
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
export var _current_zone_level: = Vector2(0,1)
|
export var _current_zone_level: = Vector2(0,0)
|
||||||
|
|
||||||
onready var _player:Player = (load("res://src/Actors/Player.tscn")).instance()
|
onready var _player:Player = (load("res://src/Actors/Player.tscn")).instance()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
_player.connect("died", self, "_on_player_died")
|
var _void = _player.connect("died", self, "_on_player_died")
|
||||||
_change_level(_current_zone_level)
|
_change_level(_current_zone_level)
|
||||||
yield(self, "level_ready")
|
yield(self, "level_ready")
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ func _change_level( newLevel:Vector2 = Vector2.ZERO, oldLevel:Vector2 = Vector2(
|
||||||
$Level.remove_child(_levels[oldLevel.x][oldLevel.y])
|
$Level.remove_child(_levels[oldLevel.x][oldLevel.y])
|
||||||
if !_levels[newLevel.x][newLevel.y].is_class("Node2D"):
|
if !_levels[newLevel.x][newLevel.y].is_class("Node2D"):
|
||||||
_levels[newLevel.x][newLevel.y] = _levels[newLevel.x][newLevel.y].instance()
|
_levels[newLevel.x][newLevel.y] = _levels[newLevel.x][newLevel.y].instance()
|
||||||
|
_levels[newLevel.x][newLevel.y].level_coords = newLevel
|
||||||
_levels[newLevel.x][newLevel.y].set_player(_player, _get_player_entering(oldLevel, newLevel))
|
_levels[newLevel.x][newLevel.y].set_player(_player, _get_player_entering(oldLevel, newLevel))
|
||||||
_levels[newLevel.x][newLevel.y].connect("level_exited", self, "_on_level_exited")
|
_levels[newLevel.x][newLevel.y].connect("level_exited", self, "_on_level_exited")
|
||||||
$Level.add_child(_levels[newLevel.x][newLevel.y])
|
$Level.add_child(_levels[newLevel.x][newLevel.y])
|
||||||
|
@ -73,18 +73,15 @@ func _on_player_died():
|
||||||
yield(Stage, "fade_finished")
|
yield(Stage, "fade_finished")
|
||||||
GameState.set_state(prev_state)
|
GameState.set_state(prev_state)
|
||||||
|
|
||||||
func _on_level_exited(next_level:bool = true, zone:int = -1):
|
func _on_level_exited(is_exit:bool, to_coords:Vector2, position:Vector2):
|
||||||
print("current level: %s, next_level: %s zone: %s" % [_current_zone_level, next_level, zone])
|
print("current level: %s, is_exit: %s to_coords: %s position %s" % [_current_zone_level, is_exit, to_coords, position])
|
||||||
var next = Vector2.ZERO
|
var next = Vector2.ZERO
|
||||||
if zone != -1:
|
if to_coords.x == -1: # The zone is to a specific plase
|
||||||
next = Vector2(
|
next = to_coords
|
||||||
zone,
|
|
||||||
0 if next_level else len(_levels[zone]) -1
|
|
||||||
)
|
|
||||||
else:
|
else:
|
||||||
next = Vector2(
|
next = Vector2(
|
||||||
_current_zone_level.x,
|
_current_zone_level.x,
|
||||||
_current_zone_level.y + 1 if next_level else _current_zone_level.y - 1
|
_current_zone_level.y + 1 if is_exit else _current_zone_level.y - 1
|
||||||
)
|
)
|
||||||
if next.y < 0:
|
if next.y < 0:
|
||||||
next.x -= 1
|
next.x -= 1
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -14,11 +14,9 @@ export var game_state = GameState.States.GAME
|
||||||
export var level_entry_point := Vector2.ZERO
|
export var level_entry_point := Vector2.ZERO
|
||||||
export var level_exit_point := Vector2.ZERO
|
export var level_exit_point := Vector2.ZERO
|
||||||
|
|
||||||
export var exit_area_2d_path : NodePath
|
var level_coords :=Vector2.ZERO
|
||||||
export var enter_area_2d_path : NodePath
|
export(Vector2) var prev_level = null
|
||||||
|
|
||||||
var _exit_area_2d = null;
|
|
||||||
var _enter_area_2d = null;
|
|
||||||
|
|
||||||
export var camer_limits := {
|
export var camer_limits := {
|
||||||
"top": 0,
|
"top": 0,
|
||||||
|
@ -28,24 +26,23 @@ export var camer_limits := {
|
||||||
}
|
}
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
self._exit_area_2d = get_node(exit_area_2d_path)
|
|
||||||
self._enter_area_2d = get_node(enter_area_2d_path)
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
func _set_active(activated:bool = true):
|
func _set_active(activated:bool, prev_level_:Vector2):
|
||||||
is_active_level = activated;
|
is_active_level = activated
|
||||||
|
self.prev_level = prev_level_
|
||||||
if activated:
|
if activated:
|
||||||
if _exit_area_2d != null: _exit_area_2d.connect("player_entered", self, "_on_ExitLevelAreaNext_player_entered")
|
for warp in _get_all_warps():
|
||||||
if _enter_area_2d != null: _enter_area_2d.connect("player_entered", self, "_on_ExitLevelArea_player_entered")
|
warp.connect("player_entered", self, "_on_WarpZone_player_entered")
|
||||||
emit_signal("level_ready")
|
emit_signal("level_ready")
|
||||||
|
|
||||||
func set_player(player:Player, is_entering:bool):
|
func set_player(player:Player, is_entering:bool, spesific_position=null):
|
||||||
_player = player
|
_player = player
|
||||||
_camera = _player.get_camera()
|
_camera = _player.get_camera()
|
||||||
_set_camera_limits()
|
_set_camera_limits()
|
||||||
_set_player_position(is_entering)
|
_set_player_position(is_entering, spesific_position)
|
||||||
add_child(player)
|
add_child(player)
|
||||||
|
|
||||||
func remove_player():
|
func remove_player():
|
||||||
|
@ -59,26 +56,25 @@ func _set_camera_limits():
|
||||||
_camera.limit_bottom = camer_limits.bottom
|
_camera.limit_bottom = camer_limits.bottom
|
||||||
_camera.limit_left = camer_limits.left
|
_camera.limit_left = camer_limits.left
|
||||||
|
|
||||||
func _set_player_position(is_entering:bool):
|
func _set_player_position(is_entering:bool, spesific_position=null):
|
||||||
|
if spesific_position != null:
|
||||||
|
_player.position = spesific_position
|
||||||
|
else:
|
||||||
_player.position = level_entry_point if is_entering else level_exit_point
|
_player.position = level_entry_point if is_entering else level_exit_point
|
||||||
_player.face_player(is_entering)
|
_player.face_player(is_entering)
|
||||||
_player.respawn_position = _player.position
|
_player.respawn_position = _player.position
|
||||||
|
|
||||||
func set_exit_area_enabled(enabled:bool=true):
|
|
||||||
if _exit_area_2d != null: _exit_area_2d.set_block_signals(enabled)
|
|
||||||
|
|
||||||
func set_enter_area_enabled(enabled:bool=true):
|
func _on_WarpZone_player_entered(is_exit, to_coords, position) -> void:
|
||||||
if _enter_area_2d != null: _enter_area_2d.set_block_signals(enabled)
|
print("_on_WarpZone_player_entered is_exit=%s to_coord=%s position=%s" % [is_exit, to_coords, position])
|
||||||
|
|
||||||
func _on_ExitLevelArea_player_entered(is_exit, zone) -> void:
|
|
||||||
print("_on_ExitLevelArea_player_entered")
|
|
||||||
self.is_active_level = false;
|
self.is_active_level = false;
|
||||||
emit_signal("level_exited", false)
|
emit_signal("level_exited", is_exit, to_coords)
|
||||||
pass # Replace with function body.
|
pass # Replace with function body.
|
||||||
|
|
||||||
|
|
||||||
func _on_ExitLevelAreaNext_player_entered(is_exit, zone) -> void:
|
func _get_all_warps():
|
||||||
print("_on_ExitLevelAreaNext_player_entered")
|
var warps := []
|
||||||
self.is_active_level = false;
|
for node in get_children():
|
||||||
emit_signal("level_exited", true)
|
if node.is_in_group("WarpZones"):
|
||||||
pass # Replace with function body.
|
warps.push_back(node)
|
||||||
|
return warps
|
|
@ -4,9 +4,14 @@ class_name WarpZone
|
||||||
|
|
||||||
signal player_entered
|
signal player_entered
|
||||||
|
|
||||||
export(int,-1, 3) var zone = -1;
|
var NON_SPECIFIED_LEVEL :=Vector2(-1, -1)
|
||||||
|
|
||||||
|
export var to_level_coord:Vector2 =NON_SPECIFIED_LEVEL
|
||||||
export var is_exit:bool = true
|
export var is_exit:bool = true
|
||||||
|
|
||||||
|
func _ready() -> void:
|
||||||
|
add_to_group("WarpZones")
|
||||||
|
|
||||||
func _on_body_entered(body:Node):
|
func _on_body_entered(body:Node):
|
||||||
if body.name == "Player" and get_parent().is_active_level:
|
if body.name == "Player" and get_parent().is_active_level:
|
||||||
emit_signal("player_entered", is_exit, zone)
|
emit_signal("player_entered", is_exit, to_level_coord, position)
|
||||||
|
|
Loading…
Reference in a new issue