Add dropdown for economic information

This commit is contained in:
Scott_NZ
2012-11-24 00:05:40 +13:00
parent babf1556e3
commit 9a9324946f
2 changed files with 269 additions and 71 deletions

View File

@@ -9,6 +9,7 @@
#endregion #endregion
using System; using System;
using System.Collections.Generic;
using System.Drawing; using System.Drawing;
using System.Linq; using System.Linq;
using OpenRA.Mods.RA.Buildings; using OpenRA.Mods.RA.Buildings;
@@ -20,26 +21,96 @@ namespace OpenRA.Mods.RA.Widgets.Logic
{ {
public class ObserverStatsLogic public class ObserverStatsLogic
{ {
ContainerWidget basicStats; class StatsDropDownOption
ScrollPanelWidget playersPanel; {
public string Title;
public Func<bool> IsSelected;
public Action OnClick;
}
ContainerWidget basicStatsHeaders;
ContainerWidget economicStatsHeaders;
ScrollPanelWidget playerStatsPanel;
ScrollItemWidget basicPlayerTemplate; ScrollItemWidget basicPlayerTemplate;
ScrollItemWidget economicPlayerTemplate;
ScrollItemWidget teamTemplate; ScrollItemWidget teamTemplate;
DropDownButtonWidget statsDropDown;
LabelWidget title;
IEnumerable<Player> players;
World world;
[ObjectCreator.UseCtor] [ObjectCreator.UseCtor]
public ObserverStatsLogic(World world, Widget widget) public ObserverStatsLogic(World world, Widget widget)
{ {
basicStats = widget.Get<ContainerWidget>("BASIC_STATS"); this.world = world;
playersPanel = widget.Get<ScrollPanelWidget>("PLAYERS_PANEL"); players = world.Players.Where(p => !p.NonCombatant);
basicPlayerTemplate = playersPanel.Get<ScrollItemWidget>("BASIC_PLAYER_TEMPLATE");
teamTemplate = playersPanel.Get<ScrollItemWidget>("TEAM_TEMPLATE");
playersPanel.RemoveChildren();
playersPanel.Layout = new GridLayout(playersPanel);
var players = world.Players.Where(p => !p.NonCombatant); title = widget.Get<LabelWidget>("TITLE");
basicStatsHeaders = widget.Get<ContainerWidget>("BASIC_STATS_HEADERS");
economicStatsHeaders = widget.Get<ContainerWidget>("ECONOMIC_STATS_HEADERS");
playerStatsPanel = widget.Get<ScrollPanelWidget>("PLAYER_STATS_PANEL");
playerStatsPanel.Layout = new GridLayout(playerStatsPanel);
basicPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("BASIC_PLAYER_TEMPLATE");
economicPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("ECONOMIC_PLAYER_TEMPLATE");
teamTemplate = playerStatsPanel.Get<ScrollItemWidget>("TEAM_TEMPLATE");
statsDropDown = widget.Get<DropDownButtonWidget>("STATS_DROPDOWN");
statsDropDown.GetText = () => "Basic";
statsDropDown.OnMouseDown = _ =>
{
var options = new List<StatsDropDownOption>
{
new StatsDropDownOption
{
Title = "Basic",
IsSelected = () => basicStatsHeaders.Visible,
OnClick = () =>
{
ClearStats();
statsDropDown.GetText = () => "Basic";
LoadStats(BasicStats);
}
},
new StatsDropDownOption
{
Title = "Economic",
IsSelected = () => economicStatsHeaders.Visible,
OnClick = () =>
{
ClearStats();
statsDropDown.GetText = () => "Economic";
LoadStats(EconomicStats);
}
}
};
Func<StatsDropDownOption, ScrollItemWidget, ScrollItemWidget> setupItem = (option, template) =>
{
var item = ScrollItemWidget.Setup(template, option.IsSelected, option.OnClick);
item.Get<LabelWidget>("LABEL").GetText = () => option.Title;
return item;
};
statsDropDown.ShowDropDown("LABEL_DROPDOWN_TEMPLATE", 100, options, setupItem);
};
widget.Height = (200 + (Math.Min(8, players.Count()) * 25)).ToString(); widget.Height = (200 + (Math.Min(8, players.Count()) * 25)).ToString();
Initialize(widget, widget.Get("BACKGROUND"), widget.Get("PLAYERS_PANEL")); InitializeWidgets(widget, widget.Get("BACKGROUND"), widget.Get("PLAYER_STATS_PANEL"));
ClearStats();
LoadStats(BasicStats);
}
void ClearStats()
{
playerStatsPanel.Children.Clear();
basicStatsHeaders.Visible = false;
economicStatsHeaders.Visible = false;
}
void LoadStats(Action<Player> forEachPlayer)
{
var teams = players.GroupBy(p => (world.LobbyInfo.ClientWithIndex(p.ClientIndex) ?? new Session.Client()).Team).OrderBy(g => g.Key); var teams = players.GroupBy(p => (world.LobbyInfo.ClientWithIndex(p.ClientIndex) ?? new Session.Client()).Team).OrderBy(g => g.Key);
foreach (var t in teams) foreach (var t in teams)
{ {
@@ -47,18 +118,19 @@ namespace OpenRA.Mods.RA.Widgets.Logic
var tt = ScrollItemWidget.Setup(teamTemplate, () => false, () => { }); var tt = ScrollItemWidget.Setup(teamTemplate, () => false, () => { });
tt.IgnoreMouseOver = true; tt.IgnoreMouseOver = true;
tt.Get<LabelWidget>("TEAM").GetText = () => team.Key == 0 ? "No team" : "Team " + team.Key; tt.Get<LabelWidget>("TEAM").GetText = () => team.Key == 0 ? "No team" : "Team " + team.Key;
playersPanel.AddChild(tt); playerStatsPanel.AddChild(tt);
foreach (var p in team) foreach (var p in team)
{ {
var player = p; var player = p;
var template = ScrollItemWidget.Setup(basicPlayerTemplate, () => false, () => forEachPlayer(player);
{
var playerBase = world.Actors.FirstOrDefault(a => !a.IsDead() && a.HasTrait<BaseBuilding>() && a.Owner == player);
if (playerBase != null)
{
Game.MoveViewport(playerBase.Location.ToFloat2());
} }
}); }
}
void EconomicStats(Player player)
{
economicStatsHeaders.Visible = true;
var template = SetupPlayerScrollItemWidget(economicPlayerTemplate, player);
var flag = template.Get<ImageWidget>("FACTION_FLAG"); var flag = template.Get<ImageWidget>("FACTION_FLAG");
flag.GetImageName = () => player.Country.Race; flag.GetImageName = () => player.Country.Race;
@@ -80,6 +152,34 @@ namespace OpenRA.Mods.RA.Widgets.Logic
else return Color.White; else return Color.White;
}; };
var assets = template.Get<LabelWidget>("TOTAL_ASSETS");
assets.GetText = () => "$" + world.Actors
.Where(a => a.Owner == player && !a.IsDead() && a.Info.Traits.WithInterface<ValuedInfo>().Any())
.Sum(a => a.Info.Traits.WithInterface<ValuedInfo>().First().Cost);
var numHarvesters = template.Get<LabelWidget>("NUMBER_HARVESTERS");
numHarvesters.GetText = () => world.Actors.Count(a => a.Owner == player && !a.IsDead() && a.HasTrait<Harvester>()).ToString();
playerStatsPanel.AddChild(template);
}
void BasicStats(Player player)
{
basicStatsHeaders.Visible = true;
var template = SetupPlayerScrollItemWidget(basicPlayerTemplate, player);
var flag = template.Get<ImageWidget>("FACTION_FLAG");
flag.GetImageName = () => player.Country.Race;
flag.GetImageCollection = () => "flags";
var playerName = template.Get<LabelWidget>("PLAYER");
playerName.GetText = () => player.PlayerName + (player.WinState == WinState.Undefined ? "" : " (" + player.WinState + ")");
playerName.GetColor = () => player.ColorRamp.GetColor(0);
var res = player.PlayerActor.Trait<PlayerResources>();
template.Get<LabelWidget>("CASH").GetText = () => "$" + (res.DisplayCash + res.DisplayOre);
template.Get<LabelWidget>("INCOME").GetText = () => "$" + res.IncomePerMin;
var powerRes = player.PlayerActor.Trait<PowerManager>(); var powerRes = player.PlayerActor.Trait<PowerManager>();
var power = template.Get<LabelWidget>("POWER"); var power = template.Get<LabelWidget>("POWER");
power.GetText = () => powerRes.PowerDrained + "/" + powerRes.PowerProvided; power.GetText = () => powerRes.PowerDrained + "/" + powerRes.PowerProvided;
@@ -91,12 +191,22 @@ namespace OpenRA.Mods.RA.Widgets.Logic
var production = template.Get<ObserverBuildIconsWidget>("PRODUCTION_ICONS"); var production = template.Get<ObserverBuildIconsWidget>("PRODUCTION_ICONS");
production.GetPlayer = () => player; production.GetPlayer = () => player;
playersPanel.AddChild(template); playerStatsPanel.AddChild(template);
}
}
} }
static void Initialize(params Widget[] widgets) ScrollItemWidget SetupPlayerScrollItemWidget(ScrollItemWidget template, Player player)
{
return ScrollItemWidget.Setup(template, () => false, () =>
{
var playerBase = world.Actors.FirstOrDefault(a => !a.IsDead() && a.HasTrait<BaseBuilding>() && a.Owner == player);
if (playerBase != null)
{
Game.MoveViewport(playerBase.Location.ToFloat2());
}
});
}
static void InitializeWidgets(params Widget[] widgets)
{ {
var args = new WidgetArgs(); var args = new WidgetArgs();
foreach (var widget in widgets) foreach (var widget in widgets)

View File

@@ -292,7 +292,7 @@ Container@OBSERVER_ROOT:
Y:0 Y:0
Width:160 Width:160
Height:25 Height:25
Text:Players Text:Statistics
Font:Bold Font:Bold
Background@RADAR_BG: Background@RADAR_BG:
X:WINDOW_RIGHT-255 X:WINDOW_RIGHT-255
@@ -411,8 +411,14 @@ Container@OBSERVER_ROOT:
Height:25 Height:25
Font:Bold Font:Bold
Align:Center Align:Center
Text:Players Text:Statistics
Container@BASIC_STATS: DropDownButton@STATS_DROPDOWN:
X:PARENT_RIGHT-140
Y:15
Width:125
Height:25
Font:Bold
Container@BASIC_STATS_HEADERS:
X:0 X:0
Y:0 Y:0
Width:PARENT_RIGHT Width:PARENT_RIGHT
@@ -435,19 +441,19 @@ Container@OBSERVER_ROOT:
Label@INCOME_HEADER: Label@INCOME_HEADER:
X:325 X:325
Y:40 Y:40
Width:160 Width:60
Height:25 Height:25
Font:Bold Font:Bold
Text:Income Text:Income
Label@POWER_HEADER Label@POWER_HEADER
X:445 X:405
Y:40 Y:40
Width:80 Width:80
Height:25 Height:25
Font:Bold Font:Bold
Text:Power Text:Power
Label@KILLS_HEADER: Label@KILLS_HEADER:
X:525 X:485
Y:40 Y:40
Width:40 Width:40
Height:25 Height:25
@@ -455,7 +461,7 @@ Container@OBSERVER_ROOT:
Text:Kills Text:Kills
Align:Right Align:Right
Label@DEATHS_HEADER: Label@DEATHS_HEADER:
X:585 X:545
Y:40 Y:40
Width:40 Width:40
Height:25 Height:25
@@ -463,14 +469,56 @@ Container@OBSERVER_ROOT:
Text:Deaths Text:Deaths
Align:Right Align:Right
Label@PRODUCTION_HEADER Label@PRODUCTION_HEADER
X:625 X:585
Y:40 Y:40
Width:PARENT_RIGHT-625 Width:PARENT_RIGHT-625
Height:25 Height:25
Font:Bold Font:Bold
Text:Production Text:Production
Align:Center Align:Center
ScrollPanel@PLAYERS_PANEL: Container@ECONOMIC_STATS_HEADERS:
X:0
Y:0
Width:PARENT_RIGHT
Height:PARENT_BOTTOM
Children:
Label@PLAYER_HEADER:
X:85
Y:40
Width:160
Height:25
Font:Bold
Text:Player
Label@CASH_HEADER:
X:245
Y:40
Width:80
Height:25
Font:Bold
Text:Cash
Label@INCOME_HEADER:
X:325
Y:40
Width:120
Height:25
Font:Bold
Text:Income
Label@TOTAL_ASSETS_HEADER
X:445
Y:40
Width:60
Height:25
Font:Bold
Text:Assets
Label@NUMBER_HARVESTERS_HEADER
X:525
Y:40
Width:60
Height:25
Font:Bold
Text:Harvesters
Align:Right
ScrollPanel@PLAYER_STATS_PANEL:
X:25 X:25
Y:70 Y:70
Width:PARENT_RIGHT-50 Width:PARENT_RIGHT-50
@@ -518,33 +566,73 @@ Container@OBSERVER_ROOT:
Y:0 Y:0
Width:60 Width:60
Height:PARENT_BOTTOM Height:PARENT_BOTTOM
Label@INCOME_CHANGE
X:355
Y:0
Width:40
Height:PARENT_BOTTOM
Label@POWER: Label@POWER:
X:415 X:375
Y:0 Y:0
Width:80 Width:80
Height:PARENT_BOTTOM Height:PARENT_BOTTOM
Label@KILLS: Label@KILLS:
X:495 X:455
Y:0 Y:0
Width:40 Width:40
Height:PARENT_BOTTOM Height:PARENT_BOTTOM
Align:Right Align:Right
Label@DEATHS: Label@DEATHS:
X:555 X:515
Y:0 Y:0
Width:40 Width:40
Height:PARENT_BOTTOM Height:PARENT_BOTTOM
Align:Right Align:Right
ObserverBuildIcons@PRODUCTION_ICONS: ObserverBuildIcons@PRODUCTION_ICONS:
X:615 X:575
Y:0 Y:0
Width:240 Width:240
Height:PARENT_BOTTOM Height:PARENT_BOTTOM
ScrollItem@ECONOMIC_PLAYER_TEMPLATE:
X:0
Y:0
Width:PARENT_RIGHT-35
Height:25
Children:
Image@FACTION_FLAG:
X:20
Y:5
Width:35
Height:PARENT_BOTTOM-5
ImageName:random
ImageCollection:flags
Label@PLAYER:
X:55
Y:0
Width:160
Height:PARENT_BOTTOM
Font:Bold
Label@CASH:
X:215
Y:0
Width:80
Height:PARENT_BOTTOM
Label@INCOME:
X:295
Y:0
Width:60
Height:PARENT_BOTTOM
Label@INCOME_CHANGE:
X:355
Y:0
Width:60
Height:PARENT_BOTTOM
Label@TOTAL_ASSETS:
X:415
Y:0
Width:60
Height:PARENT_BOTTOM
Label@NUMBER_HARVESTERS:
X:495
Y:0
Width:60
Height:PARENT_BOTTOM
Align:Right
Background@FMVPLAYER: Background@FMVPLAYER:
Width:WINDOW_RIGHT Width:WINDOW_RIGHT
Height:WINDOW_BOTTOM Height:WINDOW_BOTTOM