Cache PaletteReference in RenderSimple.

This commit is contained in:
Paul Chote
2013-02-25 21:57:47 +13:00
parent dddec1ec61
commit 3a11aeb434
3 changed files with 28 additions and 11 deletions

View File

@@ -33,7 +33,7 @@ namespace OpenRA.Traits
} }
} }
public class RenderSimple : IRender, IAutoSelectionSize, ITick public class RenderSimple : IRender, IAutoSelectionSize, ITick, INotifyOwnerChanged
{ {
public Dictionary<string, AnimationWithOffset> anims = new Dictionary<string, AnimationWithOffset>(); public Dictionary<string, AnimationWithOffset> anims = new Dictionary<string, AnimationWithOffset>();
@@ -56,7 +56,6 @@ namespace OpenRA.Traits
return Info.Image ?? actor.Name; return Info.Image ?? actor.Name;
} }
string cachedImage = null;
public string GetImage(Actor self) public string GetImage(Actor self)
{ {
if (cachedImage != null) if (cachedImage != null)
@@ -66,6 +65,9 @@ namespace OpenRA.Traits
} }
RenderSimpleInfo Info; RenderSimpleInfo Info;
string cachedImage = null;
bool initializePalette = true;
protected PaletteReference palette;
public RenderSimple(Actor self, Func<int> baseFacing) public RenderSimple(Actor self, Func<int> baseFacing)
{ {
@@ -78,17 +80,26 @@ namespace OpenRA.Traits
anim.PlayRepeating("idle"); anim.PlayRepeating("idle");
} }
protected PaletteReference Palette(Player p, WorldRenderer wr) protected virtual string PaletteName(Actor self)
{ {
return wr.Palette(Info.Palette ?? Info.PlayerPalette + p.InternalName); return Info.Palette ?? Info.PlayerPalette + self.Owner.InternalName;
} }
protected void UpdatePalette() { initializePalette = true; }
public void OnOwnerChanged(Actor self, Player oldOwner, Player newOwner) { UpdatePalette(); }
public virtual IEnumerable<Renderable> Render(Actor self, WorldRenderer wr) public virtual IEnumerable<Renderable> Render(Actor self, WorldRenderer wr)
{ {
if (initializePalette)
{
palette = wr.Palette(PaletteName(self));
initializePalette = false;
}
foreach (var a in anims.Values) foreach (var a in anims.Values)
if (a.DisableFunc == null || !a.DisableFunc()) if (a.DisableFunc == null || !a.DisableFunc())
{ {
Renderable ret = a.Image(self, Palette(self.Owner, wr)); Renderable ret = a.Image(self, palette);
if (Info.Scale != 1f) if (Info.Scale != 1f)
ret = ret.WithScale(Info.Scale).WithPos(ret.Pos + 0.5f * ret.Sprite.size * (1 - Info.Scale)); ret = ret.WithScale(Info.Scale).WithPos(ret.Pos + 0.5f * ret.Sprite.size * (1 - Info.Scale));
yield return ret; yield return ret;

View File

@@ -496,19 +496,21 @@ namespace OpenRA.Mods.RA.Missions
public override object Create(ActorInitializer init) { return new Allies04RenderHijacked(init.self, this); } public override object Create(ActorInitializer init) { return new Allies04RenderHijacked(init.self, this); }
} }
class Allies04RenderHijacked : RenderUnit, IRenderModifier class Allies04RenderHijacked : RenderUnit
{ {
Allies04Hijackable hijackable; Allies04Hijackable hijackable;
Allies04RenderHijackedInfo info;
public Allies04RenderHijacked(Actor self, Allies04RenderHijackedInfo info) public Allies04RenderHijacked(Actor self, Allies04RenderHijackedInfo info)
: base(self) : base(self)
{ {
this.info = info;
hijackable = self.Trait<Allies04Hijackable>(); hijackable = self.Trait<Allies04Hijackable>();
} }
public IEnumerable<Renderable> ModifyRender(Actor self, WorldRenderer wr, IEnumerable<Renderable> r) protected override string PaletteName(Actor self)
{ {
return r.Select(a => a.WithPalette(Palette(hijackable.OldOwner, wr))); return info.Palette ?? info.PlayerPalette + hijackable.OldOwner.InternalName;
} }
} }

View File

@@ -21,20 +21,23 @@ namespace OpenRA.Mods.RA.Render
public override object Create(ActorInitializer init) { return new RenderSpy(init.self, this); } public override object Create(ActorInitializer init) { return new RenderSpy(init.self, this); }
} }
class RenderSpy : RenderInfantryProne, IRenderModifier class RenderSpy : RenderInfantryProne
{ {
RenderSpyInfo info;
string disguisedAsSprite; string disguisedAsSprite;
Spy spy; Spy spy;
public RenderSpy(Actor self, RenderSpyInfo info) : base(self, info) public RenderSpy(Actor self, RenderSpyInfo info) : base(self, info)
{ {
this.info = info;
spy = self.Trait<Spy>(); spy = self.Trait<Spy>();
disguisedAsSprite = spy.disguisedAsSprite; disguisedAsSprite = spy.disguisedAsSprite;
} }
public IEnumerable<Renderable> ModifyRender(Actor self, WorldRenderer wr, IEnumerable<Renderable> r) protected override string PaletteName(Actor self)
{ {
return spy.disguisedAsPlayer != null ? r.Select(a => a.WithPalette(Palette(spy.disguisedAsPlayer, wr))) : r; var player = spy.disguisedAsPlayer != null ? spy.disguisedAsPlayer : self.Owner;
return info.Palette ?? info.PlayerPalette + player.InternalName;
} }
public override void Tick(Actor self) public override void Tick(Actor self)
@@ -46,6 +49,7 @@ namespace OpenRA.Mods.RA.Render
anim.ChangeImage(disguisedAsSprite, "stand"); anim.ChangeImage(disguisedAsSprite, "stand");
else else
anim.ChangeImage(GetImage(self), "stand"); anim.ChangeImage(GetImage(self), "stand");
UpdatePalette();
} }
base.Tick(self); base.Tick(self);
} }