* #3935 - toys properly play sounds when: Activated, Landed (after throwing) and Used in hand * #3935 - extracted BaseEmitSoundComponent * #3935 - refactored EmitSound components to use ECS * #3935 - added new components to client ignored components * #3935 - added suggested stuff for EmitSoundSystem et al. * #3935 added suggestions from PR * #3935 implemented suggestions from PR * #3935 updated namespace
This commit is contained in:
@@ -17,6 +17,8 @@ namespace Content.Client.Entry
|
|||||||
"OnUseTimerTrigger",
|
"OnUseTimerTrigger",
|
||||||
"WarpPoint",
|
"WarpPoint",
|
||||||
"EmitSoundOnUse",
|
"EmitSoundOnUse",
|
||||||
|
"EmitSoundOnLand",
|
||||||
|
"EmitSoundOnActivate",
|
||||||
"FootstepModifier",
|
"FootstepModifier",
|
||||||
"HeatResistance",
|
"HeatResistance",
|
||||||
"ItemTeleporter",
|
"ItemTeleporter",
|
||||||
|
|||||||
@@ -1,45 +1,15 @@
|
|||||||
using Content.Shared.Audio;
|
using Content.Server.Sound;
|
||||||
using Content.Shared.Interaction;
|
|
||||||
using Robust.Shared.Audio;
|
|
||||||
using Robust.Shared.GameObjects;
|
using Robust.Shared.GameObjects;
|
||||||
using Robust.Shared.Player;
|
|
||||||
using Robust.Shared.Serialization.Manager.Attributes;
|
|
||||||
using Robust.Shared.ViewVariables;
|
|
||||||
|
|
||||||
namespace Content.Server.Interaction.Components
|
namespace Content.Server.Interaction.Components
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Simple sound emitter that emits sound on use in hand
|
/// Simple sound emitter that emits sound on UseInHand
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[RegisterComponent]
|
[RegisterComponent]
|
||||||
public class EmitSoundOnUseComponent : Component, IUse
|
public class EmitSoundOnUseComponent : BaseEmitSoundComponent
|
||||||
{
|
{
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
///
|
|
||||||
public override string Name => "EmitSoundOnUse";
|
public override string Name => "EmitSoundOnUse";
|
||||||
|
|
||||||
[ViewVariables(VVAccess.ReadWrite)] [DataField("sound")] public string? _soundName;
|
|
||||||
[ViewVariables(VVAccess.ReadWrite)] [DataField("variation")] public float _pitchVariation;
|
|
||||||
[ViewVariables(VVAccess.ReadWrite)] [DataField("semitoneVariation")] public int _semitoneVariation;
|
|
||||||
|
|
||||||
bool IUse.UseEntity(UseEntityEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
if (!string.IsNullOrWhiteSpace(_soundName))
|
|
||||||
{
|
|
||||||
if (_pitchVariation > 0.0)
|
|
||||||
{
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _soundName, Owner, AudioHelpers.WithVariation(_pitchVariation).WithVolume(-2f));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (_semitoneVariation > 0)
|
|
||||||
{
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _soundName, Owner, AudioHelpers.WithSemitoneVariation(_semitoneVariation).WithVolume(-2f));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _soundName, Owner, AudioParams.Default.WithVolume(-2f));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
15
Content.Server/Sound/BaseEmitSoundComponent.cs
Normal file
15
Content.Server/Sound/BaseEmitSoundComponent.cs
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.Serialization.Manager.Attributes;
|
||||||
|
using Robust.Shared.ViewVariables;
|
||||||
|
|
||||||
|
namespace Content.Server.Sound
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Base sound emitter which defines most of the data fields.
|
||||||
|
/// </summary>
|
||||||
|
public abstract class BaseEmitSoundComponent : Component
|
||||||
|
{
|
||||||
|
[ViewVariables(VVAccess.ReadWrite)] [DataField("variation")] public float PitchVariation { get; set; } = 0.0f;
|
||||||
|
[ViewVariables(VVAccess.ReadWrite)] [DataField("soundCollection", required: true)] public string SoundCollectionName { get; set; } = default!;
|
||||||
|
}
|
||||||
|
}
|
||||||
14
Content.Server/Sound/EmitSoundOnActivateComponent.cs
Normal file
14
Content.Server/Sound/EmitSoundOnActivateComponent.cs
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Server.Sound
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Simple sound emitter that emits sound on ActivateInWorld
|
||||||
|
/// </summary>
|
||||||
|
[RegisterComponent]
|
||||||
|
public class EmitSoundOnActivateComponent : BaseEmitSoundComponent
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public override string Name => "EmitSoundOnActivate";
|
||||||
|
}
|
||||||
|
}
|
||||||
14
Content.Server/Sound/EmitSoundOnLandComponent.cs
Normal file
14
Content.Server/Sound/EmitSoundOnLandComponent.cs
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
|
||||||
|
namespace Content.Server.Sound
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Simple sound emitter that emits sound on LandEvent
|
||||||
|
/// </summary>
|
||||||
|
[RegisterComponent]
|
||||||
|
public class EmitSoundOnLandComponent : BaseEmitSoundComponent
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public override string Name => "EmitSoundOnLand";
|
||||||
|
}
|
||||||
|
}
|
||||||
56
Content.Server/Sound/EmitSoundSystem.cs
Normal file
56
Content.Server/Sound/EmitSoundSystem.cs
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
using Content.Shared.Audio;
|
||||||
|
using Content.Shared.Interaction;
|
||||||
|
using Content.Shared.Throwing;
|
||||||
|
using Content.Server.Interaction.Components;
|
||||||
|
using Content.Server.Throwing;
|
||||||
|
using JetBrains.Annotations;
|
||||||
|
using Robust.Shared.Audio;
|
||||||
|
using Robust.Shared.GameObjects;
|
||||||
|
using Robust.Shared.IoC;
|
||||||
|
using Robust.Shared.Prototypes;
|
||||||
|
using Robust.Shared.Player;
|
||||||
|
using Robust.Shared.Random;
|
||||||
|
|
||||||
|
namespace Content.Server.Sound
|
||||||
|
{
|
||||||
|
[UsedImplicitly]
|
||||||
|
public class EmitSoundSystem : EntitySystem
|
||||||
|
{
|
||||||
|
[Dependency] private readonly IPrototypeManager _prototypeManager = default!;
|
||||||
|
[Dependency] private readonly IRobustRandom _random = default!;
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
public override void Initialize()
|
||||||
|
{
|
||||||
|
base.Initialize();
|
||||||
|
SubscribeLocalEvent<EmitSoundOnLandComponent, LandEvent>((eUI, comp, arg) => PlaySound(comp));
|
||||||
|
SubscribeLocalEvent<EmitSoundOnUseComponent, UseInHandEvent>((eUI, comp, arg) => PlaySound(comp));
|
||||||
|
SubscribeLocalEvent<EmitSoundOnThrowComponent, ThrownEvent>((eUI, comp, arg) => PlaySound(comp));
|
||||||
|
SubscribeLocalEvent<EmitSoundOnActivateComponent, ActivateInWorldEvent>((eUI, comp, args) => PlaySound(comp));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void PlaySound(BaseEmitSoundComponent component)
|
||||||
|
{
|
||||||
|
PlayRandomSoundFromCollection(component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void PlayRandomSoundFromCollection(BaseEmitSoundComponent component)
|
||||||
|
{
|
||||||
|
var file = SelectRandomSoundFromSoundCollection(component.SoundCollectionName!);
|
||||||
|
PlaySingleSound(file, component);
|
||||||
|
}
|
||||||
|
|
||||||
|
private string SelectRandomSoundFromSoundCollection(string soundCollectionName)
|
||||||
|
{
|
||||||
|
var soundCollection = _prototypeManager.Index<SoundCollectionPrototype>(soundCollectionName);
|
||||||
|
return _random.Pick(soundCollection.PickFiles);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void PlaySingleSound(string soundName, BaseEmitSoundComponent component)
|
||||||
|
{
|
||||||
|
SoundSystem.Play(Filter.Pvs(component.Owner), soundName, component.Owner,
|
||||||
|
AudioHelpers.WithVariation(component.PitchVariation).WithVolume(-2f));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -1,42 +1,15 @@
|
|||||||
using Content.Shared.Audio;
|
using Content.Server.Sound;
|
||||||
using Content.Shared.Throwing;
|
|
||||||
using Robust.Shared.Audio;
|
|
||||||
using Robust.Shared.GameObjects;
|
using Robust.Shared.GameObjects;
|
||||||
using Robust.Shared.Player;
|
|
||||||
using Robust.Shared.Serialization.Manager.Attributes;
|
|
||||||
|
|
||||||
namespace Content.Server.Throwing
|
namespace Content.Server.Throwing
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Simple sound emitter that emits sound on use in hand
|
/// Simple sound emitter that emits sound on ThrowEvent
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[RegisterComponent]
|
[RegisterComponent]
|
||||||
public class EmitSoundOnThrowComponent : Component, ILand
|
public class EmitSoundOnThrowComponent : BaseEmitSoundComponent
|
||||||
{
|
{
|
||||||
/// <inheritdoc />
|
/// <inheritdoc />
|
||||||
///
|
|
||||||
public override string Name => "EmitSoundOnThrow";
|
public override string Name => "EmitSoundOnThrow";
|
||||||
|
|
||||||
[DataField("sound")]
|
|
||||||
public string? _soundName;
|
|
||||||
[DataField("variation")]
|
|
||||||
public float _pitchVariation;
|
|
||||||
|
|
||||||
public void PlaySoundEffect()
|
|
||||||
{
|
|
||||||
if (!string.IsNullOrWhiteSpace(_soundName))
|
|
||||||
{
|
|
||||||
if (_pitchVariation > 0.0)
|
|
||||||
{
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _soundName, Owner, AudioHelpers.WithVariation(_pitchVariation).WithVolume(-2f));
|
|
||||||
}
|
|
||||||
SoundSystem.Play(Filter.Pvs(Owner), _soundName, Owner, AudioParams.Default.WithVolume(-2f));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ILand.Land(LandEventArgs eventArgs)
|
|
||||||
{
|
|
||||||
PlaySoundEffect();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ namespace Content.Shared.Throwing
|
|||||||
// LandInteraction
|
// LandInteraction
|
||||||
// TODO: Refactor these to system messages
|
// TODO: Refactor these to system messages
|
||||||
var landMsg = new LandEvent(user, landing, coordinates);
|
var landMsg = new LandEvent(user, landing, coordinates);
|
||||||
RaiseLocalEvent(landMsg);
|
RaiseLocalEvent(landing.Uid, landMsg);
|
||||||
if (landMsg.Handled)
|
if (landMsg.Handled)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -2,96 +2,81 @@
|
|||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BaseItem
|
||||||
|
id: BasePlushie
|
||||||
|
components:
|
||||||
|
- type: EmitSoundOnUse
|
||||||
|
soundCollection: ToySqueak
|
||||||
|
- type: EmitSoundOnLand
|
||||||
|
soundCollection: ToySqueak
|
||||||
|
- type: EmitSoundOnActivate
|
||||||
|
soundCollection: ToySqueak
|
||||||
|
- type: LoopingSound
|
||||||
|
- type: ItemCooldown
|
||||||
|
- type: UseDelay
|
||||||
|
delay: 1.0
|
||||||
|
|
||||||
|
- type: entity
|
||||||
|
parent: BasePlushie
|
||||||
id: PlushieBee
|
id: PlushieBee
|
||||||
name: bee plushie
|
name: bee plushie
|
||||||
description: A cute toy that resembles an even cuter programmer.
|
description: A cute toy that resembles an even cuter programmer.
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: plushie_h
|
state: plushie_h
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BasePlushie
|
||||||
id: PlushieNuke
|
id: PlushieNuke
|
||||||
name: nukie plushie
|
name: nukie plushie
|
||||||
description: A stuffed toy that resembles a syndicate nuclear operative. The tag claims operatives to be purely fictitious.
|
description: A stuffed toy that resembles a syndicate nuclear operative. The tag claims operatives to be purely fictitious.
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: plushie_nuke
|
state: plushie_nuke
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BasePlushie
|
||||||
id: PlushieLizard
|
id: PlushieLizard
|
||||||
name: lizard plushie
|
name: lizard plushie
|
||||||
description: An adorable stuffed toy that resembles a lizardperson. Made by CentCom as a token initiative to combat speciesism in work environments. "Welcome your new colleges as you do this plush, with open arms!"
|
description: An adorable stuffed toy that resembles a lizardperson. Made by CentCom as a token initiative to combat speciesism in work environments. "Welcome your new colleges as you do this plush, with open arms!"
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: plushie_lizard
|
state: plushie_lizard
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BasePlushie
|
||||||
id: PlushieNar
|
id: PlushieNar
|
||||||
name: nar'sie plushie
|
name: nar'sie plushie
|
||||||
description: A small stuffed doll of the elder goddess Nar'Sie.
|
description: A small stuffed doll of the elder goddess Nar'Sie.
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: narplush
|
state: narplush
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BasePlushie
|
||||||
id: PlushieCarp
|
id: PlushieCarp
|
||||||
name: carp plushie
|
name: carp plushie
|
||||||
description: An adorable stuffed toy that resembles the monstrous space carp.
|
description: An adorable stuffed toy that resembles the monstrous space carp.
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: carpplush
|
state: carpplush
|
||||||
- type: Item
|
- type: Item
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
HeldPrefix: carpplush
|
HeldPrefix: carpplush
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BasePlushie
|
||||||
id: PlushieSlime
|
id: PlushieSlime
|
||||||
name: slime plushie
|
name: slime plushie
|
||||||
description: An adorable stuffed toy that resembles a slime. It's basically a hacky sack.
|
description: An adorable stuffed toy that resembles a slime. It's basically a hacky sack.
|
||||||
components:
|
components:
|
||||||
- type: Toys
|
|
||||||
- type: LoopingSound
|
|
||||||
- type: Sprite
|
- type: Sprite
|
||||||
sprite: Objects/Fun/toys.rsi
|
sprite: Objects/Fun/toys.rsi
|
||||||
state: plushie_slime
|
state: plushie_slime
|
||||||
- type: ItemCooldown
|
|
||||||
- type: UseDelay
|
|
||||||
delay: 1.0
|
|
||||||
|
|
||||||
- type: entity
|
- type: entity
|
||||||
parent: BaseItem
|
parent: BaseItem
|
||||||
|
|||||||
Reference in New Issue
Block a user