Change from using obsolete method in ExplosionOverlay (#30550)
* Change from obsolete method in ExplosionOverlay * Send AppearanceSystem through constructor
This commit is contained in:
@@ -16,15 +16,17 @@ public sealed class ExplosionOverlay : Overlay
|
|||||||
[Dependency] private readonly IRobustRandom _robustRandom = default!;
|
[Dependency] private readonly IRobustRandom _robustRandom = default!;
|
||||||
[Dependency] private readonly IEntityManager _entMan = default!;
|
[Dependency] private readonly IEntityManager _entMan = default!;
|
||||||
[Dependency] private readonly IPrototypeManager _proto = default!;
|
[Dependency] private readonly IPrototypeManager _proto = default!;
|
||||||
|
private SharedAppearanceSystem _appearance;
|
||||||
|
|
||||||
public override OverlaySpace Space => OverlaySpace.WorldSpaceBelowFOV;
|
public override OverlaySpace Space => OverlaySpace.WorldSpaceBelowFOV;
|
||||||
|
|
||||||
private ShaderInstance _shader;
|
private ShaderInstance _shader;
|
||||||
|
|
||||||
public ExplosionOverlay()
|
public ExplosionOverlay(SharedAppearanceSystem appearanceSystem)
|
||||||
{
|
{
|
||||||
IoCManager.InjectDependencies(this);
|
IoCManager.InjectDependencies(this);
|
||||||
_shader = _proto.Index<ShaderPrototype>("unshaded").Instance();
|
_shader = _proto.Index<ShaderPrototype>("unshaded").Instance();
|
||||||
|
_appearance = appearanceSystem;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Draw(in OverlayDrawArgs args)
|
protected override void Draw(in OverlayDrawArgs args)
|
||||||
@@ -33,15 +35,14 @@ public sealed class ExplosionOverlay : Overlay
|
|||||||
drawHandle.UseShader(_shader);
|
drawHandle.UseShader(_shader);
|
||||||
|
|
||||||
var xforms = _entMan.GetEntityQuery<TransformComponent>();
|
var xforms = _entMan.GetEntityQuery<TransformComponent>();
|
||||||
var query = _entMan
|
var query = _entMan.EntityQueryEnumerator<ExplosionVisualsComponent, ExplosionVisualsTexturesComponent>();
|
||||||
.EntityQuery<ExplosionVisualsComponent, ExplosionVisualsTexturesComponent, AppearanceComponent>(true);
|
|
||||||
|
|
||||||
foreach (var (visuals, textures, appearance) in query)
|
while (query.MoveNext(out var uid, out var visuals, out var textures))
|
||||||
{
|
{
|
||||||
if (visuals.Epicenter.MapId != args.MapId)
|
if (visuals.Epicenter.MapId != args.MapId)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!appearance.TryGetData(ExplosionAppearanceData.Progress, out int index))
|
if (!_appearance.TryGetData(uid, ExplosionAppearanceData.Progress, out int index))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
index = Math.Min(index, visuals.Intensity.Count - 1);
|
index = Math.Min(index, visuals.Intensity.Count - 1);
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ public sealed class ExplosionOverlaySystem : EntitySystem
|
|||||||
[Dependency] private readonly IOverlayManager _overlayMan = default!;
|
[Dependency] private readonly IOverlayManager _overlayMan = default!;
|
||||||
[Dependency] private readonly SharedPointLightSystem _lights = default!;
|
[Dependency] private readonly SharedPointLightSystem _lights = default!;
|
||||||
[Dependency] private readonly IMapManager _mapMan = default!;
|
[Dependency] private readonly IMapManager _mapMan = default!;
|
||||||
|
[Dependency] private readonly SharedAppearanceSystem _appearance = default!;
|
||||||
|
|
||||||
public override void Initialize()
|
public override void Initialize()
|
||||||
{
|
{
|
||||||
@@ -28,7 +29,7 @@ public sealed class ExplosionOverlaySystem : EntitySystem
|
|||||||
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentInit>(OnExplosionInit);
|
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentInit>(OnExplosionInit);
|
||||||
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentRemove>(OnCompRemove);
|
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentRemove>(OnCompRemove);
|
||||||
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentHandleState>(OnExplosionHandleState);
|
SubscribeLocalEvent<ExplosionVisualsComponent, ComponentHandleState>(OnExplosionHandleState);
|
||||||
_overlayMan.AddOverlay(new ExplosionOverlay());
|
_overlayMan.AddOverlay(new ExplosionOverlay(_appearance));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnExplosionHandleState(EntityUid uid, ExplosionVisualsComponent component, ref ComponentHandleState args)
|
private void OnExplosionHandleState(EntityUid uid, ExplosionVisualsComponent component, ref ComponentHandleState args)
|
||||||
|
|||||||
Reference in New Issue
Block a user