Fix zoom command for aghost (#15687)
This commit is contained in:
@@ -1,5 +1,9 @@
|
||||
using Content.Client.Movement.Systems;
|
||||
using Content.Shared.Movement.Components;
|
||||
using Content.Shared.Movement.Systems;
|
||||
using JetBrains.Annotations;
|
||||
using Robust.Client.Graphics;
|
||||
using Robust.Client.Player;
|
||||
using Robust.Shared.Console;
|
||||
|
||||
namespace Content.Client.Commands;
|
||||
@@ -7,7 +11,9 @@ namespace Content.Client.Commands;
|
||||
[UsedImplicitly]
|
||||
public sealed class ZoomCommand : IConsoleCommand
|
||||
{
|
||||
[Dependency] private readonly IEntityManager _entManager = default!;
|
||||
[Dependency] private readonly IEyeManager _eyeMan = default!;
|
||||
[Dependency] private readonly IPlayerManager _playerManager = default!;
|
||||
|
||||
public string Command => "zoom";
|
||||
public string Description => Loc.GetString("zoom-command-description");
|
||||
@@ -53,6 +59,14 @@ public sealed class ZoomCommand : IConsoleCommand
|
||||
}
|
||||
}
|
||||
|
||||
var player = _playerManager.LocalPlayer?.ControlledEntity;
|
||||
|
||||
if (_entManager.TryGetComponent<ContentEyeComponent>(player, out var content))
|
||||
{
|
||||
_entManager.System<ContentEyeSystem>().RequestZoom(player.Value, zoom, content);
|
||||
return;
|
||||
}
|
||||
|
||||
_eyeMan.CurrentEye.Zoom = zoom;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -9,6 +9,17 @@ public sealed class ContentEyeSystem : SharedContentEyeSystem
|
||||
{
|
||||
[Dependency] private readonly IPlayerManager _player = default!;
|
||||
|
||||
public void RequestZoom(EntityUid uid, Vector2 zoom, ContentEyeComponent? content = null)
|
||||
{
|
||||
if (!Resolve(uid, ref content, false))
|
||||
return;
|
||||
|
||||
RaisePredictiveEvent(new RequestTargetZoomEvent()
|
||||
{
|
||||
TargetZoom = zoom,
|
||||
});
|
||||
}
|
||||
|
||||
public override void Update(float frameTime)
|
||||
{
|
||||
base.Update(frameTime);
|
||||
|
||||
@@ -9,19 +9,12 @@ public sealed class ContentEyeSystem : SharedContentEyeSystem
|
||||
{
|
||||
base.Update(frameTime);
|
||||
|
||||
var eyeQuery = GetEntityQuery<SharedEyeComponent>();
|
||||
var query = AllEntityQuery<ContentEyeComponent, SharedEyeComponent>();
|
||||
|
||||
foreach (var (_, comp) in EntityQuery<ActiveContentEyeComponent, ContentEyeComponent>(true))
|
||||
while (query.MoveNext(out var uid, out var comp, out var eyeComp))
|
||||
{
|
||||
var uid = comp.Owner;
|
||||
|
||||
// Use a separate query jjuussstt in case any actives mistakenly hang around.
|
||||
if (!eyeQuery.TryGetComponent(comp.Owner, out var eyeComp) ||
|
||||
eyeComp.Zoom.Equals(comp.TargetZoom))
|
||||
{
|
||||
RemComp<ActiveContentEyeComponent>(comp.Owner);
|
||||
if (eyeComp.Zoom.Equals(comp.TargetZoom))
|
||||
continue;
|
||||
}
|
||||
|
||||
UpdateEye(uid, comp, eyeComp, frameTime);
|
||||
}
|
||||
|
||||
@@ -1,7 +0,0 @@
|
||||
namespace Content.Shared.Movement.Components;
|
||||
|
||||
[RegisterComponent]
|
||||
public sealed class ActiveContentEyeComponent : Component
|
||||
{
|
||||
|
||||
}
|
||||
@@ -1,3 +1,4 @@
|
||||
using Content.Shared.Movement.Systems;
|
||||
using Robust.Shared.GameStates;
|
||||
|
||||
namespace Content.Shared.Movement.Components;
|
||||
@@ -5,18 +6,18 @@ namespace Content.Shared.Movement.Components;
|
||||
/// <summary>
|
||||
/// Holds SS14 eye data not relevant for engine, e.g. lerp targets.
|
||||
/// </summary>
|
||||
[RegisterComponent, NetworkedComponent]
|
||||
public sealed class ContentEyeComponent : Component
|
||||
[RegisterComponent, NetworkedComponent, AutoGenerateComponentState, Access(typeof(SharedContentEyeSystem))]
|
||||
public sealed partial class ContentEyeComponent : Component
|
||||
{
|
||||
/// <summary>
|
||||
/// Zoom we're lerping to.
|
||||
/// </summary>
|
||||
[DataField("targetZoom")]
|
||||
[DataField("targetZoom"), AutoNetworkedField]
|
||||
public Vector2 TargetZoom = Vector2.One;
|
||||
|
||||
/// <summary>
|
||||
/// How far we're allowed to zoom out.
|
||||
/// </summary>
|
||||
[ViewVariables(VVAccess.ReadWrite), DataField("maxZoom")]
|
||||
[ViewVariables(VVAccess.ReadWrite), DataField("maxZoom"), AutoNetworkedField]
|
||||
public Vector2 MaxZoom = Vector2.One;
|
||||
}
|
||||
|
||||
@@ -1,11 +1,9 @@
|
||||
using Content.Shared.Input;
|
||||
using Content.Shared.Movement.Components;
|
||||
using Robust.Shared.GameStates;
|
||||
using Robust.Shared.Input;
|
||||
using Robust.Shared.Input.Binding;
|
||||
using Robust.Shared.Players;
|
||||
using Robust.Shared.Serialization;
|
||||
using Robust.Shared.Timing;
|
||||
|
||||
namespace Content.Shared.Movement.Systems;
|
||||
|
||||
@@ -24,9 +22,8 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
public override void Initialize()
|
||||
{
|
||||
base.Initialize();
|
||||
SubscribeLocalEvent<ContentEyeComponent, ComponentGetState>(OnGetState);
|
||||
SubscribeLocalEvent<ContentEyeComponent, ComponentHandleState>(OnHandleState);
|
||||
SubscribeLocalEvent<ContentEyeComponent, ComponentStartup>(OnContentEyeStartup);
|
||||
SubscribeAllEvent<RequestTargetZoomEvent>(OnContentZoomRequest);
|
||||
|
||||
CommandBinds.Builder
|
||||
.Bind(ContentKeyFunctions.ZoomIn, new ScrollInputCmdHandler(true, this))
|
||||
@@ -37,6 +34,15 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
Sawmill.Level = LogLevel.Info;
|
||||
}
|
||||
|
||||
private void OnContentZoomRequest(RequestTargetZoomEvent msg, EntitySessionEventArgs args)
|
||||
{
|
||||
if (!TryComp<ContentEyeComponent>(args.SenderSession.AttachedEntity, out var content))
|
||||
return;
|
||||
|
||||
content.TargetZoom = msg.TargetZoom;
|
||||
Dirty(content);
|
||||
}
|
||||
|
||||
public override void Shutdown()
|
||||
{
|
||||
base.Shutdown();
|
||||
@@ -52,24 +58,6 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
Dirty(component);
|
||||
}
|
||||
|
||||
private void OnGetState(EntityUid uid, ContentEyeComponent component, ref ComponentGetState args)
|
||||
{
|
||||
args.State = new ContentEyeComponentState()
|
||||
{
|
||||
TargetZoom = component.TargetZoom,
|
||||
MaxZoom = component.MaxZoom,
|
||||
};
|
||||
}
|
||||
|
||||
private void OnHandleState(EntityUid uid, ContentEyeComponent component, ref ComponentHandleState args)
|
||||
{
|
||||
if (args.Current is not ContentEyeComponentState state)
|
||||
return;
|
||||
|
||||
component.TargetZoom = state.TargetZoom;
|
||||
component.MaxZoom = state.MaxZoom;
|
||||
}
|
||||
|
||||
protected void UpdateEye(EntityUid uid, ContentEyeComponent content, SharedEyeComponent eye, float frameTime)
|
||||
{
|
||||
var diff = content.TargetZoom - eye.Zoom;
|
||||
@@ -78,7 +66,6 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
{
|
||||
eye.Zoom = content.TargetZoom;
|
||||
Dirty(eye);
|
||||
RemComp<ActiveContentEyeComponent>(uid);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -102,7 +89,6 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
return;
|
||||
|
||||
component.TargetZoom = Vector2.One;
|
||||
EnsureComp<ActiveContentEyeComponent>(uid);
|
||||
Dirty(component);
|
||||
}
|
||||
|
||||
@@ -129,18 +115,10 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
return;
|
||||
|
||||
component.TargetZoom = actual;
|
||||
EnsureComp<ActiveContentEyeComponent>(uid);
|
||||
Dirty(component);
|
||||
Sawmill.Debug($"Set target zoom to {actual}");
|
||||
}
|
||||
|
||||
[Serializable, NetSerializable]
|
||||
private sealed class ContentEyeComponentState : ComponentState
|
||||
{
|
||||
public Vector2 TargetZoom;
|
||||
public Vector2 MaxZoom;
|
||||
}
|
||||
|
||||
private sealed class ResetZoomInputCmdHandler : InputCmdHandler
|
||||
{
|
||||
private readonly SharedContentEyeSystem _system;
|
||||
@@ -192,4 +170,13 @@ public abstract class SharedContentEyeSystem : EntitySystem
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Sendable from client to server to request a target zoom.
|
||||
/// </summary>
|
||||
[Serializable, NetSerializable]
|
||||
public sealed class RequestTargetZoomEvent : EntityEventArgs
|
||||
{
|
||||
public Vector2 TargetZoom;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user