фикс системы таскания
This commit is contained in:
@@ -1,10 +0,0 @@
|
||||
using Robust.Shared.Serialization;
|
||||
using Content.Shared.DoAfter;
|
||||
|
||||
namespace Content.Shared.Carrying
|
||||
{
|
||||
[Serializable, NetSerializable]
|
||||
public sealed partial class CarryDoAfterEvent : SimpleDoAfterEvent
|
||||
{
|
||||
}
|
||||
}
|
||||
@@ -1,28 +1,13 @@
|
||||
using Robust.Shared.GameStates;
|
||||
using Robust.Shared.Serialization;
|
||||
|
||||
namespace Content.Shared.Carrying
|
||||
namespace Content.Shared._White.Carrying;
|
||||
|
||||
[RegisterComponent, NetworkedComponent, Access(typeof(CarryingSlowdownSystem)), AutoGenerateComponentState]
|
||||
public sealed partial class CarryingSlowdownComponent : Component
|
||||
{
|
||||
[RegisterComponent, NetworkedComponent, Access(typeof(CarryingSlowdownSystem))]
|
||||
[DataField, ViewVariables(VVAccess.ReadWrite), AutoNetworkedField]
|
||||
public float WalkModifier = 0.7f;
|
||||
|
||||
public sealed partial class CarryingSlowdownComponent : Component
|
||||
{
|
||||
[DataField("walkModifier", required: true)] [ViewVariables(VVAccess.ReadWrite)]
|
||||
public float WalkModifier = 1.0f;
|
||||
|
||||
[DataField("sprintModifier", required: true)] [ViewVariables(VVAccess.ReadWrite)]
|
||||
public float SprintModifier = 1.0f;
|
||||
}
|
||||
|
||||
[Serializable, NetSerializable]
|
||||
public sealed class CarryingSlowdownComponentState : ComponentState
|
||||
{
|
||||
public float WalkModifier;
|
||||
public float SprintModifier;
|
||||
public CarryingSlowdownComponentState(float walkModifier, float sprintModifier)
|
||||
{
|
||||
WalkModifier = walkModifier;
|
||||
SprintModifier = sprintModifier;
|
||||
}
|
||||
}
|
||||
}
|
||||
[DataField, ViewVariables(VVAccess.ReadWrite), AutoNetworkedField]
|
||||
public float SprintModifier = 0.7f;
|
||||
}
|
||||
@@ -1,47 +1,35 @@
|
||||
using Content.Shared.DoAfter;
|
||||
using Content.Shared.Movement.Systems;
|
||||
using Robust.Shared.GameStates;
|
||||
using Robust.Shared.Serialization;
|
||||
|
||||
namespace Content.Shared.Carrying
|
||||
namespace Content.Shared._White.Carrying;
|
||||
|
||||
public sealed class CarryingSlowdownSystem : EntitySystem
|
||||
{
|
||||
public sealed class CarryingSlowdownSystem : EntitySystem
|
||||
[Dependency] private readonly MovementSpeedModifierSystem _movementSpeed = default!;
|
||||
|
||||
public override void Initialize()
|
||||
{
|
||||
[Dependency] private readonly MovementSpeedModifierSystem _movementSpeed = default!;
|
||||
base.Initialize();
|
||||
SubscribeLocalEvent<CarryingSlowdownComponent, RefreshMovementSpeedModifiersEvent>(OnRefreshMoveSpeed);
|
||||
}
|
||||
|
||||
public override void Initialize()
|
||||
{
|
||||
base.Initialize();
|
||||
SubscribeLocalEvent<CarryingSlowdownComponent, ComponentGetState>(OnGetState);
|
||||
SubscribeLocalEvent<CarryingSlowdownComponent, ComponentHandleState>(OnHandleState);
|
||||
SubscribeLocalEvent<CarryingSlowdownComponent, RefreshMovementSpeedModifiersEvent>(OnRefreshMoveSpeed);
|
||||
}
|
||||
public void SetModifier(EntityUid uid, CarryingSlowdownComponent? component = null)
|
||||
{
|
||||
if (!Resolve(uid, ref component))
|
||||
return;
|
||||
|
||||
public void SetModifier(EntityUid uid, float walkSpeedModifier, float sprintSpeedModifier, CarryingSlowdownComponent? component = null)
|
||||
{
|
||||
if (!Resolve(uid, ref component))
|
||||
return;
|
||||
_movementSpeed.RefreshMovementSpeedModifiers(uid);
|
||||
}
|
||||
|
||||
component.WalkModifier = walkSpeedModifier;
|
||||
component.SprintModifier = sprintSpeedModifier;
|
||||
_movementSpeed.RefreshMovementSpeedModifiers(uid);
|
||||
}
|
||||
private void OnGetState(EntityUid uid, CarryingSlowdownComponent component, ref ComponentGetState args)
|
||||
{
|
||||
args.State = new CarryingSlowdownComponentState(component.WalkModifier, component.SprintModifier);
|
||||
}
|
||||
|
||||
private void OnHandleState(EntityUid uid, CarryingSlowdownComponent component, ref ComponentHandleState args)
|
||||
{
|
||||
if (args.Current is CarryingSlowdownComponentState state)
|
||||
{
|
||||
component.WalkModifier = state.WalkModifier;
|
||||
component.SprintModifier = state.SprintModifier;
|
||||
|
||||
_movementSpeed.RefreshMovementSpeedModifiers(uid);
|
||||
}
|
||||
}
|
||||
private void OnRefreshMoveSpeed(EntityUid uid, CarryingSlowdownComponent component, RefreshMovementSpeedModifiersEvent args)
|
||||
{
|
||||
args.ModifySpeed(component.WalkModifier, component.SprintModifier);
|
||||
}
|
||||
private void OnRefreshMoveSpeed(
|
||||
EntityUid uid,
|
||||
CarryingSlowdownComponent component,
|
||||
RefreshMovementSpeedModifiersEvent args)
|
||||
{
|
||||
args.ModifySpeed(component.WalkModifier, component.SprintModifier);
|
||||
}
|
||||
}
|
||||
|
||||
[Serializable, NetSerializable]
|
||||
public sealed partial class CarryDoAfterEvent : SimpleDoAfterEvent;
|
||||
Reference in New Issue
Block a user