gd: weapon throws orients and throws itself correctly
This commit is contained in:
@ -75,7 +75,9 @@ public partial class DashSystem: Node3D
|
||||
shouldMantle = mantleResult.IsSome(out mantleLocation);
|
||||
}
|
||||
|
||||
var targetColor = shouldMantle ? new Color(0.2f, 0.2f, 1f) : new Color(1f, 1f, 1f);
|
||||
var targetColor = hasHit ? new Color(1f, 0.2f, 0.2f) : new Color(1f, 1f, 1f);
|
||||
targetColor = shouldMantle ? new Color(0.2f, 0.2f, 1f) : targetColor;
|
||||
|
||||
var targetMaterial = (StandardMaterial3D) _dashTarget.GetSurfaceOverrideMaterial(0);
|
||||
targetMaterial.SetAlbedo(targetColor);
|
||||
_dashTarget.SetVisible(true);
|
||||
@ -106,4 +108,14 @@ public partial class DashSystem: Node3D
|
||||
_tweenQueueSystem.QueueTween(DashResolve.MantleLocation, 0.2f);
|
||||
}
|
||||
}
|
||||
|
||||
public void DashToThrownWeapon()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
public void DashToPlantedWeapon()
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,7 @@
|
||||
[ext_resource type="PackedScene" uid="uid://wq1okogkhc5l" path="res://systems/mantle/mantle_system.tscn" id="2_pff7b"]
|
||||
|
||||
[sub_resource type="SphereShape3D" id="SphereShape3D_qu4wy"]
|
||||
radius = 0.1
|
||||
|
||||
[sub_resource type="SphereMesh" id="SphereMesh_qu4wy"]
|
||||
|
||||
@ -15,7 +16,7 @@ script = ExtResource("1_hwig2")
|
||||
[node name="DashCast3D" type="ShapeCast3D" parent="."]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1.68, 0)
|
||||
shape = SubResource("SphereShape3D_qu4wy")
|
||||
target_position = Vector3(0, 0, -20)
|
||||
target_position = Vector3(0, 0, -12)
|
||||
max_results = 1
|
||||
collision_mask = 2
|
||||
debug_shape_custom_color = Color(0.911631, 0.11884, 0.656218, 1)
|
||||
|
@ -22,7 +22,7 @@ debug_shape_custom_color = Color(1, 0, 0, 1)
|
||||
[node name="WallInFrontCast3D" type="ShapeCast3D" parent="."]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0)
|
||||
shape = SubResource("CapsuleShape3D_qu4wy")
|
||||
target_position = Vector3(0, 0, -2)
|
||||
target_position = Vector3(0, 0, -1.5)
|
||||
max_results = 1
|
||||
collision_mask = 2
|
||||
debug_shape_custom_color = Color(0.911631, 0.11884, 0.656218, 1)
|
||||
|
@ -4,6 +4,11 @@ namespace Movementtests.systems;
|
||||
|
||||
public partial class WeaponSystem : RigidBody3D
|
||||
{
|
||||
[Export(PropertyHint.Range, "0,100,1,or_greater")]
|
||||
public float ThrowForce { get; set; } = 1f;
|
||||
[Export(PropertyHint.Range, "0,0.2,0.01,or_greater")]
|
||||
public float StraightThrowDuration { get; set; } = 0.1f;
|
||||
|
||||
private Node3D _head;
|
||||
private ShapeCast3D _dashCast3D;
|
||||
private Camera3D _camera;
|
||||
@ -27,15 +32,14 @@ public partial class WeaponSystem : RigidBody3D
|
||||
Freeze = true;
|
||||
}
|
||||
|
||||
public void ThrowWeapon(Vector3 start, Vector3 end, bool hasHit, Vector3 collisionLocation, Vector3 collisionNormal)
|
||||
public void ThrowWeapon(Vector3 end, bool hasHit, Vector3 collisionLocation, Vector3 collisionNormal)
|
||||
{
|
||||
_throwDirection = (end - start).Normalized();
|
||||
_throwDirection = (end - GlobalPosition).Normalized();
|
||||
_plantLocation = collisionLocation;
|
||||
_plantNormal = collisionNormal;
|
||||
LookAt(GlobalTransform.Origin + _throwDirection);
|
||||
RotateX(-Mathf.Pi / 2);
|
||||
LookAt(end);
|
||||
|
||||
var tween = _tweenQueueSystem.TweenToLocation(new TweenQueueSystem.TweenInputs(end, 1f));
|
||||
var tween = _tweenQueueSystem.TweenToLocation(new TweenQueueSystem.TweenInputs(end, StraightThrowDuration));
|
||||
if (hasHit)
|
||||
tween.Finished += PlantWeaponInWall;
|
||||
else
|
||||
@ -45,12 +49,13 @@ public partial class WeaponSystem : RigidBody3D
|
||||
public void ThrowWeaponOnCurve()
|
||||
{
|
||||
Freeze = false;
|
||||
ApplyImpulse(_throwDirection * ThrowForce);
|
||||
}
|
||||
|
||||
public void PlantWeaponInWall()
|
||||
{
|
||||
Position = _plantLocation;
|
||||
LookAt(_plantLocation + _plantNormal, Vector3.Up);
|
||||
GlobalPosition = _plantLocation;
|
||||
LookAt(GlobalTransform.Origin + _plantNormal, Vector3.Up, true);
|
||||
}
|
||||
|
||||
public void ResetWeapon()
|
||||
|
@ -13,14 +13,14 @@ bottom_radius = 0.05
|
||||
height = 1.0
|
||||
|
||||
[node name="Weapon" type="RigidBody3D"]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0)
|
||||
script = ExtResource("1_csqwk")
|
||||
|
||||
[node name="TweenQueueSystem" parent="." instance=ExtResource("2_x1nha")]
|
||||
|
||||
[node name="CollisionShape3D" type="CollisionShape3D" parent="."]
|
||||
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0)
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, 1, 0, -1, -4.37114e-08, 0, 0, 0)
|
||||
shape = SubResource("CylinderShape3D_avini")
|
||||
|
||||
[node name="MeshInstance3D" type="MeshInstance3D" parent="."]
|
||||
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, 1, 0, -1, -4.37114e-08, 0, 0, 0)
|
||||
mesh = SubResource("CylinderMesh_x1nha")
|
||||
|
Reference in New Issue
Block a user