Kill PostGameWidget
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="3.5">
|
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="3.5">
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||||
@@ -99,7 +99,6 @@
|
|||||||
<Compile Include="Widgets\Delegates\SettingsMenuDelegate.cs" />
|
<Compile Include="Widgets\Delegates\SettingsMenuDelegate.cs" />
|
||||||
<Compile Include="Widgets\MoneyBinWidget.cs" />
|
<Compile Include="Widgets\MoneyBinWidget.cs" />
|
||||||
<Compile Include="Widgets\MapPreviewWidget.cs" />
|
<Compile Include="Widgets\MapPreviewWidget.cs" />
|
||||||
<Compile Include="Widgets\PostGameWidget.cs" />
|
|
||||||
<Compile Include="Widgets\WidgetUtils.cs" />
|
<Compile Include="Widgets\WidgetUtils.cs" />
|
||||||
<Compile Include="Effects\DelayedAction.cs" />
|
<Compile Include="Effects\DelayedAction.cs" />
|
||||||
<Compile Include="Effects\FlashTarget.cs" />
|
<Compile Include="Effects\FlashTarget.cs" />
|
||||||
@@ -237,7 +236,7 @@
|
|||||||
<Name>OpenRA.FileFormats</Name>
|
<Name>OpenRA.FileFormats</Name>
|
||||||
</ProjectReference>
|
</ProjectReference>
|
||||||
<Compile Include="Widgets\Delegates\DeveloperModeDelegate.cs" />
|
<Compile Include="Widgets\Delegates\DeveloperModeDelegate.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<BootstrapperPackage Include="Microsoft.Net.Framework.2.0">
|
<BootstrapperPackage Include="Microsoft.Net.Framework.2.0">
|
||||||
<Visible>False</Visible>
|
<Visible>False</Visible>
|
||||||
|
|||||||
@@ -8,6 +8,8 @@
|
|||||||
*/
|
*/
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
using OpenRA.Traits;
|
||||||
|
using System.Linq;
|
||||||
namespace OpenRA.Widgets.Delegates
|
namespace OpenRA.Widgets.Delegates
|
||||||
{
|
{
|
||||||
public class IngameChromeDelegate : IWidgetDelegate
|
public class IngameChromeDelegate : IWidgetDelegate
|
||||||
@@ -53,7 +55,36 @@ namespace OpenRA.Widgets.Delegates
|
|||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
Game.AddChatLine += gameRoot.GetWidget<ChatDisplayWidget>("CHAT_DISPLAY").AddLine;
|
Game.AddChatLine += gameRoot.GetWidget<ChatDisplayWidget>("CHAT_DISPLAY").AddLine;
|
||||||
}
|
|
||||||
|
|
||||||
|
var postgameBG = gameRoot.GetWidget("POSTGAME_BG");
|
||||||
|
var postgameText = postgameBG.GetWidget<LabelWidget>("TEXT");
|
||||||
|
postgameBG.IsVisible = () =>
|
||||||
|
{
|
||||||
|
var conds = Game.world.Queries.WithTrait<IVictoryConditions>()
|
||||||
|
.Where(c => !c.Actor.Owner.NonCombatant);
|
||||||
|
|
||||||
|
if (Game.world.LocalPlayer != null && conds.Count() > 1)
|
||||||
|
{
|
||||||
|
if (conds.Any(c => c.Actor.Owner == Game.world.LocalPlayer && c.Trait.HasLost)
|
||||||
|
|| conds.All(c => AreMutualAllies(c.Actor.Owner, Game.world.LocalPlayer) || c.Trait.HasLost))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
|
||||||
|
postgameText.GetText = () =>
|
||||||
|
{
|
||||||
|
var lost = Game.world.Queries.WithTrait<IVictoryConditions>()
|
||||||
|
.Where(c => c.Actor.Owner == Game.world.LocalPlayer)
|
||||||
|
.Any(c => c.Trait.HasLost);
|
||||||
|
|
||||||
|
return (lost) ? "YOU ARE DEFEATED" : "YOU ARE VICTORIOUS";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
bool AreMutualAllies(Player a, Player b) { return a.Stances[b] == Stance.Ally && b.Stances[a] == Stance.Ally; }
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,58 +0,0 @@
|
|||||||
#region Copyright & License Information
|
|
||||||
/*
|
|
||||||
* Copyright 2007-2010 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 LICENSE.
|
|
||||||
*/
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
using System.Drawing;
|
|
||||||
using System.Linq;
|
|
||||||
using OpenRA.Traits;
|
|
||||||
|
|
||||||
namespace OpenRA.Widgets
|
|
||||||
{
|
|
||||||
class PostGameWidget : Widget
|
|
||||||
{
|
|
||||||
public PostGameWidget() : base() { }
|
|
||||||
|
|
||||||
bool AreMutualAllies(Player a, Player b) { return a.Stances[b] == Stance.Ally && b.Stances[a] == Stance.Ally; }
|
|
||||||
|
|
||||||
// todo: all this shit needs to move, probably to Player.
|
|
||||||
|
|
||||||
public override void DrawInner(World world)
|
|
||||||
{
|
|
||||||
if (world.LocalPlayer == null) return;
|
|
||||||
|
|
||||||
if (world.players.Count > 2) /* more than just us + neutral */
|
|
||||||
{
|
|
||||||
var conds = world.Queries.WithTrait<IVictoryConditions>()
|
|
||||||
.Where(c => !c.Actor.Owner.NonCombatant);
|
|
||||||
|
|
||||||
if (conds.Any(c => c.Actor.Owner == world.LocalPlayer && c.Trait.HasLost))
|
|
||||||
DrawText("YOU ARE DEFEATED");
|
|
||||||
else if (conds.All(c => AreMutualAllies(c.Actor.Owner, world.LocalPlayer) || c.Trait.HasLost))
|
|
||||||
DrawText("YOU ARE VICTORIOUS");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DrawText(string s)
|
|
||||||
{
|
|
||||||
var size = Game.chrome.renderer.TitleFont.Measure(s);
|
|
||||||
|
|
||||||
WidgetUtils.DrawPanel("dialog4", new Rectangle(
|
|
||||||
(Game.viewport.Width - size.X - 40) / 2,
|
|
||||||
(Game.viewport.Height - size.Y - 10) / 2,
|
|
||||||
size.X + 40,
|
|
||||||
size.Y + 13));
|
|
||||||
|
|
||||||
Game.chrome.renderer.TitleFont.DrawText(s,
|
|
||||||
new float2((Game.viewport.Width - size.X) / 2,
|
|
||||||
(Game.viewport.Height - size.Y) / 2 - .2f * size.Y), Color.White);
|
|
||||||
|
|
||||||
Game.chrome.renderer.RgbaSpriteRenderer.Flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -9,8 +9,23 @@ Container@ROOT:
|
|||||||
Id:GAME_TIMER
|
Id:GAME_TIMER
|
||||||
X: WINDOW_RIGHT/2
|
X: WINDOW_RIGHT/2
|
||||||
Y: 10
|
Y: 10
|
||||||
PostGame@POSTGAME_TEXT:
|
Background@POSTGAME_BG:
|
||||||
Id:POSTGAME_TEXT
|
Id:POSTGAME_BG
|
||||||
|
X:(WINDOW_RIGHT - WIDTH)/2
|
||||||
|
Y:(WINDOW_BOTTOM - HEIGHT)/2
|
||||||
|
Width:400
|
||||||
|
Height:100
|
||||||
|
Background:dialog4
|
||||||
|
Visible:false
|
||||||
|
Children:
|
||||||
|
Label@TEXT:
|
||||||
|
Id:TEXT
|
||||||
|
X:(PARENT_RIGHT - WIDTH)/2
|
||||||
|
Y:(PARENT_BOTTOM - HEIGHT)/2
|
||||||
|
Width:200
|
||||||
|
Height:40
|
||||||
|
Align:Center
|
||||||
|
Bold:True
|
||||||
SpecialPowerBin@INGAME_POWERS_BIN:
|
SpecialPowerBin@INGAME_POWERS_BIN:
|
||||||
Id:INGAME_POWERS_BIN
|
Id:INGAME_POWERS_BIN
|
||||||
X:0
|
X:0
|
||||||
|
|||||||
@@ -9,8 +9,23 @@ Container@ROOT:
|
|||||||
Id:GAME_TIMER
|
Id:GAME_TIMER
|
||||||
X: WINDOW_RIGHT/2
|
X: WINDOW_RIGHT/2
|
||||||
Y: 10
|
Y: 10
|
||||||
PostGame@POSTGAME_TEXT:
|
Background@POSTGAME_BG:
|
||||||
Id:POSTGAME_TEXT
|
Id:POSTGAME_BG
|
||||||
|
X:(WINDOW_RIGHT - WIDTH)/2
|
||||||
|
Y:(WINDOW_BOTTOM - HEIGHT)/2
|
||||||
|
Width:400
|
||||||
|
Height:100
|
||||||
|
Background:dialog4
|
||||||
|
Visible:false
|
||||||
|
Children:
|
||||||
|
Label@TEXT:
|
||||||
|
Id:TEXT
|
||||||
|
X:(PARENT_RIGHT - WIDTH)/2
|
||||||
|
Y:(PARENT_BOTTOM - HEIGHT)/2
|
||||||
|
Width:200
|
||||||
|
Height:40
|
||||||
|
Align:Center
|
||||||
|
Bold:True
|
||||||
SpecialPowerBin@INGAME_POWERS_BIN:
|
SpecialPowerBin@INGAME_POWERS_BIN:
|
||||||
Id:INGAME_POWERS_BIN
|
Id:INGAME_POWERS_BIN
|
||||||
X:0
|
X:0
|
||||||
|
|||||||
Reference in New Issue
Block a user