Tweak special powers widget: move unnecessary calculations out of Draw(); display the charge time over the icon.
This commit is contained in:
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user