Merge pull request #4999 from Mailaender/start-game-notification

Moved StartGameNotification into its own trait
This commit is contained in:
Paul Chote
2014-04-21 01:32:29 +12:00
9 changed files with 50 additions and 13 deletions

View File

@@ -262,9 +262,6 @@ namespace OpenRA
orderManager.LastTickTime = Environment.TickCount; orderManager.LastTickTime = Environment.TickCount;
orderManager.StartGame(); orderManager.StartGame();
worldRenderer.RefreshPalette(); worldRenderer.RefreshPalette();
if (!isShellmap)
Sound.PlayNotification(null, "Speech", "StartGame", null);
} }
public static bool IsHost public static bool IsHost

View File

@@ -26,12 +26,12 @@ namespace OpenRA.GameRules
public readonly string[] DisableVariants = { }; public readonly string[] DisableVariants = { };
public readonly string[] DisablePrefixes = { }; public readonly string[] DisablePrefixes = { };
static Dictionary<string, string[]> Load( MiniYaml y, string name ) static Dictionary<string, string[]> Load(MiniYaml y, string name)
{ {
return y.NodesDict.ContainsKey( name ) return y.NodesDict.ContainsKey(name)
? y.NodesDict[ name ].NodesDict.ToDictionary( ? y.NodesDict[name].NodesDict.ToDictionary(
a => a.Key, a => a.Key,
a => FieldLoader.GetValue<string[]>( "(value)", a.Value.Value ) ) a => FieldLoader.GetValue<string[]>("(value)", a.Value.Value))
: new Dictionary<string, string[]>(); : new Dictionary<string, string[]>();
} }

View File

@@ -1,6 +1,6 @@
#region Copyright & License Information #region Copyright & License Information
/* /*
* Copyright 2007-2011 The OpenRA Developers (see AUTHORS) * Copyright 2007-2014 The OpenRA Developers (see AUTHORS)
* This file is part of OpenRA, which is free software. It is made * This file is part of OpenRA, which is free software. It is made
* available to you under the terms of the GNU General Public License * available to you under the terms of the GNU General Public License
* as published by the Free Software Foundation. For more information, * as published by the Free Software Foundation. For more information,
@@ -22,17 +22,16 @@ namespace OpenRA.Mods.RA
class ActorLostNotification : INotifyKilled class ActorLostNotification : INotifyKilled
{ {
ActorLostNotificationInfo Info; ActorLostNotificationInfo info;
public ActorLostNotification(ActorLostNotificationInfo info) public ActorLostNotification(ActorLostNotificationInfo info)
{ {
Info = info; this.info = info;
} }
public void Killed(Actor self, AttackInfo e) public void Killed(Actor self, AttackInfo e)
{ {
var player = (Info.NotifyAll) ? self.World.LocalPlayer : self.Owner; var player = (info.NotifyAll) ? self.World.LocalPlayer : self.Owner;
Sound.PlayNotification(player, "Speech", Info.Notification, self.Owner.Country.Race); Sound.PlayNotification(player, "Speech", info.Notification, self.Owner.Country.Race);
} }
} }
} }

View File

@@ -496,6 +496,7 @@
<Compile Include="Buildings\LineBuildNode.cs" /> <Compile Include="Buildings\LineBuildNode.cs" />
<Compile Include="ModChooserLoadScreen.cs" /> <Compile Include="ModChooserLoadScreen.cs" />
<Compile Include="Render\WithBuildingPlacedAnimation.cs" /> <Compile Include="Render\WithBuildingPlacedAnimation.cs" />
<Compile Include="StartGameNotification.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\OpenRA.Game\OpenRA.Game.csproj"> <ProjectReference Include="..\OpenRA.Game\OpenRA.Game.csproj">

View File

@@ -0,0 +1,36 @@
#region Copyright & License Information
/*
* Copyright 2007-2014 The OpenRA Developers (see AUTHORS)
* This file is part of OpenRA, which is free software. It is made
* available to you under the terms of the GNU General Public License
* as published by the Free Software Foundation. For more information,
* see COPYING.
*/
#endregion
using OpenRA.Graphics;
using OpenRA.Traits;
namespace OpenRA.Mods.RA
{
class StartGameNotificationInfo : ITraitInfo
{
public readonly string Notification = "StartGame";
public object Create(ActorInitializer init) { return new StartGameNotification(this); }
}
class StartGameNotification : IWorldLoaded
{
StartGameNotificationInfo info;
public StartGameNotification(StartGameNotificationInfo info)
{
this.info = info;
}
public void WorldLoaded(World w, WorldRenderer wr)
{
Sound.PlayNotification(null, "Speech", info.Notification, null);
}
}
}

View File

@@ -1307,6 +1307,7 @@ Rules:
LuaScripts: desert-shellmap.lua LuaScripts: desert-shellmap.lua
LoadWidgetAtGameStart: LoadWidgetAtGameStart:
Widget: MAINMENU Widget: MAINMENU
-StartGameNotification:
TRAN.Husk2: TRAN.Husk2:
Burns: Burns:
Damage: 0 Damage: 0

View File

@@ -165,4 +165,5 @@ World:
ValidateOrder: ValidateOrder:
DebugPauseState: DebugPauseState:
RadarPings: RadarPings:
StartGameNotification:

View File

@@ -37,6 +37,7 @@ Smudges:
Rules: Rules:
World: World:
-StartGameNotification:
-SpawnMPUnits: -SpawnMPUnits:
-MPStartLocations: -MPStartLocations:
LoadWidgetAtGameStart: LoadWidgetAtGameStart:

View File

@@ -97,4 +97,5 @@ World:
DebugPauseState: DebugPauseState:
ScreenShaker: ScreenShaker:
RadarPings: RadarPings:
StartGameNotification: