Compare commits
No commits in common. "515aab1a700833eccd4c1de921d454242ca9852c" and "0ac9d0fae8888381d52826f00108a3c4955ac9e5" have entirely different histories.
515aab1a70
...
0ac9d0fae8
|
|
@ -4,31 +4,15 @@
|
||||||
[ext_resource type="Script" uid="uid://cphrdy0xexx30" path="res://scenes/game.gd" id="1_vtaks"]
|
[ext_resource type="Script" uid="uid://cphrdy0xexx30" path="res://scenes/game.gd" id="1_vtaks"]
|
||||||
[ext_resource type="PackedScene" uid="uid://7vohdw0xop0g" path="res://scenes/worldborder.tscn" id="2_dinhu"]
|
[ext_resource type="PackedScene" uid="uid://7vohdw0xop0g" path="res://scenes/worldborder.tscn" id="2_dinhu"]
|
||||||
[ext_resource type="Script" uid="uid://coplu13jpw4xq" path="res://scripts/camera_2d.gd" id="3_kvpfn"]
|
[ext_resource type="Script" uid="uid://coplu13jpw4xq" path="res://scripts/camera_2d.gd" id="3_kvpfn"]
|
||||||
[ext_resource type="Script" uid="uid://b4jrogrq54c8f" path="res://scripts/SpawnEntry.gd" id="6_ir15t"]
|
|
||||||
[ext_resource type="Script" uid="uid://dovkm6w8af08x" path="res://scripts/spawn_control.gd" id="6_p57ef"]
|
[ext_resource type="Script" uid="uid://dovkm6w8af08x" path="res://scripts/spawn_control.gd" id="6_p57ef"]
|
||||||
[ext_resource type="PackedScene" uid="uid://ccotbw7gepsge" path="res://scenes/slime.tscn" id="7_ca42v"]
|
|
||||||
[ext_resource type="Texture2D" uid="uid://c4i3fnr6gpjp" path="res://assets/tileset/Tiled_files/details.png" id="7_gee14"]
|
[ext_resource type="Texture2D" uid="uid://c4i3fnr6gpjp" path="res://assets/tileset/Tiled_files/details.png" id="7_gee14"]
|
||||||
[ext_resource type="PackedScene" uid="uid://b4v0ntaukg2je" path="res://scenes/witch.tscn" id="7_u5sy4"]
|
[ext_resource type="PackedScene" uid="uid://b4v0ntaukg2je" path="res://scenes/witch.tscn" id="7_u5sy4"]
|
||||||
[ext_resource type="Texture2D" uid="uid://0xu8ohipv2mj" path="res://assets/tileset/Tiled_files/Objects.png" id="8_0tnpc"]
|
[ext_resource type="Texture2D" uid="uid://0xu8ohipv2mj" path="res://assets/tileset/Tiled_files/Objects.png" id="8_0tnpc"]
|
||||||
[ext_resource type="PackedScene" uid="uid://cj83ht5o2l8c1" path="res://scenes/blue_slime.tscn" id="8_rysoc"]
|
|
||||||
[ext_resource type="PackedScene" uid="uid://cgu7w2jd42f3a" path="res://scenes/tile_map_layer(background).tscn" id="8_vtaks"]
|
[ext_resource type="PackedScene" uid="uid://cgu7w2jd42f3a" path="res://scenes/tile_map_layer(background).tscn" id="8_vtaks"]
|
||||||
[ext_resource type="PackedScene" uid="uid://bgpsc6dvsn7ak" path="res://scenes/tile_map_layer(objects).tscn" id="9_kvpfn"]
|
[ext_resource type="PackedScene" uid="uid://bgpsc6dvsn7ak" path="res://scenes/tile_map_layer(objects).tscn" id="9_kvpfn"]
|
||||||
[ext_resource type="PackedScene" uid="uid://co8t1fr3b3kub" path="res://scenes/tile_map_layer(overlay).tscn" id="10_dinhu"]
|
[ext_resource type="PackedScene" uid="uid://co8t1fr3b3kub" path="res://scenes/tile_map_layer(overlay).tscn" id="10_dinhu"]
|
||||||
[ext_resource type="Script" uid="uid://ckv6prbe1o7s1" path="res://scripts/drop_manager.gd" id="10_vtaks"]
|
[ext_resource type="Script" uid="uid://ckv6prbe1o7s1" path="res://scripts/drop_manager.gd" id="10_vtaks"]
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_ssvqc"]
|
|
||||||
script = ExtResource("6_ir15t")
|
|
||||||
weight = 1.0
|
|
||||||
enemy = ExtResource("7_ca42v")
|
|
||||||
metadata/_custom_type_script = "uid://b4jrogrq54c8f"
|
|
||||||
|
|
||||||
[sub_resource type="Resource" id="Resource_264po"]
|
|
||||||
script = ExtResource("6_ir15t")
|
|
||||||
min_time = 10.0
|
|
||||||
weight = 0.5
|
|
||||||
enemy = ExtResource("8_rysoc")
|
|
||||||
metadata/_custom_type_script = "uid://b4jrogrq54c8f"
|
|
||||||
|
|
||||||
[sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_vtaks"]
|
[sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_vtaks"]
|
||||||
texture = ExtResource("7_gee14")
|
texture = ExtResource("7_gee14")
|
||||||
1:1/0 = 0
|
1:1/0 = 0
|
||||||
|
|
@ -2378,7 +2362,6 @@ anchors_preset = 0
|
||||||
offset_right = 40.0
|
offset_right = 40.0
|
||||||
offset_bottom = 40.0
|
offset_bottom = 40.0
|
||||||
script = ExtResource("6_p57ef")
|
script = ExtResource("6_p57ef")
|
||||||
spawn_entries = Array[ExtResource("6_ir15t")]([SubResource("Resource_ssvqc"), SubResource("Resource_264po")])
|
|
||||||
|
|
||||||
[node name="SpawnTimer" type="Timer" parent="." unique_id=1852920556]
|
[node name="SpawnTimer" type="Timer" parent="." unique_id=1852920556]
|
||||||
wait_time = 0.2
|
wait_time = 0.2
|
||||||
|
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
extends Resource
|
|
||||||
class_name SpawnEntry
|
|
||||||
@export var min_time: float
|
|
||||||
@export var weight: float
|
|
||||||
@export var enemy: PackedScene
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
uid://b4jrogrq54c8f
|
|
||||||
|
|
@ -5,8 +5,6 @@ var down_right
|
||||||
var up_right
|
var up_right
|
||||||
var down_left
|
var down_left
|
||||||
var viewport_rect
|
var viewport_rect
|
||||||
var elapsed_time = 0.0
|
|
||||||
@export var spawn_entries: Array[SpawnEntry]
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
var camera: Camera2D = get_parent().get_node("Camera2D")
|
var camera: Camera2D = get_parent().get_node("Camera2D")
|
||||||
|
|
@ -19,7 +17,6 @@ func _ready() -> void:
|
||||||
up_right = Vector2(down_right.x, up_left.y)
|
up_right = Vector2(down_right.x, up_left.y)
|
||||||
down_left = Vector2(up_left.x, down_right.y)
|
down_left = Vector2(up_left.x, down_right.y)
|
||||||
|
|
||||||
|
|
||||||
func get_spawn_position() -> Vector2:
|
func get_spawn_position() -> Vector2:
|
||||||
var side = randi() % 4
|
var side = randi() % 4
|
||||||
var spawn_x
|
var spawn_x
|
||||||
|
|
@ -43,28 +40,15 @@ func get_spawn_position() -> Vector2:
|
||||||
return Vector2(spawn_x, spawn_y)
|
return Vector2(spawn_x, spawn_y)
|
||||||
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
func _process(delta: float) -> void:
|
func _process(delta: float) -> void:
|
||||||
elapsed_time += delta
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
func spawn_enemy() -> void:
|
func spawn_enemy() -> void:
|
||||||
var sum_weight = 0.0
|
var enemy_scene = preload("res://scenes/blue_slime.tscn")
|
||||||
var available = []
|
var enemy = enemy_scene.instantiate()
|
||||||
for entry in spawn_entries:
|
|
||||||
if entry.min_time <= elapsed_time:
|
|
||||||
available.append(entry)
|
|
||||||
sum_weight += entry.weight
|
|
||||||
var roll = randf() * sum_weight
|
|
||||||
var winner = null
|
|
||||||
for entry in available:
|
|
||||||
roll -= entry.weight
|
|
||||||
if roll <= 0:
|
|
||||||
winner = entry
|
|
||||||
break
|
|
||||||
if winner == null:
|
|
||||||
return
|
|
||||||
var enemy = winner.enemy.instantiate()
|
|
||||||
enemy.global_position = get_spawn_position()
|
enemy.global_position = get_spawn_position()
|
||||||
add_child(enemy)
|
add_child(enemy)
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
func _on_spawn_timer_timeout() -> void:
|
func _on_spawn_timer_timeout() -> void:
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue