Compare commits

...

11 Commits

Author SHA1 Message Date
Artur David 34e5e4560e add uid file 2026-06-02 09:13:59 +02:00
Artur David d995df7279 fixed spell library reference in debug menu 2026-06-02 09:10:55 +02:00
Artur David dd202b719a fixed spell library type inference error 2026-06-02 09:09:35 +02:00
Artur David cef6dd5a21 wired debug menu into game scene 2026-06-02 09:08:27 +02:00
Artur David 381bfd9e3d added debug menu 2026-06-02 09:07:23 +02:00
Artur David 16aeec7e12 fixed missing level_up_disabled guard in on_enemy_died 2026-06-02 09:06:06 +02:00
Artur David 46639221c5 added level up disable flag and force level up to drop manager 2026-06-02 09:05:16 +02:00
Artur David cb9ed7d0ec fixed fruits not being removed after collection 2026-06-02 08:48:12 +02:00
Artur David f3c7146367 renamed variable and added safety check 2026-06-02 08:39:01 +02:00
Artur David 7fe0990949 made fruits drop less when there are too many on screen 2026-06-02 08:34:03 +02:00
Artur David e7e0e2ce9f added fruit drop limit variables 2026-06-02 08:32:41 +02:00
5 changed files with 146 additions and 2 deletions

View File

@ -3,8 +3,11 @@ extends Node2D
@onready var _timer_label: Label = $CanvasLayer/TimerLabel
@onready var _spawn_control = $SpawnControl
var _debug_menu_script = preload("res://scripts/debug_menu.gd")
func _ready():
MusicManager.play(preload("res://assets/music&sfx/music/ashveil-355633.mp3"))
add_child(_debug_menu_script.new())
func _process(_delta: float) -> void:
var t = int(_spawn_control.elapsed_time)

View File

@ -62,3 +62,5 @@ func collect():
var scale_tween = create_tween()
collected.emit(self)
scale_tween.tween_property(self, "scale", Vector2.ZERO,0.2)
await scale_tween.finished
queue_free()

View File

@ -0,0 +1,118 @@
extends CanvasLayer
@onready var _spawn_control = get_node("/root/Game/SpawnControl")
@onready var _witch = get_node("/root/Game/Witch")
@onready var _drop_manager = get_node("/root/Game/DropManager")
var _spell_dispatch: Dictionary
var _lvl_disable_btn: Button
func _ready() -> void:
layer = 10
_spell_dispatch = {
SpellLibrary.FIREBALL: _witch.shoot_fireballs,
SpellLibrary.SHURIKEN: _witch.shoot_shuriken,
SpellLibrary.FIRE_SWIRL: _witch.shoot_fire_swirl,
SpellLibrary.TORNADO: _witch.shoot_tornado,
}
_build_ui()
hide()
func _exit_tree() -> void:
Engine.time_scale = 1.0
func _unhandled_input(event: InputEvent) -> void:
if event is InputEventKey and event.pressed and not event.echo:
if event.keycode == KEY_D and event.ctrl_pressed:
visible = not visible
get_viewport().set_input_as_handled()
func _build_ui() -> void:
var panel := PanelContainer.new()
var style := StyleBoxFlat.new()
style.bg_color = Color(0.0, 0.0, 0.0, 0.75)
panel.add_theme_stylebox_override("panel", style)
panel.anchor_left = 1.0
panel.anchor_right = 1.0
panel.anchor_top = 0.0
panel.anchor_bottom = 1.0
panel.offset_left = -220
panel.offset_right = 0
add_child(panel)
var scroll := ScrollContainer.new()
scroll.horizontal_scroll_mode = ScrollContainer.SCROLL_MODE_DISABLED
panel.add_child(scroll)
var vbox := VBoxContainer.new()
vbox.custom_minimum_size = Vector2(210, 0)
vbox.add_theme_constant_override("separation", 4)
scroll.add_child(vbox)
_add_section(vbox, "ENEMIES")
_add_button(vbox, "Kill All", _kill_all_enemies)
_add_section(vbox, "TIME SCALE")
var hbox_scale := HBoxContainer.new()
vbox.add_child(hbox_scale)
for s in [1, 2, 5, 10]:
var btn := Button.new()
btn.text = "%dx" % s
btn.size_flags_horizontal = Control.SIZE_EXPAND_FILL
btn.pressed.connect(_set_time_scale.bind(float(s)))
hbox_scale.add_child(btn)
_add_section(vbox, "SKIP TIME")
var hbox_time := HBoxContainer.new()
vbox.add_child(hbox_time)
for secs in [30, 60]:
var btn := Button.new()
btn.text = "+%ds" % secs
btn.size_flags_horizontal = Control.SIZE_EXPAND_FILL
btn.pressed.connect(_skip_time.bind(float(secs)))
hbox_time.add_child(btn)
_add_section(vbox, "SPELLS")
for spell_id in SpellLibrary.recipes.keys():
if _spell_dispatch.has(spell_id):
_add_button(vbox, spell_id.capitalize(), _spell_dispatch[spell_id])
_add_section(vbox, "LEVEL")
_add_button(vbox, "Level Up", _force_level_up)
_lvl_disable_btn = Button.new()
_lvl_disable_btn.text = "Disable Level Up: OFF"
_lvl_disable_btn.size_flags_horizontal = Control.SIZE_EXPAND_FILL
_lvl_disable_btn.pressed.connect(_toggle_level_up_disabled)
vbox.add_child(_lvl_disable_btn)
func _add_section(parent: VBoxContainer, title: String) -> void:
var label := Label.new()
label.text = title
label.add_theme_color_override("font_color", Color.YELLOW)
label.add_theme_font_size_override("font_size", 11)
parent.add_child(label)
func _add_button(parent: VBoxContainer, label: String, callback: Callable) -> void:
var btn := Button.new()
btn.text = label
btn.size_flags_horizontal = Control.SIZE_EXPAND_FILL
btn.pressed.connect(callback)
parent.add_child(btn)
func _kill_all_enemies() -> void:
for enemy in get_tree().get_nodes_in_group("enemies"):
if is_instance_valid(enemy):
enemy.die()
func _set_time_scale(scale: float) -> void:
Engine.time_scale = scale
func _skip_time(secs: float) -> void:
_spawn_control.elapsed_time += secs
func _force_level_up() -> void:
_drop_manager.force_level_up()
func _toggle_level_up_disabled() -> void:
_drop_manager.level_up_disabled = not _drop_manager.level_up_disabled
_lvl_disable_btn.text = "Disable Level Up: " + ("ON" if _drop_manager.level_up_disabled else "OFF")

View File

@ -0,0 +1 @@
uid://0r76ifdlnlv

View File

@ -3,9 +3,13 @@ extends Node2D
@onready var player = get_node("/root/Game/Player")
@onready var bar = get_node("/root/Game/CanvasLayer/ProgressBar")
signal leveled_up
@export var fruit_drop_threshold: int = 7
@export var fruit_drop_ceiling: int = 15
var level_up_disabled: bool = false # FOR DEBUG MENU
# Called when the node enters the scene tree for the first time.
func _ready() -> void:
assert(fruit_drop_threshold <= fruit_drop_ceiling)
bar.max_value = player.max_xp
pass # Replace with function body.
@ -19,7 +23,7 @@ func on_enemy_died(enemy):
var enemy_xp = enemy.xp
player.current_xp += enemy.xp
bar.value = player.current_xp
if player.current_xp >= player.max_xp:
if player.current_xp >= player.max_xp and not level_up_disabled:
leveled_up.emit()
player.max_xp = player.max_xp * 1.3
bar.max_value = player.max_xp
@ -32,8 +36,24 @@ func on_enemy_died(enemy):
func drop_item(enemy):
if not is_instance_valid(enemy):
return
var fruit_count = get_children().filter(func(c): return c is DropsBase).size()
for entry in enemy.drop_table:
if randf() < entry.chance:
var effective_chance = entry.chance
if fruit_count >= fruit_drop_ceiling:
continue
elif fruit_count > fruit_drop_threshold:
var chance_scale = 1.0 - float(fruit_count - fruit_drop_threshold) / float(fruit_drop_ceiling - fruit_drop_threshold)
effective_chance *= chance_scale
if randf() < effective_chance:
var drop = entry.drop.instantiate()
drop.global_position = enemy.global_position
add_child(drop)
# FOR DEBUG MENU
func force_level_up() -> void:
leveled_up.emit()
player.max_xp = player.max_xp * 1.3
bar.max_value = player.max_xp
player.current_xp = 0
bar.value = 0
player.level += 1