* Initial * Cleanup a bunch of things * some changes dunno * RequireAnchored * a * stuff * more work * Lots of progress * delete pipe visualizer * a * b * pipenet and pipenode cleanup * Fixes * Adds GasValve * Adds GasMiner * Fix stuff, maybe? * More fixes * Ignored components on the client * Adds thermomachine behavior, change a bunch of stuff * Remove Anchored * some work, but it's shitcode * significantly more ECS * ECS AtmosDevices * Cleanup * fix appearance * when the pipe direction is sus * Gas tanks and canisters * pipe anchoring and stuff * coding is my passion * Unsafe pipes take longer to unanchor * turns out we're no longer using eris canisters * Gas canister inserted tank appearance, improvements * Work on a bunch of appearances * Scrubber appearance * Reorganize AtmosphereSystem.Piping into a bunch of different systems * Appearance for vent/scrubber/pump turns off when leaving atmosphere * ThermoMachine appearance * Cleanup gas tanks * Remove passive gate unused imports * remove old canister UI functionality * PipeNode environment air, make everything use AssumeAir instead of merging manually * a * Reorganize atmos to follow new structure * ????? * Canister UI, restructure client * Restructure shared * Fix build tho * listen, at least the canister UI works entirely... * fix build : ) * Atmos device prototypes have names and descriptions * gas canister ui slider doesn't jitter * trinary prototypes * sprite for miners * ignore components * fix YAML * Fix port system doing useless thing * Fix build * fix thinking moment * fix build again because * canister direction * pipenode is a word * GasTank Air will throw on invalid states * fix build.... * Unhardcode volume pump thresholds * Volume pump and filter take time into account * Rename Join/Leave atmosphere events to AtmosDeviceEnabled/Disabled Event * Gas tank node volume is set by initial mixtuer * I love node container
72 lines
2.1 KiB
C#
72 lines
2.1 KiB
C#
using Content.Shared.Atmos.Components;
|
|
using JetBrains.Annotations;
|
|
using Robust.Client.GameObjects;
|
|
using Robust.Shared.GameObjects;
|
|
using Robust.Shared.Serialization.Manager.Attributes;
|
|
|
|
namespace Content.Client.Atmos.Visualizers
|
|
{
|
|
[UsedImplicitly]
|
|
public class FireVisualizer : AppearanceVisualizer
|
|
{
|
|
[DataField("fireStackAlternateState")]
|
|
private int _fireStackAlternateState = 3;
|
|
|
|
[DataField("normalState")]
|
|
private string? _normalState;
|
|
|
|
[DataField("alternateState")]
|
|
private string? _alternateState;
|
|
|
|
[DataField("sprite")]
|
|
private string? _sprite;
|
|
|
|
public override void InitializeEntity(IEntity entity)
|
|
{
|
|
base.InitializeEntity(entity);
|
|
|
|
var sprite = entity.GetComponent<ISpriteComponent>();
|
|
|
|
sprite.LayerMapReserveBlank(FireVisualLayers.Fire);
|
|
sprite.LayerSetVisible(FireVisualLayers.Fire, false);
|
|
}
|
|
|
|
public override void OnChangeData(AppearanceComponent component)
|
|
{
|
|
base.OnChangeData(component);
|
|
|
|
if (component.TryGetData(FireVisuals.OnFire, out bool onFire))
|
|
{
|
|
var fireStacks = 0f;
|
|
|
|
if (component.TryGetData(FireVisuals.FireStacks, out float stacks))
|
|
fireStacks = stacks;
|
|
|
|
SetOnFire(component, onFire, fireStacks);
|
|
}
|
|
}
|
|
|
|
private void SetOnFire(AppearanceComponent component, bool onFire, float fireStacks)
|
|
{
|
|
var sprite = component.Owner.GetComponent<ISpriteComponent>();
|
|
|
|
if (_sprite != null)
|
|
{
|
|
sprite.LayerSetRSI(FireVisualLayers.Fire, _sprite);
|
|
}
|
|
|
|
sprite.LayerSetVisible(FireVisualLayers.Fire, onFire);
|
|
|
|
if(fireStacks > _fireStackAlternateState && !string.IsNullOrEmpty(_alternateState))
|
|
sprite.LayerSetState(FireVisualLayers.Fire, _alternateState);
|
|
else
|
|
sprite.LayerSetState(FireVisualLayers.Fire, _normalState);
|
|
}
|
|
}
|
|
|
|
public enum FireVisualLayers : byte
|
|
{
|
|
Fire
|
|
}
|
|
}
|