fixed unit production bug; unit is not emitted until space is clear.

This commit is contained in:
Chris Forbes
2009-11-17 20:17:25 +13:00
parent 7711a0bf01
commit a2de047c9f
4 changed files with 40 additions and 8 deletions

View File

@@ -20,12 +20,14 @@ namespace OpenRa.Game
readonly Sprite moneyBinSprite; readonly Sprite moneyBinSprite;
readonly SpriteRenderer buildPaletteRenderer; readonly SpriteRenderer buildPaletteRenderer;
readonly Animation cantBuild; readonly Animation cantBuild;
readonly Animation ready;
readonly List<Pair<Rectangle, Action<bool>>> buildItems = new List<Pair<Rectangle, Action<bool>>>(); readonly List<Pair<Rectangle, Action<bool>>> buildItems = new List<Pair<Rectangle, Action<bool>>>();
readonly Cache<string, Animation> clockAnimations; readonly Cache<string, Animation> clockAnimations;
readonly List<Sprite> digitSprites; readonly List<Sprite> digitSprites;
readonly Dictionary<string, Sprite[]> tabSprites; readonly Dictionary<string, Sprite[]> tabSprites;
readonly Sprite[] shimSprites; readonly Sprite[] shimSprites;
readonly Sprite blank;
public Chrome(Renderer r) public Chrome(Renderer r)
{ {
@@ -37,6 +39,8 @@ namespace OpenRa.Game
specialBinSprite = new Sprite(specialBin, new Rectangle(0, 0, 32, 192), TextureChannel.Alpha); specialBinSprite = new Sprite(specialBin, new Rectangle(0, 0, 32, 192), TextureChannel.Alpha);
moneyBinSprite = new Sprite(specialBin, new Rectangle(512-320, 0, 320, 64), TextureChannel.Alpha); moneyBinSprite = new Sprite(specialBin, new Rectangle(512-320, 0, 320, 64), TextureChannel.Alpha);
blank = SheetBuilder.Add(new Size(64,48), 16);
sprites = groups sprites = groups
.SelectMany(g => Rules.Categories[g]) .SelectMany(g => Rules.Categories[g])
.Where(u => Rules.UnitInfo[u].TechLevel != -1) .Where(u => Rules.UnitInfo[u].TechLevel != -1)
@@ -71,6 +75,9 @@ namespace OpenRa.Game
new Sprite( specialBin, new Rectangle( 0, 202, 192 +9, 10 ), TextureChannel.Alpha ), new Sprite( specialBin, new Rectangle( 0, 202, 192 +9, 10 ), TextureChannel.Alpha ),
new Sprite( specialBin, new Rectangle( 0, 216, 9, 48 ), TextureChannel.Alpha ), new Sprite( specialBin, new Rectangle( 0, 216, 9, 48 ), TextureChannel.Alpha ),
}; };
ready = new Animation("pips");
ready.PlayRepeating("ready");
} }
public void Draw() public void Draw()
@@ -107,7 +114,8 @@ namespace OpenRa.Game
{ {
var groupName = q.Key; var groupName = q.Key;
if (!Rules.TechTree.BuildableItems(Game.LocalPlayer, q.Key).Any()) continue; if (!Rules.TechTree.BuildableItems(Game.LocalPlayer, q.Key).Any()) continue;
var index = q.Key == currentTab ? 2 : 0; var producing = Game.LocalPlayer.Producing(groupName);
var index = q.Key == currentTab ? 2 : (producing != null && producing.Done) ? 1 : 0;
chromeRenderer.DrawSprite(q.Value[index], new float2(x, y), 0); chromeRenderer.DrawSprite(q.Value[index], new float2(x, y), 0);
buildItems.Add(Pair.New(new Rectangle(x, y, 27, 40), (Action<bool>)(isLmb => currentTab = groupName))); buildItems.Add(Pair.New(new Rectangle(x, y, 27, 40), (Action<bool>)(isLmb => currentTab = groupName)));
@@ -163,6 +171,14 @@ namespace OpenRa.Game
clockAnimations[queueName].Tick(); clockAnimations[queueName].Tick();
buildPaletteRenderer.DrawSprite(clockAnimations[queueName].Image, buildPaletteRenderer.DrawSprite(clockAnimations[queueName].Image,
Game.viewport.Location + new float2(rect.Location), 0); Game.viewport.Location + new float2(rect.Location), 0);
if (currentItem.Done)
{
ready.Play("ready");
buildPaletteRenderer.DrawSprite(ready.Image, Game.viewport.Location
+ new float2(rect.Location)
+ new float2((64 - ready.Image.size.X) / 2, 2), 0);
}
} }
var closureItem = item; var closureItem = item;
@@ -171,12 +187,21 @@ namespace OpenRa.Game
if (++x == 3) { x = 0; y++; } if (++x == 3) { x = 0; y++; }
} }
while( x != 0)
{
var rect = new Rectangle(Game.viewport.Width - (3 - x) * 64, 40 + 48 * y, 64, 48);
buildPaletteRenderer.DrawSprite(blank, Game.viewport.Location + new float2(rect.Location), 0);
buildItems.Add(Pair.New(rect,
(Action<bool>)(_ => { })));
if (++x == 3) { x = 0; y++; }
}
buildPaletteRenderer.Flush(); buildPaletteRenderer.Flush();
for (var j = 0; j <= y; j++) for (var j = 0; j < y; j++)
chromeRenderer.DrawSprite(shimSprites[2], new float2(Game.viewport.Width - 192 - 9, 40 + 48 * j), 0); chromeRenderer.DrawSprite(shimSprites[2], new float2(Game.viewport.Width - 192 - 9, 40 + 48 * j), 0);
chromeRenderer.DrawSprite(shimSprites[0], new float2(Game.viewport.Width - 192 - 9, 40 - 9), 0); chromeRenderer.DrawSprite(shimSprites[0], new float2(Game.viewport.Width - 192 - 9, 40 - 9), 0);
chromeRenderer.DrawSprite(shimSprites[1], new float2(Game.viewport.Width - 192 - 9, 40 - 1 + 48 + 48 * y), 0); chromeRenderer.DrawSprite(shimSprites[1], new float2(Game.viewport.Width - 192 - 9, 40 - 1 + 48 * y), 0);
chromeRenderer.Flush(); chromeRenderer.Flush();
} }

View File

@@ -337,6 +337,10 @@ namespace OpenRa.Game
} }
else else
{ {
var productionPoint = (1 / 24f * producer.CenterLocation).ToInt2();
if (UnitInfluence.GetUnitAt(productionPoint) != null)
return;
unit = new Actor(name, (1 / 24f * producer.CenterLocation).ToInt2(), player); unit = new Actor(name, (1 / 24f * producer.CenterLocation).ToInt2(), player);
var mobile = unit.traits.Get<Mobile>(); var mobile = unit.traits.Get<Mobile>();
mobile.facing = 128; mobile.facing = 128;

View File

@@ -120,7 +120,13 @@ namespace OpenRa.Game
public void Tick( Player player ) public void Tick( Player player )
{ {
if( Paused || Done ) return; if (Done)
{
if (OnComplete != null) OnComplete();
return;
}
if( Paused ) return;
var costThisFrame = RemainingCost / RemainingTime; var costThisFrame = RemainingCost / RemainingTime;
if( costThisFrame != 0 && !player.TakeCash( costThisFrame ) ) return; if( costThisFrame != 0 && !player.TakeCash( costThisFrame ) ) return;
@@ -129,10 +135,7 @@ namespace OpenRa.Game
RemainingTime -= 1; RemainingTime -= 1;
if( RemainingTime > 0 ) return; if( RemainingTime > 0 ) return;
// item finished; do whatever needs done.
Done = true; Done = true;
if (OnComplete != null)
OnComplete();
} }
} }
} }

View File

@@ -110,7 +110,7 @@ namespace OpenRa.Game
if (order.Player == Game.LocalPlayer) if (order.Player == Game.LocalPlayer)
Game.PlaySound(group == "Building" Game.PlaySound(group == "Building"
? "conscmp1.aud" : "unitrdy1.aud", false); ? "conscmp1.aud" : "unitrdy1.aud", false);
if (group != "Building") if (group != "Building" && group != "Defense")
Game.BuildUnit(order.Player, order.TargetString); Game.BuildUnit(order.Player, order.TargetString);
}))); })));
break; break;