From bdf05d5479e2e3cb4855885a981337bed11487af Mon Sep 17 00:00:00 2001 From: teatov Date: Sun, 13 Oct 2024 21:27:53 +1000 Subject: [PATCH] refactor `Interactable` and `Unit` --- scripts/interactable.gd | 12 +++++---- scripts/ui/unit_info.gd | 33 +++++++++++-------------- scripts/units/abstract/unit.gd | 45 +++++++++++++++++----------------- 3 files changed, 44 insertions(+), 46 deletions(-) diff --git a/scripts/interactable.gd b/scripts/interactable.gd index 04d9a46..0f0751c 100644 --- a/scripts/interactable.gd +++ b/scripts/interactable.gd @@ -1,8 +1,10 @@ extends CharacterBody3D class_name Interactable -## A base interactable object that can be hovered over and clicked on +## A base interactable object that can be hovered over and clicked on. -const MIN_DRAG_DISTANCE: float = 15 +## When releasing the mouse button, how many pixels away from the click. +## position the cursor has to be for it to be considered a click and not drag. +const MAX_CLICK_RELEASE_DISTANCE: float = 15 var _hovered: bool = false var _mouse_over: bool = false @@ -19,10 +21,10 @@ func _ready() -> void: func _process(_delta: float) -> void: - _hovered = HoveringManager.hovered_node == self and _mouse_over if not _can_interact: _hovered = false return + _hovered = HoveringManager.hovered_node == self and _mouse_over hover_indicator.visible = _hovered @@ -39,7 +41,7 @@ func _input(event: InputEvent) -> void: else: if ( (button_event.position - _click_start_position).length() - < MIN_DRAG_DISTANCE + < MAX_CLICK_RELEASE_DISTANCE ): _click() @@ -53,4 +55,4 @@ func _on_mouse_entered() -> void: func _on_mouse_exited() -> void: - _mouse_over = false \ No newline at end of file + _mouse_over = false diff --git a/scripts/ui/unit_info.gd b/scripts/ui/unit_info.gd index 8680653..f5d4711 100644 --- a/scripts/ui/unit_info.gd +++ b/scripts/ui/unit_info.gd @@ -15,7 +15,8 @@ enum State { const ANIMATION_SPEED: float = 0.25 -var _unit: Unit +var unit: Unit + var _state: State = State.NONE var _anim_time: float = 0 @@ -30,7 +31,7 @@ func _ready() -> void: func _process(delta: float) -> void: super._process(delta) - if _unit == null or not visible: + if unit == null or not visible: return _anim_time += delta @@ -40,16 +41,9 @@ func _process(delta: float) -> void: func open(who: Unit) -> void: - if _unit != null: - close() visible = true - _unit = who - set_target(_unit.ui_origin) - - -func close() -> void: - _unit.toggle_info(false) - super.close() + unit = who + set_target(unit.ui_origin) func _handle_pictogram() -> void: @@ -59,29 +53,30 @@ func _handle_pictogram() -> void: wrapf(_anim_time / ANIMATION_SPEED, 0, 4) ) * atlas.region.size.x + func _get_state() -> void: - if _unit is Aphid: - match (_unit as Aphid).state: + if unit is Aphid: + match (unit as Aphid).state: Aphid.State.WANDERING: _state = State.APHID_IDLE - if _unit is AntNitwit: - match (_unit as AntNitwit).state: + if unit is AntNitwit: + match (unit as AntNitwit).state: AntNitwit.State.WANDERING: _state = State.ANT_IDLE AntNitwit.State.MOVING: _state = State.ANT_MOVING AntNitwit.State.GATHERING: - _get_gathering_state((_unit as AntNitwit).gathering.state) + _get_gathering_state((unit as AntNitwit).gathering.state) - if _unit is AntGatherer: - match (_unit as AntGatherer).state: + if unit is AntGatherer: + match (unit as AntGatherer).state: AntGatherer.State.WANDERING: _state = State.ANT_IDLE AntGatherer.State.MOVING: _state = State.ANT_MOVING AntGatherer.State.GATHERING: - _get_gathering_state((_unit as AntGatherer).gathering.state) + _get_gathering_state((unit as AntGatherer).gathering.state) func _get_gathering_state(gather_state: Gathering.State) -> void: diff --git a/scripts/units/abstract/unit.gd b/scripts/units/abstract/unit.gd index fcec43e..26de005 100644 --- a/scripts/units/abstract/unit.gd +++ b/scripts/units/abstract/unit.gd @@ -1,22 +1,25 @@ extends Interactable class_name Unit -const MOVE_SPEED: float = 3 const TURN_SPEED: float = 10 +const LOCOMOTION_CHANGE_SPEED: float = 8 + +var _move_speed: float = 3 var _max_wander_distance: float = 5 var _min_wander_interval: float = 0.25 var _max_wander_interval: float = 5 -var _is_on_screen: bool = false -var _wandering_timer: float = 0 var _wandering_center: Vector3 = Vector3.ZERO +var _wandering_timer: float = 0 + var _spawn_pos: Vector3 var _locomotion_value: float = 0 -var _showing_info: bool = false var _advance_anim_delta_accum: float = 0 +var _showing_info: bool = false + @onready var nav_agent: NavigationAgent3D = $NavigationAgent3D @onready var ui_origin: Node3D = $UiOrigin @onready var animation_tree: AnimationTree = $AnimationTree @@ -41,11 +44,13 @@ func _ready() -> void: anim_advance_indicator.visible = false if _spawn_pos != null and _spawn_pos != Vector3.ZERO: global_position = _spawn_pos - _wandering_center = global_position - nav_agent.max_speed = MOVE_SPEED + + nav_agent.max_speed = _move_speed nav_agent.velocity_computed.connect(_on_nav_agent_velocity_computed) + set_max_slides(2) + visibility_notifier.screen_entered.connect( _on_visibility_notifier_screen_entered, ) @@ -56,23 +61,19 @@ func _ready() -> void: func _process(delta: float) -> void: super._process(delta) - _animate(delta) + _handle_animation(delta) + _showing_info = UiManager.unit_info.unit == self func _physics_process(_delta: float) -> void: - _navigate() - - -func toggle_info(on: bool) -> void: - _showing_info = on + _handle_navigation() func _click() -> void: UiManager.unit_info.open(self) - toggle_info(true) -func _navigate() -> void: +func _handle_navigation() -> void: if nav_agent.is_navigation_finished(): velocity = Vector3.ZERO return @@ -80,12 +81,12 @@ func _navigate() -> void: var next_pos := nav_agent.get_next_path_position() var direction := global_position.direction_to(next_pos) - var new_velocity := direction * MOVE_SPEED + var new_velocity := direction * _move_speed nav_agent.set_velocity(new_velocity) -func _animate(delta: float) -> void: - if not _is_on_screen: +func _handle_animation(delta: float) -> void: + if not visibility_notifier.is_on_screen(): return if velocity.length() > 0.01: @@ -100,8 +101,8 @@ func _animate(delta: float) -> void: _locomotion_value = move_toward( _locomotion_value, - velocity.length() / MOVE_SPEED, - delta * 8 + velocity.length() / _move_speed, + delta * LOCOMOTION_CHANGE_SPEED ) animation_tree.set("parameters/locomotion/blend_position", _locomotion_value) @@ -113,10 +114,12 @@ func _animate(delta: float) -> void: ) var frame := Engine.get_frames_drawn() var advance := (frame + get_instance_id()) % advance_anim_step == 0 - anim_advance_indicator.visible = advance and DebugManager.enabled + if advance: animation_tree.advance(_advance_anim_delta_accum) _advance_anim_delta_accum = 0 + + anim_advance_indicator.visible = advance and DebugManager.enabled func _wander(delta: float) -> void: @@ -138,10 +141,8 @@ func _on_nav_agent_velocity_computed(safe_velocity: Vector3) -> void: func _on_visibility_notifier_screen_entered() -> void: - _is_on_screen = true SelectionManager.add_unit_to_visible(self) func _on_visibility_notifier_screen_exited() -> void: - _is_on_screen = false SelectionManager.remove_unit_from_visible(self)