Ух ты
This commit is contained in:
@@ -50,11 +50,18 @@ public sealed class FastAndFuriousAspect : AspectSystem<FastAndFuriousAspectComp
|
|||||||
|
|
||||||
private void HandleLateJoin(PlayerSpawnCompleteEvent ev)
|
private void HandleLateJoin(PlayerSpawnCompleteEvent ev)
|
||||||
{
|
{
|
||||||
if (!ev.LateJoin)
|
var query = EntityQueryEnumerator<FastAndFuriousAspectComponent, GameRuleComponent>();
|
||||||
return;
|
while (query.MoveNext(out var ruleEntity, out _, out var gameRule))
|
||||||
|
{
|
||||||
|
if (!GameTicker.IsGameRuleAdded(ruleEntity, gameRule))
|
||||||
|
continue;
|
||||||
|
|
||||||
ModifySpeedIfActive(ev.Mob);
|
if (!ev.LateJoin)
|
||||||
_chatHelper.SendAspectDescription(ev.Mob, Loc.GetString("fast-and-furious-aspect-desc"));
|
return;
|
||||||
|
|
||||||
|
ModifySpeedIfActive(ev.Mob);
|
||||||
|
_chatHelper.SendAspectDescription(ev.Mob, Loc.GetString("fast-and-furious-aspect-desc"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ModifySpeedIfActive(EntityUid mob)
|
private void ModifySpeedIfActive(EntityUid mob)
|
||||||
|
|||||||
@@ -12,6 +12,8 @@ public sealed partial class AspectComponent : Component
|
|||||||
|
|
||||||
[DataField] public string? Requires;
|
[DataField] public string? Requires;
|
||||||
|
|
||||||
|
[DataField] public string? Sender;
|
||||||
|
|
||||||
[DataField] public float Weight = 1.0f;
|
[DataField] public float Weight = 1.0f;
|
||||||
|
|
||||||
[DataField] public bool IsForbidden;
|
[DataField] public bool IsForbidden;
|
||||||
|
|||||||
@@ -66,8 +66,10 @@ public abstract class AspectSystem<T> : GameRuleSystem<T> where T : Component
|
|||||||
|
|
||||||
if (aspect is { Description: not null, IsHidden: false })
|
if (aspect is { Description: not null, IsHidden: false })
|
||||||
{
|
{
|
||||||
_chatSystem.DispatchGlobalAnnouncement(aspect.Description, playSound: false,
|
_chatSystem.DispatchGlobalAnnouncement(aspect.Description,
|
||||||
colorOverride: Color.Aquamarine);
|
sender: aspect.Sender ??= "Центральное Командование",
|
||||||
|
playSound: false,
|
||||||
|
colorOverride: Color.Aquamarine);
|
||||||
}
|
}
|
||||||
|
|
||||||
_audio.PlayGlobal(aspect.StartAudio, Filter.Broadcast(), true);
|
_audio.PlayGlobal(aspect.StartAudio, Filter.Broadcast(), true);
|
||||||
@@ -105,14 +107,17 @@ public abstract class AspectSystem<T> : GameRuleSystem<T> where T : Component
|
|||||||
|
|
||||||
if (aspect is { Name: not null, IsHidden: false })
|
if (aspect is { Name: not null, IsHidden: false })
|
||||||
{
|
{
|
||||||
_chatSystem.DispatchGlobalAnnouncement($"Именем аспекта являлось: {aspect.Name}", playSound: false,
|
|
||||||
colorOverride: Color.Aquamarine);
|
_chatSystem.DispatchGlobalAnnouncement($"Именем аспекта являлось: {aspect.Name}",
|
||||||
|
sender: aspect.Sender ??= "Центральное Командование",
|
||||||
|
playSound: false,
|
||||||
|
colorOverride: Color.Aquamarine);
|
||||||
}
|
}
|
||||||
|
|
||||||
_audio.PlayGlobal(aspect.EndAudio, Filter.Broadcast(), true);
|
_audio.PlayGlobal(aspect.EndAudio, Filter.Broadcast(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#region Helpers
|
#region Helpers
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Forces this aspect to end prematurely.
|
/// Forces this aspect to end prematurely.
|
||||||
@@ -140,5 +145,5 @@ public abstract class AspectSystem<T> : GameRuleSystem<T> where T : Component
|
|||||||
return grids.Count > 0;
|
return grids.Count > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Акценты вне контроля
|
name: Акценты вне контроля
|
||||||
description: Всегда интересно, какой акцент вы услышите следующим
|
sender: Федерация Космических Волшебников
|
||||||
|
description: Всегда интересно, какой акцент вы услышите следующим.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -18,7 +19,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Fast and Furious
|
name: Fast and Furious
|
||||||
description: Люди спешат и не важно куда
|
description: Новейшие разработки в области фильтрации питьевой воды привели к непредвиденным результатам. КПД двигательных систем большинства органических и неорганических существ возрос на 60%!
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -58,7 +59,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Drunk
|
name: Drunk
|
||||||
description: На станции стоит явный запах вчерашнего веселья... и кажется оно только начинается
|
description: На станции стоит явный запах вчерашнего веселья... и кажется оно только начинается.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -71,7 +72,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Cargo Rich
|
name: Cargo Rich
|
||||||
description: Карго работало усердно в прошлую смену, за что они и были награждены премией в размере 100000 кредитов
|
description: Карго работало усердно в прошлую смену, за что они и были награждены премией в размере 100000 кредитов.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -97,7 +98,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Weak Walls
|
name: Weak Walls
|
||||||
description: На стенах явно экономили
|
description: В связи с невыполнением экономических показателей за предыдущий финансовый период - было принято решение на экономии строительных материалов для стен.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -110,7 +111,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: No engine
|
name: No engine
|
||||||
description: Какой-то смышлённый агент синдиката решил украсть все ваши генераторы энергии целиком
|
description: Какой-то смышлённый агент синдиката решил украсть все ваши генераторы энергии целиком.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -123,7 +124,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Airunlock
|
name: Airunlock
|
||||||
description: Кого волнует безопасность? Экипаж свободно может ходить по всем отсекам, ведь все шлюзы теперь для них доступны
|
sender: Федерация Космических Волшебников
|
||||||
|
description: Кого волнует безопасность? Экипаж свободно может ходить по всем отсекам, ведь все шлюзы теперь для них доступны.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -137,7 +139,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Bloody
|
name: Bloody
|
||||||
description: В эту смену любая незначительная травма может оказаться летальной
|
sender: Федерация Космических Волшебников
|
||||||
|
description: В эту смену любая незначительная травма может оказаться летальной.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -150,6 +153,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Weak
|
name: Weak
|
||||||
|
sender: Федерация Космических Волшебников
|
||||||
description: Удары стали слабее. Пули мягче. К чему это приведёт?
|
description: Удары стали слабее. Пули мягче. К чему это приведёт?
|
||||||
weight: 1
|
weight: 1
|
||||||
startAudio:
|
startAudio:
|
||||||
@@ -163,7 +167,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Battled
|
name: Battled
|
||||||
description: Люди очень насторожены и готовы дать отпор в любую секунду
|
description: Люди очень насторожены и готовы дать отпор в любую секунду.
|
||||||
weight: 1
|
weight: 1
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -189,6 +193,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Presents
|
name: Presents
|
||||||
|
sender: Федерация Космических Волшебников
|
||||||
description: А вы верите в Деда Мороза?
|
description: А вы верите в Деда Мороза?
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
@@ -202,6 +207,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Dance
|
name: Dance
|
||||||
|
sender: Федерация Космических Волшебников
|
||||||
description: Танцуют все!
|
description: Танцуют все!
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
@@ -215,7 +221,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Reflect
|
name: Reflect
|
||||||
description: Ваше отражение повсюду
|
sender: Федерация Космических Волшебников
|
||||||
|
description: Ваше отражение повсюду.
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -228,7 +235,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Slippery
|
name: Slippery
|
||||||
description: Постарайтесь не поскальзываться!
|
sender: Федерация Космических Волшебников
|
||||||
|
description: Постарайтесь не подскальзываться!
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -241,7 +249,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Extra TC
|
name: Extra TC
|
||||||
description: Синдикат выделил 10 дополнительных телекристаллов для предателей
|
description: Синдикат выделил 10 дополнительных телекристаллов для предателей.
|
||||||
requires: Traitors
|
requires: Traitors
|
||||||
weight: 3
|
weight: 3
|
||||||
isHidden: true
|
isHidden: true
|
||||||
@@ -254,7 +262,8 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Whisper
|
name: Whisper
|
||||||
description: Из-за боли в горле речь дается вам с трудом
|
sender: Федерация Космических Волшебников
|
||||||
|
description: Вы слишком шумные, мы запрещаем вам повышать голос!
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -268,6 +277,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Darkness
|
name: Darkness
|
||||||
|
sender: Федерация Космических Волшебников
|
||||||
description: Почему все так темно?
|
description: Почему все так темно?
|
||||||
weight: 2
|
weight: 2
|
||||||
startAudio:
|
startAudio:
|
||||||
@@ -281,7 +291,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Stolen Floor
|
name: Stolen Floor
|
||||||
description: Рабочие забыли положить плитку при строительстве станции
|
description: Рабочие забыли положить плитку при строительстве станции.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -294,7 +304,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Are We In Dungeon
|
name: Are We In Dungeon
|
||||||
description: В связи с невероятной хрупкостью окон было решено заменить их на стены
|
description: В связи с невероятной хрупкостью окон было решено заменить их на стены.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -307,7 +317,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Cat Ears And Tail
|
name: Cat Ears And Tail
|
||||||
description: Из-за ошибки в системе клонирования на ЦК все члены экипажа стали походить на фелинидов
|
description: Из-за ошибки в системе клонирования на ЦК все члены экипажа стали походить на фелинидов.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -333,7 +343,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Random item
|
name: Random item
|
||||||
description: ЦК выдало каждому члену экипажа определённый предмет
|
description: ЦК выдало каждому члену экипажа определённый предмет.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
@@ -346,7 +356,7 @@
|
|||||||
components:
|
components:
|
||||||
- type: Aspect
|
- type: Aspect
|
||||||
name: Immersive
|
name: Immersive
|
||||||
description: В связи с недавними трагичными событиями экипаж станции погрузился в себя
|
description: В связи с недавними трагичными событиями экипаж станции погрузился в себя.
|
||||||
weight: 3
|
weight: 3
|
||||||
startAudio:
|
startAudio:
|
||||||
path: /Audio/White/Aspects/accent.ogg
|
path: /Audio/White/Aspects/accent.ogg
|
||||||
|
|||||||
Reference in New Issue
Block a user