瀏覽代碼

:wrench: The chocolate goes to the walker pocket

DricomDragon 2 月之前
父節點
當前提交
333a3873b6

+ 8 - 1
godot/component/entity/collectibles/chocolate/chocolate.gd

@@ -3,6 +3,7 @@ extends Node3D
 
 
 const COLLECT_ANIM := "collection"
+const COLLECT_DURATION := 2.0
 
 @onready var chocolateAnimation: AnimationPlayer = $ChocolateAnimation
 @onready var pickupSound: AudioStreamPlayer3D = $ChocolatePickupSound
@@ -21,12 +22,18 @@ func _on_chocolate_tablet_body_entered(body: Node3D) -> void:
 
 func _give_chocolate_to(walker: Walker) -> void:
 	walker.give_chocolate()
-	reparent.call_deferred(walker)
+	_go_to.call_deferred(walker)
 	chocolateAnimation.play(COLLECT_ANIM)
 	chocolateAnimation.animation_finished.connect(_finish)
 	pickupSound.play()
 
 
+func _go_to(walker: Walker) -> void:
+	reparent(walker)
+	var center_tween = create_tween()
+	center_tween.tween_property(self, "position", walker.get_pocket_position(), COLLECT_DURATION)
+
+
 func _finish(animation_name: String) -> void:
 	if COLLECT_ANIM == animation_name:
 		# Collection is finished

+ 5 - 0
godot/component/entity/walker/walker.gd

@@ -60,6 +60,11 @@ func give_chocolate():
 	chocolate_collected.emit()
 
 
+## Return local pocket position where the chocolate is collected
+func get_pocket_position() -> Vector3:
+	return $ChocolatePocket.get_position()
+
+
 func _physics_process(delta: float) -> void:
 	if is_onboard():
 		_get_on_driver_seat()

+ 3 - 0
godot/component/entity/walker/walker.tscn

@@ -23,3 +23,6 @@ enabled = false
 target_position = Vector3(0, 1.5, -1.5)
 collision_mask = 8
 hit_from_inside = true
+
+[node name="ChocolatePocket" type="Marker3D" parent="."]
+transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0.419289, -0.108942)