Hook up tib storage bar

This commit is contained in:
Paul Chote
2011-07-02 06:23:48 +12:00
parent 7e67fdb446
commit e922e8028c
7 changed files with 84 additions and 13 deletions

View File

@@ -91,6 +91,7 @@
<Compile Include="Widgets\Logic\CncIngameMenuLogic.cs" />
<Compile Include="Widgets\Logic\CncConquestObjectivesLogic.cs" />
<Compile Include="Widgets\PowerBarWidget.cs" />
<Compile Include="Widgets\SiloBarWidget.cs" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\OpenRA.FileFormats\OpenRA.FileFormats.csproj">

View File

@@ -51,7 +51,7 @@ namespace OpenRA.Mods.RA.Widgets
providedFrac*b.Height);
Game.Renderer.LineRenderer.FillRect(rect, color);
var indicator = ChromeProvider.GetImage("powerbar-bits", "indicator");
var indicator = ChromeProvider.GetImage("sidebar-bits", "left-indicator");
var drainedFrac = pm.PowerDrained / powerScaleBy;
lastDrainedFrac = drainedFrac = float2.Lerp(lastDrainedFrac.GetValueOrDefault(drainedFrac), drainedFrac, .3f);

View File

@@ -0,0 +1,65 @@
#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.Drawing;
using OpenRA.Graphics;
using OpenRA.Traits;
using OpenRA.Widgets;
namespace OpenRA.Mods.RA.Widgets
{
public class SiloBarWidget : Widget
{
public float LowStorageThreshold = 0.8f;
float? lastCapacityFrac;
float? lastStoredFrac;
readonly PlayerResources pr;
[ObjectCreator.UseCtor]
public SiloBarWidget( [ObjectCreator.Param] World world )
{
pr = world.LocalPlayer.PlayerActor.Trait<PlayerResources>();
}
public override void DrawInner()
{
float scaleBy = 100;
var max = Math.Max(pr.OreCapacity, pr.Ore);
while (max >= scaleBy) scaleBy *= 2;
// Current capacity
var capacityFrac = pr.OreCapacity / scaleBy;
lastCapacityFrac = capacityFrac = float2.Lerp(lastCapacityFrac.GetValueOrDefault(capacityFrac), capacityFrac, .3f);
var color = Color.LimeGreen;
if (pr.Ore >= LowStorageThreshold*pr.OreCapacity)
color = Color.Orange;
if (pr.Ore == pr.OreCapacity)
color = Color.Red;
var b = RenderBounds;
var rect = new RectangleF(Game.viewport.Location.X + b.X,
Game.viewport.Location.Y + b.Y + (1-capacityFrac)*b.Height,
(float)b.Width,
capacityFrac*b.Height);
Game.Renderer.LineRenderer.FillRect(rect, color);
var indicator = ChromeProvider.GetImage("sidebar-bits", "right-indicator");
var storedFrac = pr.Ore / scaleBy;
lastStoredFrac = storedFrac = float2.Lerp(lastStoredFrac.GetValueOrDefault(storedFrac), storedFrac, .3f);
float2 pos = new float2(b.X, b.Y + (1-storedFrac)*b.Height - indicator.size.Y / 2);
Game.Renderer.RgbaSpriteRenderer.DrawSprite(indicator, pos);
}
}
}

View File

@@ -55,8 +55,8 @@
inkscape:pageopacity="0.0"
inkscape:pageshadow="2"
inkscape:zoom="11.313708"
inkscape:cx="324.81809"
inkscape:cy="470.28486"
inkscape:cx="331.88915"
inkscape:cy="473.8204"
inkscape:document-units="px"
inkscape:current-layer="layer1"
showgrid="false"
@@ -105,14 +105,6 @@
inkscape:groupmode="layer"
id="layer1"
transform="translate(0,-540.3622)">
<rect
style="fill:#31312e;fill-opacity:1;stroke:#c8b9ff;stroke-width:0.2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0"
id="rect3946"
width="275.13324"
height="150.9407"
x="244.65895"
y="-22.546127"
transform="translate(0,540.3622)" />
<rect
y="572.86218"
x="352.5"
@@ -782,5 +774,11 @@
height="2"
x="323"
y="583.36224" />
<path
style="fill:#ffffff;fill-opacity:1;stroke:none"
d="m 336,580.3622 -4,4 0,0 4,4 z"
id="path3952"
inkscape:connector-curvature="0"
sodipodi:nodetypes="ccccc" />
</g>
</svg>

Before

Width:  |  Height:  |  Size: 41 KiB

After

Width:  |  Height:  |  Size: 40 KiB

View File

@@ -380,5 +380,6 @@ strategic: strategic.png
enemy_owned: 32,32,32,32
player_owned: 96,0,32,32
powerbar-bits: chrome.png
indicator: 320,40,11,8
sidebar-bits: chrome.png
left-indicator: 320,40,11,8
right-indicator: 325,40,11,8

View File

@@ -155,6 +155,12 @@ Container@INGAME_ROOT:
Width:10
Height:152
Background:panel-black
Children:
SiloBar:
X:1
Y:1
Width:PARENT_RIGHT-2
Height:PARENT_BOTTOM-2
Label@SILOICON:
X:171
Y:170

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

After

Width:  |  Height:  |  Size: 37 KiB