Tweak special powers widget: move unnecessary calculations out of Draw(); display the charge time over the icon.

This commit is contained in:
Paul Chote
2011-07-06 20:25:03 +12:00
parent 574133429a
commit ef8ed398ce

View File

@@ -25,7 +25,7 @@ namespace OpenRA.Mods.Cnc.Widgets
Dictionary<string, Sprite> iconSprites; Dictionary<string, Sprite> iconSprites;
Animation clock; Animation clock;
Dictionary<Rectangle, string> Icons = new Dictionary<Rectangle, string>(); Dictionary<Rectangle, SupportPowerIcon> Icons = new Dictionary<Rectangle, SupportPowerIcon>();
public readonly string TooltipContainer; public readonly string TooltipContainer;
public readonly string TooltipTemplate = "SUPPORT_POWER_TOOLTIP"; public readonly string TooltipTemplate = "SUPPORT_POWER_TOOLTIP";
@@ -36,6 +36,8 @@ namespace OpenRA.Mods.Cnc.Widgets
public override Rectangle EventBounds { get { return eventBounds; } } public override Rectangle EventBounds { get { return eventBounds; } }
readonly WorldRenderer worldRenderer; readonly WorldRenderer worldRenderer;
readonly SupportPowerManager spm; readonly SupportPowerManager spm;
readonly SpriteFont overlayFont;
readonly float2 holdOffset, readyOffset, timeOffset;
[ObjectCreator.UseCtor] [ObjectCreator.UseCtor]
public SupportPowersWidget([ObjectCreator.Param] World world, public SupportPowersWidget([ObjectCreator.Param] World world,
@@ -53,19 +55,38 @@ namespace OpenRA.Mods.Cnc.Widgets
u => Game.modData.SpriteLoader.LoadAllSprites(u)[0]); u => Game.modData.SpriteLoader.LoadAllSprites(u)[0]);
clock = new Animation("clock"); clock = new Animation("clock");
overlayFont = Game.Renderer.Fonts["TinyBold"];
holdOffset = new float2(32,24) - overlayFont.Measure("On Hold") / 2;
readyOffset = new float2(32,24) - overlayFont.Measure("Ready") / 2;
timeOffset = new float2(32,24) - overlayFont.Measure(WidgetUtils.FormatTime(0)) / 2;
}
public class SupportPowerIcon
{
public SupportPowerManager.SupportPowerInstance Power;
public float2 Pos;
public Sprite Sprite;
} }
public void RefreshIcons() public void RefreshIcons()
{ {
Icons = new Dictionary<Rectangle, string>(); Icons = new Dictionary<Rectangle, SupportPowerIcon>();
var powers = spm.Powers.Where(p => !p.Value.Disabled).Select(p => p.Key); var powers = spm.Powers.Values.Where(p => !p.Disabled);
var i = 0; var i = 0;
var rb = RenderBounds; var rb = RenderBounds;
foreach (var item in powers) foreach (var p in powers)
{ {
var rect = new Rectangle(rb.X + 1, rb.Y + i * (48 + Spacing) + 1, 64, 48); var rect = new Rectangle(rb.X + 1, rb.Y + i * (48 + Spacing) + 1, 64, 48);
Icons.Add(rect, item); var power = new SupportPowerIcon()
{
Power = p,
Pos = new float2(rect.Location),
Sprite = iconSprites[p.Info.Image]
};
Icons.Add(rect, power);
i++; i++;
} }
@@ -74,49 +95,44 @@ namespace OpenRA.Mods.Cnc.Widgets
public override void Draw() public override void Draw()
{ {
var overlayFont = Game.Renderer.Fonts["TinyBold"];
var holdOffset = new float2(32,24) - overlayFont.Measure("On Hold") / 2;
var readyOffset = new float2(32,24) - overlayFont.Measure("Ready") / 2;
// Background // Background
foreach (var kv in Icons) foreach (var rect in Icons.Keys)
WidgetUtils.DrawPanel("panel-black", kv.Key.InflateBy(1,1,1,1)); WidgetUtils.DrawPanel("panel-black", rect.InflateBy(1,1,1,1));
// Icons // Icons
foreach (var kv in Icons) foreach (var p in Icons.Values)
{ {
var rect = kv.Key; WidgetUtils.DrawSHP(p.Sprite, p.Pos, worldRenderer);
var power = spm.Powers[kv.Value];
var drawPos = new float2(rect.Location);
WidgetUtils.DrawSHP(iconSprites[power.Info.Image], drawPos, worldRenderer);
// Charge progress // Charge progress
clock.PlayFetchIndex("idle", clock.PlayFetchIndex("idle",
() => (power.TotalTime - power.RemainingTime) () => (p.Power.TotalTime - p.Power.RemainingTime)
* (clock.CurrentSequence.Length - 1) / power.TotalTime); * (clock.CurrentSequence.Length - 1) / p.Power.TotalTime);
clock.Tick(); clock.Tick();
WidgetUtils.DrawSHP(clock.Image, drawPos, worldRenderer); WidgetUtils.DrawSHP(clock.Image, p.Pos, worldRenderer);
} }
// Overlays // Overlay
foreach (var kv in Icons) foreach (var p in Icons.Values)
{ {
var power = spm.Powers[kv.Value]; if (p.Power.Ready)
var drawPos = new float2(kv.Key.Location);
if (power.Ready)
overlayFont.DrawTextWithContrast("Ready", overlayFont.DrawTextWithContrast("Ready",
drawPos + readyOffset, p.Pos + readyOffset,
Color.White, Color.Black, 1); Color.White, Color.Black, 1);
else if (!power.Active) else if (!p.Power.Active)
overlayFont.DrawTextWithContrast("On Hold", overlayFont.DrawTextWithContrast("On Hold",
drawPos + holdOffset, p.Pos + holdOffset,
Color.White, Color.Black, 1);
else
overlayFont.DrawTextWithContrast(WidgetUtils.FormatTime(p.Power.RemainingTime),
p.Pos + timeOffset,
Color.White, Color.Black, 1); Color.White, Color.Black, 1);
} }
} }
public override void Tick () public override void Tick()
{ {
// TODO: Only do this when the powers have changed
RefreshIcons(); RefreshIcons();
} }
@@ -136,9 +152,9 @@ namespace OpenRA.Mods.Cnc.Widgets
{ {
if (mi.Event == MouseInputEvent.Move) if (mi.Event == MouseInputEvent.Move)
{ {
var power = Icons.Where(i => i.Key.Contains(mi.Location)) var icon = Icons.Where(i => i.Key.Contains(mi.Location))
.Select(i => i.Value).FirstOrDefault(); .Select(i => i.Value).FirstOrDefault();
TooltipPower = (power != null) ? spm.Powers[power] : null; TooltipPower = (icon != null) ? icon.Power : null;
return false; return false;
} }
@@ -149,7 +165,7 @@ namespace OpenRA.Mods.Cnc.Widgets
.Select(i => i.Value).FirstOrDefault(); .Select(i => i.Value).FirstOrDefault();
if (clicked != null) if (clicked != null)
spm.Target(clicked); spm.Target(clicked.Power.Info.OrderName);
return true; return true;
} }