Start implementing graphs for the stats panel
This commit is contained in:
@@ -384,6 +384,7 @@
|
|||||||
<Compile Include="Widgets\Logic\SettingsMenuLogic.cs" />
|
<Compile Include="Widgets\Logic\SettingsMenuLogic.cs" />
|
||||||
<Compile Include="Widgets\MoneyBinWidget.cs" />
|
<Compile Include="Widgets\MoneyBinWidget.cs" />
|
||||||
<Compile Include="Widgets\ObserverProductionIconsWidget.cs" />
|
<Compile Include="Widgets\ObserverProductionIconsWidget.cs" />
|
||||||
|
<Compile Include="Widgets\ObserverStatsGraphWidget.cs" />
|
||||||
<Compile Include="Widgets\ObserverSupportPowerIconsWidget.cs" />
|
<Compile Include="Widgets\ObserverSupportPowerIconsWidget.cs" />
|
||||||
<Compile Include="Widgets\OrderButtonWidget.cs" />
|
<Compile Include="Widgets\OrderButtonWidget.cs" />
|
||||||
<Compile Include="Widgets\PowerBinWidget.cs" />
|
<Compile Include="Widgets\PowerBinWidget.cs" />
|
||||||
|
|||||||
@@ -8,6 +8,7 @@
|
|||||||
*/
|
*/
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using OpenRA.Mods.RA.Buildings;
|
using OpenRA.Mods.RA.Buildings;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
@@ -23,12 +24,26 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
World world;
|
World world;
|
||||||
Player player;
|
Player player;
|
||||||
|
|
||||||
public double MapControl;
|
public double MapControl;
|
||||||
public int OrderCount;
|
public int OrderCount;
|
||||||
|
|
||||||
|
public int EarnedThisMinute
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return player.PlayerActor.Trait<PlayerResources>().Earned - earnedAtBeginningOfMinute;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public Queue<int> EarnedSamples = new Queue<int>(100);
|
||||||
|
int earnedAtBeginningOfMinute;
|
||||||
|
|
||||||
public int KillsCost;
|
public int KillsCost;
|
||||||
public int DeathsCost;
|
public int DeathsCost;
|
||||||
|
|
||||||
public int UnitsKilled;
|
public int UnitsKilled;
|
||||||
public int UnitsDead;
|
public int UnitsDead;
|
||||||
|
|
||||||
public int BuildingsKilled;
|
public int BuildingsKilled;
|
||||||
public int BuildingsDead;
|
public int BuildingsDead;
|
||||||
|
|
||||||
@@ -48,9 +63,23 @@ namespace OpenRA.Mods.RA
|
|||||||
.Count() / total;
|
.Count() / total;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpdateEarnedThisMinute()
|
||||||
|
{
|
||||||
|
EarnedSamples.Enqueue(EarnedThisMinute);
|
||||||
|
earnedAtBeginningOfMinute = player.PlayerActor.Trait<PlayerResources>().Earned;
|
||||||
|
if (EarnedSamples.Count > 100)
|
||||||
|
{
|
||||||
|
EarnedSamples.Dequeue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void Tick(Actor self)
|
public void Tick(Actor self)
|
||||||
{
|
{
|
||||||
if (self.World.FrameNumber % 250 == 1)
|
if (self.World.FrameNumber % 1500 == 0)
|
||||||
|
{
|
||||||
|
UpdateEarnedThisMinute();
|
||||||
|
}
|
||||||
|
if (self.World.FrameNumber % 250 == 0)
|
||||||
{
|
{
|
||||||
UpdateMapControl();
|
UpdateMapControl();
|
||||||
}
|
}
|
||||||
@@ -92,7 +121,7 @@ namespace OpenRA.Mods.RA
|
|||||||
attackerStats.BuildingsKilled++;
|
attackerStats.BuildingsKilled++;
|
||||||
defenderStats.BuildingsDead++;
|
defenderStats.BuildingsDead++;
|
||||||
}
|
}
|
||||||
if (self.HasTrait<IMove>())
|
else if (self.HasTrait<IMove>())
|
||||||
{
|
{
|
||||||
attackerStats.UnitsKilled++;
|
attackerStats.UnitsKilled++;
|
||||||
defenderStats.UnitsDead++;
|
defenderStats.UnitsDead++;
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ using System;
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Drawing;
|
using System.Drawing;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using OpenRA.FileFormats;
|
||||||
using OpenRA.Mods.RA.Buildings;
|
using OpenRA.Mods.RA.Buildings;
|
||||||
using OpenRA.Network;
|
using OpenRA.Network;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
@@ -25,11 +26,13 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
ContainerWidget economicStatsHeaders;
|
ContainerWidget economicStatsHeaders;
|
||||||
ContainerWidget productionStatsHeaders;
|
ContainerWidget productionStatsHeaders;
|
||||||
ContainerWidget combatStatsHeaders;
|
ContainerWidget combatStatsHeaders;
|
||||||
|
ContainerWidget earnedThisMinuteGraphHeaders;
|
||||||
ScrollPanelWidget playerStatsPanel;
|
ScrollPanelWidget playerStatsPanel;
|
||||||
ScrollItemWidget basicPlayerTemplate;
|
ScrollItemWidget basicPlayerTemplate;
|
||||||
ScrollItemWidget economicPlayerTemplate;
|
ScrollItemWidget economicPlayerTemplate;
|
||||||
ScrollItemWidget productionPlayerTemplate;
|
ScrollItemWidget productionPlayerTemplate;
|
||||||
ScrollItemWidget combatPlayerTemplate;
|
ScrollItemWidget combatPlayerTemplate;
|
||||||
|
ContainerWidget earnedThisMinuteGraphTemplate;
|
||||||
ScrollItemWidget teamTemplate;
|
ScrollItemWidget teamTemplate;
|
||||||
DropDownButtonWidget statsDropDown;
|
DropDownButtonWidget statsDropDown;
|
||||||
IEnumerable<Player> players;
|
IEnumerable<Player> players;
|
||||||
@@ -45,6 +48,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
economicStatsHeaders = widget.Get<ContainerWidget>("ECONOMIC_STATS_HEADERS");
|
economicStatsHeaders = widget.Get<ContainerWidget>("ECONOMIC_STATS_HEADERS");
|
||||||
productionStatsHeaders = widget.Get<ContainerWidget>("PRODUCTION_STATS_HEADERS");
|
productionStatsHeaders = widget.Get<ContainerWidget>("PRODUCTION_STATS_HEADERS");
|
||||||
combatStatsHeaders = widget.Get<ContainerWidget>("COMBAT_STATS_HEADERS");
|
combatStatsHeaders = widget.Get<ContainerWidget>("COMBAT_STATS_HEADERS");
|
||||||
|
earnedThisMinuteGraphHeaders = widget.Get<ContainerWidget>("EARNED_THIS_MIN_GRAPH_HEADERS");
|
||||||
|
|
||||||
playerStatsPanel = widget.Get<ScrollPanelWidget>("PLAYER_STATS_PANEL");
|
playerStatsPanel = widget.Get<ScrollPanelWidget>("PLAYER_STATS_PANEL");
|
||||||
playerStatsPanel.Layout = new GridLayout(playerStatsPanel);
|
playerStatsPanel.Layout = new GridLayout(playerStatsPanel);
|
||||||
@@ -53,6 +57,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
economicPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("ECONOMIC_PLAYER_TEMPLATE");
|
economicPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("ECONOMIC_PLAYER_TEMPLATE");
|
||||||
productionPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("PRODUCTION_PLAYER_TEMPLATE");
|
productionPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("PRODUCTION_PLAYER_TEMPLATE");
|
||||||
combatPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("COMBAT_PLAYER_TEMPLATE");
|
combatPlayerTemplate = playerStatsPanel.Get<ScrollItemWidget>("COMBAT_PLAYER_TEMPLATE");
|
||||||
|
earnedThisMinuteGraphTemplate = playerStatsPanel.Get<ContainerWidget>("EARNED_THIS_MIN_GRAPH_TEMPLATE");
|
||||||
|
|
||||||
teamTemplate = playerStatsPanel.Get<ScrollItemWidget>("TEAM_TEMPLATE");
|
teamTemplate = playerStatsPanel.Get<ScrollItemWidget>("TEAM_TEMPLATE");
|
||||||
|
|
||||||
@@ -105,6 +110,17 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
statsDropDown.GetText = () => "Combat";
|
statsDropDown.GetText = () => "Combat";
|
||||||
DisplayStats(CombatStats);
|
DisplayStats(CombatStats);
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
new StatsDropDownOption
|
||||||
|
{
|
||||||
|
Title = "Earnings (graph)",
|
||||||
|
IsSelected = () => earnedThisMinuteGraphHeaders.Visible,
|
||||||
|
OnClick = () =>
|
||||||
|
{
|
||||||
|
ClearStats();
|
||||||
|
statsDropDown.GetText = () => "Earnings (graph)";
|
||||||
|
EarnedThisMinuteGraph();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
Func<StatsDropDownOption, ScrollItemWidget, ScrollItemWidget> setupItem = (option, template) =>
|
Func<StatsDropDownOption, ScrollItemWidget, ScrollItemWidget> setupItem = (option, template) =>
|
||||||
@@ -116,9 +132,6 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
statsDropDown.ShowDropDown("LABEL_DROPDOWN_TEMPLATE", 150, options, setupItem);
|
statsDropDown.ShowDropDown("LABEL_DROPDOWN_TEMPLATE", 150, options, setupItem);
|
||||||
};
|
};
|
||||||
|
|
||||||
widget.Height = (200 + (Math.Min(8, players.Count()) * 25)).ToString();
|
|
||||||
InitializeWidgets(widget, widget.Get("BACKGROUND"), widget.Get("PLAYER_STATS_PANEL"));
|
|
||||||
|
|
||||||
ClearStats();
|
ClearStats();
|
||||||
DisplayStats(BasicStats);
|
DisplayStats(BasicStats);
|
||||||
}
|
}
|
||||||
@@ -130,9 +143,23 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
economicStatsHeaders.Visible = false;
|
economicStatsHeaders.Visible = false;
|
||||||
productionStatsHeaders.Visible = false;
|
productionStatsHeaders.Visible = false;
|
||||||
combatStatsHeaders.Visible = false;
|
combatStatsHeaders.Visible = false;
|
||||||
|
earnedThisMinuteGraphHeaders.Visible = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DisplayStats(Func<Player, ScrollItemWidget> forEachPlayer)
|
void EarnedThisMinuteGraph()
|
||||||
|
{
|
||||||
|
earnedThisMinuteGraphHeaders.Visible = true;
|
||||||
|
var template = earnedThisMinuteGraphTemplate.Clone();
|
||||||
|
|
||||||
|
var graph = template.Get<ObserverStatsGraphWidget>("EARNED_THIS_MIN_GRAPH");
|
||||||
|
graph.GetDataSource = () => players.Select(p => Pair.New(p, p.PlayerActor.Trait<PlayerStatistics>().EarnedSamples.Select(s => (float)s)));
|
||||||
|
graph.GetDataScale = () => 1 / 100f;
|
||||||
|
graph.GetLastValueFormat = () => "${0}";
|
||||||
|
|
||||||
|
playerStatsPanel.AddChild(template);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DisplayStats(Func<Player, ScrollItemWidget> createItem)
|
||||||
{
|
{
|
||||||
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)
|
||||||
@@ -145,7 +172,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
foreach (var p in team)
|
foreach (var p in team)
|
||||||
{
|
{
|
||||||
var player = p;
|
var player = p;
|
||||||
playerStatsPanel.AddChild(forEachPlayer(player));
|
playerStatsPanel.AddChild(createItem(player));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -190,9 +217,11 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
AddPlayerFlagAndName(template, player);
|
AddPlayerFlagAndName(template, player);
|
||||||
|
|
||||||
var res = player.PlayerActor.Trait<PlayerResources>();
|
var res = player.PlayerActor.Trait<PlayerResources>();
|
||||||
|
var stats = player.PlayerActor.Trait<PlayerStatistics>();
|
||||||
|
|
||||||
template.Get<LabelWidget>("CASH").GetText = () => "$" + (res.DisplayCash + res.DisplayOre);
|
template.Get<LabelWidget>("CASH").GetText = () => "$" + (res.DisplayCash + res.DisplayOre);
|
||||||
template.Get<LabelWidget>("EARNED_MIN").GetText = () => EarnedPerMinute(res.Earned);
|
template.Get<LabelWidget>("EARNED_MIN").GetText = () => AverageEarnedPerMinute(res.Earned);
|
||||||
|
template.Get<LabelWidget>("EARNED_THIS_MIN").GetText = () => "$" + stats.EarnedThisMinute;
|
||||||
template.Get<LabelWidget>("EARNED").GetText = () => "$" + res.Earned;
|
template.Get<LabelWidget>("EARNED").GetText = () => "$" + res.Earned;
|
||||||
template.Get<LabelWidget>("SPENT").GetText = () => "$" + res.Spent;
|
template.Get<LabelWidget>("SPENT").GetText = () => "$" + res.Spent;
|
||||||
|
|
||||||
@@ -216,7 +245,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
|
|
||||||
var res = player.PlayerActor.Trait<PlayerResources>();
|
var res = player.PlayerActor.Trait<PlayerResources>();
|
||||||
template.Get<LabelWidget>("CASH").GetText = () => "$" + (res.DisplayCash + res.DisplayOre);
|
template.Get<LabelWidget>("CASH").GetText = () => "$" + (res.DisplayCash + res.DisplayOre);
|
||||||
template.Get<LabelWidget>("EARNED_MIN").GetText = () => EarnedPerMinute(res.Earned);
|
template.Get<LabelWidget>("EARNED_MIN").GetText = () => AverageEarnedPerMinute(res.Earned);
|
||||||
|
|
||||||
var powerRes = player.PlayerActor.Trait<PowerManager>();
|
var powerRes = player.PlayerActor.Trait<PowerManager>();
|
||||||
var power = template.Get<LabelWidget>("POWER");
|
var power = template.Get<LabelWidget>("POWER");
|
||||||
@@ -227,7 +256,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
template.Get<LabelWidget>("DEATHS").GetText = () => player.Deaths.ToString();
|
template.Get<LabelWidget>("DEATHS").GetText = () => player.Deaths.ToString();
|
||||||
|
|
||||||
var stats = player.PlayerActor.Trait<PlayerStatistics>();
|
var stats = player.PlayerActor.Trait<PlayerStatistics>();
|
||||||
template.Get<LabelWidget>("ACTIONS_MIN").GetText = () => OrdersPerMinute(stats.OrderCount);
|
template.Get<LabelWidget>("ACTIONS_MIN").GetText = () => AverageOrdersPerMinute(stats.OrderCount);
|
||||||
|
|
||||||
return template;
|
return template;
|
||||||
}
|
}
|
||||||
@@ -249,12 +278,12 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
return (control * 100).ToString("F1") + "%";
|
return (control * 100).ToString("F1") + "%";
|
||||||
}
|
}
|
||||||
|
|
||||||
string OrdersPerMinute(double orders)
|
string AverageOrdersPerMinute(double orders)
|
||||||
{
|
{
|
||||||
return (world.FrameNumber == 0 ? 0 : orders / (world.FrameNumber / 1500.0)).ToString("F1");
|
return (world.FrameNumber == 0 ? 0 : orders / (world.FrameNumber / 1500.0)).ToString("F1");
|
||||||
}
|
}
|
||||||
|
|
||||||
string EarnedPerMinute(double earned)
|
string AverageEarnedPerMinute(double earned)
|
||||||
{
|
{
|
||||||
return "$" + (world.FrameNumber == 0 ? 0 : earned / (world.FrameNumber / 1500.0)).ToString("F2");
|
return "$" + (world.FrameNumber == 0 ? 0 : earned / (world.FrameNumber / 1500.0)).ToString("F2");
|
||||||
}
|
}
|
||||||
@@ -270,15 +299,6 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
playerName.GetColor = () => player.ColorRamp.GetColor(0);
|
playerName.GetColor = () => player.ColorRamp.GetColor(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void InitializeWidgets(params Widget[] widgets)
|
|
||||||
{
|
|
||||||
var args = new WidgetArgs();
|
|
||||||
foreach (var widget in widgets)
|
|
||||||
{
|
|
||||||
widget.Initialize(args);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static Color GetPowerColor(PowerState state)
|
static Color GetPowerColor(PowerState state)
|
||||||
{
|
{
|
||||||
if (state == PowerState.Critical) return Color.Red;
|
if (state == PowerState.Critical) return Color.Red;
|
||||||
|
|||||||
@@ -10,10 +10,10 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Drawing;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using OpenRA.Graphics;
|
using OpenRA.Graphics;
|
||||||
using OpenRA.Widgets;
|
using OpenRA.Widgets;
|
||||||
using System.Drawing;
|
|
||||||
|
|
||||||
namespace OpenRA.Mods.RA.Widgets
|
namespace OpenRA.Mods.RA.Widgets
|
||||||
{
|
{
|
||||||
|
|||||||
91
OpenRA.Mods.RA/Widgets/ObserverStatsGraphWidget.cs
Normal file
91
OpenRA.Mods.RA/Widgets/ObserverStatsGraphWidget.cs
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
#region Copyright & License Information
|
||||||
|
/*
|
||||||
|
* Copyright 2007-2011 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 System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Drawing;
|
||||||
|
using System.Linq;
|
||||||
|
using OpenRA.FileFormats;
|
||||||
|
|
||||||
|
namespace OpenRA.Widgets
|
||||||
|
{
|
||||||
|
public class ObserverStatsGraphWidget : Widget
|
||||||
|
{
|
||||||
|
public Func<IEnumerable<Pair<Player, IEnumerable<float>>>> GetDataSource = () => null;
|
||||||
|
public Func<float> GetDataScale = () => 1.0f;
|
||||||
|
public Func<string> GetLastValueFormat = () => "{0}";
|
||||||
|
public Func<int> GetNodeCount = () => 20;
|
||||||
|
public Func<int> GetNodeStep = () => 5;
|
||||||
|
|
||||||
|
public ObserverStatsGraphWidget() : base() { }
|
||||||
|
|
||||||
|
protected ObserverStatsGraphWidget(ObserverStatsGraphWidget other)
|
||||||
|
: base(other)
|
||||||
|
{
|
||||||
|
GetDataSource = other.GetDataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Draw()
|
||||||
|
{
|
||||||
|
var rect = RenderBounds;
|
||||||
|
var origin = new float2(rect.Left, rect.Bottom);
|
||||||
|
var basis = new float2(rect.Width / 100, rect.Height / 100);
|
||||||
|
|
||||||
|
Game.Renderer.LineRenderer.DrawLine(origin, origin + new float2(100, 0) * basis, Color.White, Color.White);
|
||||||
|
Game.Renderer.LineRenderer.DrawLine(origin, origin - new float2(0, 100) * basis, Color.White, Color.White);
|
||||||
|
Game.Renderer.LineRenderer.DrawLine(origin + new float2(100, 0) * basis, origin + new float2(100, -100) * basis, Color.White, Color.White);
|
||||||
|
|
||||||
|
var tinyBold = Game.Renderer.Fonts["TinyBold"];
|
||||||
|
|
||||||
|
var i = 0;
|
||||||
|
foreach (var pair in GetDataSource())
|
||||||
|
{
|
||||||
|
var player = pair.First;
|
||||||
|
var data = pair.Second.Reverse().Take(GetNodeCount()).Reverse();
|
||||||
|
var color = player.ColorRamp.GetColor(0);
|
||||||
|
if (data.Any())
|
||||||
|
{
|
||||||
|
var scale = GetDataScale();
|
||||||
|
var scaledData = data.Select(d => d * scale);
|
||||||
|
var n = 0;
|
||||||
|
var step = GetNodeStep();
|
||||||
|
scaledData.Aggregate((a, b) =>
|
||||||
|
{
|
||||||
|
Game.Renderer.LineRenderer.DrawLine(
|
||||||
|
origin + new float2(n, -a) * basis,
|
||||||
|
origin + new float2(n + step, -b) * basis,
|
||||||
|
color, color);
|
||||||
|
n += step;
|
||||||
|
return b;
|
||||||
|
});
|
||||||
|
|
||||||
|
var lastValue = data.Last();
|
||||||
|
if (lastValue != 0)
|
||||||
|
{
|
||||||
|
var scaledLastValue = lastValue * scale;
|
||||||
|
var lastValueFormat = GetLastValueFormat();
|
||||||
|
if (lastValueFormat != null)
|
||||||
|
{
|
||||||
|
tinyBold.DrawText(lastValueFormat.F(lastValue), origin + new float2(n, -scaledLastValue - 2) * basis, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tinyBold.DrawText(player.PlayerName, new float2(rect.Left, rect.Top) + new float2(5, 10 * i - 3), color);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override Widget Clone()
|
||||||
|
{
|
||||||
|
return new ObserverStatsGraphWidget(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -10,10 +10,10 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Drawing;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using OpenRA.Graphics;
|
using OpenRA.Graphics;
|
||||||
using OpenRA.Widgets;
|
using OpenRA.Widgets;
|
||||||
using System.Drawing;
|
|
||||||
|
|
||||||
namespace OpenRA.Mods.RA.Widgets
|
namespace OpenRA.Mods.RA.Widgets
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -396,7 +396,7 @@ Container@OBSERVER_ROOT:
|
|||||||
X:25
|
X:25
|
||||||
Y:50
|
Y:50
|
||||||
Width:950
|
Width:950
|
||||||
Height:400
|
Height:500
|
||||||
Visible:false
|
Visible:false
|
||||||
Children:
|
Children:
|
||||||
Background@BACKGROUND:
|
Background@BACKGROUND:
|
||||||
@@ -413,9 +413,9 @@ Container@OBSERVER_ROOT:
|
|||||||
Align:Center
|
Align:Center
|
||||||
Text:Statistics
|
Text:Statistics
|
||||||
DropDownButton@STATS_DROPDOWN:
|
DropDownButton@STATS_DROPDOWN:
|
||||||
X:PARENT_RIGHT-140
|
X:PARENT_RIGHT-200
|
||||||
Y:15
|
Y:15
|
||||||
Width:125
|
Width:185
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Container@BASIC_STATS_HEADERS:
|
Container@BASIC_STATS_HEADERS:
|
||||||
@@ -503,29 +503,36 @@ Container@OBSERVER_ROOT:
|
|||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Earned/min
|
Text:Earned/min
|
||||||
Label@ASSETS_HEADER:
|
Label@EARNED_THIS_MIN_HEADER:
|
||||||
X:425
|
X:425
|
||||||
Y:40
|
Y:40
|
||||||
Width:60
|
Width:60
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
|
Text:Earned this min
|
||||||
|
Label@ASSETS_HEADER:
|
||||||
|
X:565
|
||||||
|
Y:40
|
||||||
|
Width:60
|
||||||
|
Height:25
|
||||||
|
Font:Bold
|
||||||
Text:Assets
|
Text:Assets
|
||||||
Label@EARNED_HEADER:
|
Label@EARNED_HEADER:
|
||||||
X:505
|
X:645
|
||||||
Y:40
|
Y:40
|
||||||
Width:60
|
Width:60
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Earned
|
Text:Earned
|
||||||
Label@SPENT_HEADER:
|
Label@SPENT_HEADER:
|
||||||
X:585
|
X:725
|
||||||
Y:40
|
Y:40
|
||||||
Width:60
|
Width:60
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Spent
|
Text:Spent
|
||||||
Label@HARVESTERS_HEADER:
|
Label@HARVESTERS_HEADER:
|
||||||
X:665
|
X:805
|
||||||
Y:40
|
Y:40
|
||||||
Width:60
|
Width:60
|
||||||
Height:25
|
Height:25
|
||||||
@@ -607,7 +614,7 @@ Container@OBSERVER_ROOT:
|
|||||||
Width:40
|
Width:40
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Units Dead
|
Text:Units Lost
|
||||||
Align:Right
|
Align:Right
|
||||||
Label@BUILDINGS_KILLED_HEADER:
|
Label@BUILDINGS_KILLED_HEADER:
|
||||||
X:725
|
X:725
|
||||||
@@ -615,7 +622,7 @@ Container@OBSERVER_ROOT:
|
|||||||
Width:40
|
Width:40
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Bld Destroyed
|
Text:Bldg Killed
|
||||||
Align:Right
|
Align:Right
|
||||||
Label@BUILDINGS_DEAD_HEADER:
|
Label@BUILDINGS_DEAD_HEADER:
|
||||||
X:825
|
X:825
|
||||||
@@ -623,8 +630,22 @@ Container@OBSERVER_ROOT:
|
|||||||
Width:40
|
Width:40
|
||||||
Height:25
|
Height:25
|
||||||
Font:Bold
|
Font:Bold
|
||||||
Text:Bld Lost
|
Text:Bldg Lost
|
||||||
Align:Right
|
Align:Right
|
||||||
|
Container@EARNED_THIS_MIN_GRAPH_HEADERS:
|
||||||
|
X:0
|
||||||
|
Y:0
|
||||||
|
Width:PARENT_RIGHT
|
||||||
|
Height:PARENT_BOTTOM
|
||||||
|
Children:
|
||||||
|
Label@EARNED_THIS_MIN_HEADER:
|
||||||
|
X:0
|
||||||
|
Y:40
|
||||||
|
Width:PARENT_RIGHT
|
||||||
|
Height:25
|
||||||
|
Font:Bold
|
||||||
|
Text:Earnings received each minute
|
||||||
|
Align:Center
|
||||||
ScrollPanel@PLAYER_STATS_PANEL:
|
ScrollPanel@PLAYER_STATS_PANEL:
|
||||||
X:25
|
X:25
|
||||||
Y:70
|
Y:70
|
||||||
@@ -725,23 +746,28 @@ Container@OBSERVER_ROOT:
|
|||||||
Y:0
|
Y:0
|
||||||
Width:60
|
Width:60
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
Label@ASSETS:
|
Label@EARNED_THIS_MIN:
|
||||||
X:395
|
X:395
|
||||||
Y:0
|
Y:0
|
||||||
Width:60
|
Width:60
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
|
Label@ASSETS:
|
||||||
|
X:535
|
||||||
|
Y:0
|
||||||
|
Width:60
|
||||||
|
Height:PARENT_BOTTOM
|
||||||
Label@EARNED:
|
Label@EARNED:
|
||||||
X:475
|
X:615
|
||||||
Y:0
|
Y:0
|
||||||
Width:60
|
Width:60
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
Label@SPENT:
|
Label@SPENT:
|
||||||
X:555
|
X:695
|
||||||
Y:0
|
Y:0
|
||||||
Width:60
|
Width:60
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
Label@HARVESTERS:
|
Label@HARVESTERS:
|
||||||
X:635
|
X:775
|
||||||
Y:0
|
Y:0
|
||||||
Width:60
|
Width:60
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
@@ -833,6 +859,17 @@ Container@OBSERVER_ROOT:
|
|||||||
Width:40
|
Width:40
|
||||||
Height:PARENT_BOTTOM
|
Height:PARENT_BOTTOM
|
||||||
Align:Right
|
Align:Right
|
||||||
|
Container@EARNED_THIS_MIN_GRAPH_TEMPLATE:
|
||||||
|
X:0
|
||||||
|
Y:0
|
||||||
|
Width:PARENT_RIGHT-35
|
||||||
|
Height:300
|
||||||
|
Children:
|
||||||
|
ObserverStatsGraph@EARNED_THIS_MIN_GRAPH:
|
||||||
|
X:0
|
||||||
|
Y:0
|
||||||
|
Width:800
|
||||||
|
Height:PARENT_BOTTOM
|
||||||
Background@FMVPLAYER:
|
Background@FMVPLAYER:
|
||||||
Width:WINDOW_RIGHT
|
Width:WINDOW_RIGHT
|
||||||
Height:WINDOW_BOTTOM
|
Height:WINDOW_BOTTOM
|
||||||
|
|||||||
Reference in New Issue
Block a user