AudioHelpers.cs 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using Robust.Shared.Audio;
  2. using Robust.Shared.Prototypes;
  3. using Robust.Shared.Random;
  4. namespace Content.Shared.Audio
  5. {
  6. public static class AudioHelpers
  7. {
  8. /// <summary>
  9. /// Returns a random pitch.
  10. /// </summary>
  11. [Obsolete("Use AudioParams.Variation data-field")]
  12. public static AudioParams WithVariation(float amplitude)
  13. {
  14. return WithVariation(amplitude, null);
  15. }
  16. /// <summary>
  17. /// Returns a random pitch.
  18. /// </summary>
  19. [Obsolete("Use AudioParams.Variation data-field")]
  20. public static AudioParams WithVariation(float amplitude, IRobustRandom? rand)
  21. {
  22. IoCManager.Resolve(ref rand);
  23. var scale = (float) rand.NextGaussian(1, amplitude);
  24. return AudioParams.Default.WithPitchScale(scale);
  25. }
  26. // Might as well just hardcode these because the audio system is limited to pitching up and down
  27. // by 12 semitones anyway (ie. 0.5 to 2.0 multiplier).
  28. private static readonly float[] SemitoneMultipliers =
  29. {
  30. 0.5f, 233.08f/440f, 246.94f/440f, 261.63f/440f,
  31. 277.18f/440f, 293.66f/440f, 311.13f/440f, 329.63f/440f,
  32. 349.23f/440f, 369.99f/440f, 392.00f/440f, 415.30f/440f,
  33. 1.0f,
  34. 466.16f/440f, 493.88f/440f, 523.25f/440f, 554.37f/440f,
  35. 587.33f/440f, 622.25f/440f, 659.26f/440f, 698.46f/440f,
  36. 739.99f/440f, 783.99f/440f, 830.61f/440f, 2.0f
  37. };
  38. /// <summary>
  39. /// Returns a pitch multiplier that shifts by the given number of semitones.
  40. /// </summary>
  41. /// <param name="shift">Number of semitones to shift, positive or negative. Clamped between -12 and 12
  42. /// which correspond to a pitch multiplier of 0.5 and 2.0 respectively.</param>
  43. public static AudioParams ShiftSemitone(AudioParams @params, int shift)
  44. {
  45. shift = MathHelper.Clamp(shift, -12, 12);
  46. float pitchMult = SemitoneMultipliers[shift + 12];
  47. return @params.WithPitchScale(pitchMult);
  48. }
  49. /// <summary>
  50. /// Returns a pitch multiplier shifted by a random number of semitones within variation.
  51. /// </summary>
  52. /// <param name="variation">Max number of semitones to shift in either direction. Values above 12 have no effect.</param>
  53. public static AudioParams WithSemitoneVariation(AudioParams @params, int variation, IRobustRandom rand)
  54. {
  55. IoCManager.Resolve(ref rand);
  56. variation = Math.Clamp(variation, 0, 12);
  57. return ShiftSemitone(@params, rand.Next(-variation, variation));
  58. }
  59. }
  60. }