From 8ef55030720e420c65ba8b432fb99f57f023b0ac Mon Sep 17 00:00:00 2001 From: akorzunin Date: Fri, 13 Sep 2024 15:41:59 +0300 Subject: [PATCH] feat: added GAME_SPEED setting w/ reload config --- project.godot | 5 ++ src/components/controls/CommonControls.gd | 11 +++++ src/components/settings/Config.gd | 5 ++ src/components/settings/DefaultConfig.gd | 3 +- src/components/timers/LoopTimer.gd | 12 +++-- src/components/timers/ScaleTimer.gd | 6 ++- src/globals.gd | 3 ++ .../icosahedron/components/Icosahedron.gd | 3 +- .../icosahedron/test/game_speed_test.gd | 48 +++++++++++++++++++ 9 files changed, 87 insertions(+), 9 deletions(-) create mode 100755 src/models/icosahedron/test/game_speed_test.gd diff --git a/project.godot b/project.godot index dbcccdb..b3f7293 100644 --- a/project.godot +++ b/project.godot @@ -96,6 +96,11 @@ ui_pause={ , Object(InputEventJoypadButton,"resource_local_to_scene":false,"resource_name":"","device":-1,"button_index":6,"pressure":0.0,"pressed":true,"script":null) ] } +ui_reload={ +"deadzone": 0.5, +"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":82,"key_label":0,"unicode":82,"location":0,"echo":false,"script":null) +] +} [input_devices] diff --git a/src/components/controls/CommonControls.gd b/src/components/controls/CommonControls.gd index 654b1aa..c5e9b97 100644 --- a/src/components/controls/CommonControls.gd +++ b/src/components/controls/CommonControls.gd @@ -19,3 +19,14 @@ func _unhandled_input(event: InputEvent) -> void: toggle_debug_stats.emit(state) config._on_debug_stats_state(state) get_viewport().set_input_as_handled() + if event.is_action_pressed('ui_reload'): + G.reload_settings.emit() + +func _notification(what: int): + if what == NOTIFICATION_WM_GO_BACK_REQUEST: + var p := Utils.get_platform() + if p == Utils.Platform.MOBILE: + # Back button on android + InputEmit.new().emit({ + action = 'ui_cancel' + }) diff --git a/src/components/settings/Config.gd b/src/components/settings/Config.gd index 2b79f14..e88c0f2 100644 --- a/src/components/settings/Config.gd +++ b/src/components/settings/Config.gd @@ -28,6 +28,11 @@ func _init() -> void: func _ready() -> void: set_fps_counter_state.connect(_on_fps_counter_state) set_debug_stats_state.connect(_on_debug_stats_state) + G.reload_settings.connect(_on_reload_settings) + +func _on_reload_settings(): + var gs = SettingsConfig.load_gs(config) + G.settings = gs func _on_fps_counter_state(state: bool): G.settings.FPS_COUNTER_ENABLED = state diff --git a/src/components/settings/DefaultConfig.gd b/src/components/settings/DefaultConfig.gd index f773b43..abc4480 100644 --- a/src/components/settings/DefaultConfig.gd +++ b/src/components/settings/DefaultConfig.gd @@ -6,6 +6,8 @@ const settings = { SPAWN_MODE=2, DESPAWNER_MODE=16633, SCALE_FACTOR=10, + SPAWN_SPEED=10, + GAME_SPEED=10, ROTATION_SPEED=12, MAX_LEVEL=0, }, @@ -18,6 +20,5 @@ const settings = { VSYNC_ENABLED=true, CONTROL_TYPE="FREE_SPIN", IS_CONTROL_INVERTED=false, - DEFAULT_LEVEL=0, } } diff --git a/src/components/timers/LoopTimer.gd b/src/components/timers/LoopTimer.gd index f3bc47a..0e948f5 100644 --- a/src/components/timers/LoopTimer.gd +++ b/src/components/timers/LoopTimer.gd @@ -6,15 +6,17 @@ var time_start: int # Called when the node enters the scene tree for the first time. func _ready() -> void: game_state_manager.game_state_changed.connect(_on_game_state_changed) + G.reload_settings.connect(_on_reload_settings) -# Called every frame. 'delta' is the elapsed time since the previous frame. -func _process(delta: float) -> void: - pass +func _on_reload_settings(): + await timeout + stop() + start(100. / (G.settings.SPAWN_SPEED * G.settings.GAME_SPEED)) func _on_game_state_changed(old_state: GameStateManager.GameState, new_state: GameStateManager.GameState) -> void: var gs = GameStateManager.GameState if new_state == gs.GAME_ACTIVE: - start(10. / G.settings.get("SPAWN_SPEED", 10)) + start(100. / (G.settings.SPAWN_SPEED * G.settings.GAME_SPEED)) time_start = Time.get_ticks_msec() if new_state in [gs.GAME_END, gs.GAME_MENU]: stop() @@ -35,7 +37,7 @@ func get_elapsed_time() -> String: return "000:000" return format_time(raw_time) -func format_time(time: int) -> String: +static func format_time(time: int) -> String: var ms := time % 1000 var sec := float(time) / 1000 return "%d:%03d" % [sec, ms] diff --git a/src/components/timers/ScaleTimer.gd b/src/components/timers/ScaleTimer.gd index 2a9edbb..80c7eae 100644 --- a/src/components/timers/ScaleTimer.gd +++ b/src/components/timers/ScaleTimer.gd @@ -3,12 +3,14 @@ class_name ScaleTimer @onready var game_state_manager: GameStateManager = %GameStateManager +# 10 ms +const tick_dur := int(10. / 1000. ) + # Called when the node enters the scene tree for the first time. func _ready() -> void: game_state_manager.game_state_changed.connect(_on_game_state) autostart = true - # 10 ms - wait_time = 10. / 1000. + wait_time = tick_dur func _on_game_state(old_state: GameStateManager.GameState, new_state: GameStateManager.GameState): var gs = GameStateManager.GameState diff --git a/src/globals.gd b/src/globals.gd index 6026abf..7d85aeb 100644 --- a/src/globals.gd +++ b/src/globals.gd @@ -18,3 +18,6 @@ signal font_changed(new_font: FontType) @warning_ignore("unused_signal") signal level_changed(new_level: int) + +@warning_ignore("unused_signal") +signal reload_settings() diff --git a/src/models/icosahedron/components/Icosahedron.gd b/src/models/icosahedron/components/Icosahedron.gd index 3c46f2a..d280aac 100644 --- a/src/models/icosahedron/components/Icosahedron.gd +++ b/src/models/icosahedron/components/Icosahedron.gd @@ -34,7 +34,8 @@ func _ready() -> void: func _on_scale_tick() -> void: if scaling_enabled: - var sf: float = (G.settings.SCALE_FACTOR + 1000.) / 1000. + var sf: float = 1. + (G.settings.SCALE_FACTOR / 1000. ) \ + * (0.5 + (G.settings.GAME_SPEED / (10. + G.settings.GAME_SPEED))) scale_object_local(Vector3(sf, sf, sf)) func despawn(): diff --git a/src/models/icosahedron/test/game_speed_test.gd b/src/models/icosahedron/test/game_speed_test.gd new file mode 100755 index 0000000..f887acc --- /dev/null +++ b/src/models/icosahedron/test/game_speed_test.gd @@ -0,0 +1,48 @@ +#!/usr/bin/env -S godot --headless -s --quit +extends SceneTree + +var G ={ + settings ={ + SPAWN_MODE=2, + DESPAWNER_MODE=16633, + ROTATION_SPEED=12, + MAX_LEVEL=0, + + SPAWN_SPEED=10, + SCALE_FACTOR=10, + GAME_SPEED=10, + } +} + +func gs_calc(x: int): + return 0.5 + (x / (10. + x)) + +func get_loop(): + return 100. / (G.settings.SPAWN_SPEED * G.settings.GAME_SPEED) + +func get_scale(): + # return 1. + ((G.settings.SCALE_FACTOR / 10.) * gs_calc(G.settings.GAME_SPEED)) / 100. + # return 1. + ( + # (G.settings.SCALE_FACTOR / 10.) + # * (0.5 + (G.settings.GAME_SPEED / (10. + G.settings.GAME_SPEED))) + # ) / 100. + return 1. + (G.settings.SCALE_FACTOR / 1000. ) * (0.5 + (G.settings.GAME_SPEED / (10. + G.settings.GAME_SPEED))) + +func main(): + print_debug(gs_calc(20)) + + print_debug("base loop: ", 1, " > ", get_loop()) + print_debug("base scale: ", 1.01, " > ", get_scale()) + G.settings.GAME_SPEED = 5 + print_debug("\nL2: gs=", G.settings.GAME_SPEED) + print_debug("loop: ", get_loop()) + print_debug("scale: ", get_scale()) + G.settings.GAME_SPEED = 20 + print_debug("\nL3: gs=", G.settings.GAME_SPEED) + print_debug("loop: ", get_loop()) + print_debug("scale: ", get_scale()) + pass + +func _init(): + main() + quit()