Scale is now set via a field on Render* and interacts properly with chronoshift and building previews.
This commit is contained in:
@@ -91,17 +91,10 @@ namespace OpenRA
|
|||||||
|
|
||||||
public RectangleF GetBounds(bool useAltitude)
|
public RectangleF GetBounds(bool useAltitude)
|
||||||
{
|
{
|
||||||
var si = Info.Traits.GetOrDefault<SelectableInfo>();
|
var size = Size.Value;
|
||||||
|
var loc = CenterLocation - 0.5f * size;
|
||||||
var size = Size.Value;
|
|
||||||
|
|
||||||
/* apply scaling */
|
|
||||||
var scale = this.TraitOrDefault<Scale>();
|
|
||||||
if (scale != null && scale.Info.Value != 1)
|
|
||||||
size = size*scale.Info.Value;
|
|
||||||
|
|
||||||
var loc = CenterLocation - 0.5f * size;
|
|
||||||
|
|
||||||
|
var si = Info.Traits.GetOrDefault<SelectableInfo>();
|
||||||
if (si != null && si.Bounds != null && si.Bounds.Length > 2)
|
if (si != null && si.Bounds != null && si.Bounds.Length > 2)
|
||||||
loc += new float2(si.Bounds[2], si.Bounds[3]);
|
loc += new float2(si.Bounds[2], si.Bounds[3]);
|
||||||
|
|
||||||
|
|||||||
@@ -199,7 +199,6 @@
|
|||||||
<Compile Include="Network\SyncReport.cs" />
|
<Compile Include="Network\SyncReport.cs" />
|
||||||
<Compile Include="Traits\EditorAppearance.cs" />
|
<Compile Include="Traits\EditorAppearance.cs" />
|
||||||
<Compile Include="Traits\ValidateOrder.cs" />
|
<Compile Include="Traits\ValidateOrder.cs" />
|
||||||
<Compile Include="Traits\Scale.cs" />
|
|
||||||
<Compile Include="TraitDictionary.cs" />
|
<Compile Include="TraitDictionary.cs" />
|
||||||
<Compile Include="Traits\Activities\CancelableActivity.cs" />
|
<Compile Include="Traits\Activities\CancelableActivity.cs" />
|
||||||
<Compile Include="Traits\SharesCell.cs" />
|
<Compile Include="Traits\SharesCell.cs" />
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ namespace OpenRA.Traits
|
|||||||
public readonly string[] OverrideTileset = null;
|
public readonly string[] OverrideTileset = null;
|
||||||
public readonly string[] OverrideImage = null;
|
public readonly string[] OverrideImage = null;
|
||||||
public readonly string Palette = null;
|
public readonly string Palette = null;
|
||||||
|
public readonly float Scale = 1f;
|
||||||
public abstract object Create(ActorInitializer init);
|
public abstract object Create(ActorInitializer init);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -48,17 +49,24 @@ namespace OpenRA.Traits
|
|||||||
return cachedImage = GetImage(self.Info, self.World.Map.Tileset);
|
return cachedImage = GetImage(self.Info, self.World.Map.Tileset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RenderSimpleInfo Info;
|
||||||
public RenderSimple(Actor self, Func<int> baseFacing)
|
public RenderSimple(Actor self, Func<int> baseFacing)
|
||||||
{
|
{
|
||||||
anims.Add( "", new Animation( GetImage(self), baseFacing ) );
|
anims.Add( "", new Animation( GetImage(self), baseFacing ) );
|
||||||
|
Info = self.Info.Traits.Get<RenderSimpleInfo>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual IEnumerable<Renderable> Render( Actor self )
|
public virtual IEnumerable<Renderable> Render( Actor self )
|
||||||
{
|
{
|
||||||
var palette = self.Info.Traits.Get<RenderSimpleInfo>().Palette;
|
|
||||||
foreach( var a in anims.Values )
|
foreach( var a in anims.Values )
|
||||||
if( a.DisableFunc == null || !a.DisableFunc() )
|
if( a.DisableFunc == null || !a.DisableFunc() )
|
||||||
yield return ( palette == null ) ? a.Image( self ) : a.Image( self ).WithPalette(palette);
|
{
|
||||||
|
Renderable ret = a.Image( self );
|
||||||
|
if (Info.Scale != 1f)
|
||||||
|
ret = ret.WithScale(Info.Scale).WithPos(ret.Pos + 0.5f*ret.Sprite.size*(1 - Info.Scale));
|
||||||
|
yield return ( Info.Palette == null ) ? ret : ret.WithPalette(Info.Palette);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual void Tick(Actor self)
|
public virtual void Tick(Actor self)
|
||||||
|
|||||||
@@ -1,40 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
|
|
||||||
namespace OpenRA.Traits
|
|
||||||
{
|
|
||||||
public class ScaleInfo : ITraitInfo
|
|
||||||
{
|
|
||||||
public readonly float Value = 1f; /* default */
|
|
||||||
|
|
||||||
public ScaleInfo() { } /* only because we have other ctors */
|
|
||||||
|
|
||||||
public object Create(ActorInitializer init) { return new Scale(this); }
|
|
||||||
}
|
|
||||||
|
|
||||||
public class Scale : IRenderModifier
|
|
||||||
{
|
|
||||||
public ScaleInfo Info { get; protected set; }
|
|
||||||
|
|
||||||
public Scale(ScaleInfo info)
|
|
||||||
{
|
|
||||||
this.Info = info;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerable<Renderable> ModifyRender(Actor self, IEnumerable<Renderable> r)
|
|
||||||
{
|
|
||||||
var r2 = new List<Renderable>(r);
|
|
||||||
var r3 = new List<Renderable>();
|
|
||||||
|
|
||||||
for (int i = 0; i < r2.Count;i++)
|
|
||||||
{
|
|
||||||
var renderable = r2[i];
|
|
||||||
|
|
||||||
renderable.Scale = Info.Value;
|
|
||||||
r3.Add(renderable);
|
|
||||||
// yield return renderable;
|
|
||||||
}
|
|
||||||
|
|
||||||
return r3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -151,15 +151,6 @@ namespace OpenRA.Traits
|
|||||||
public readonly int ZOffset;
|
public readonly int ZOffset;
|
||||||
public float Scale;
|
public float Scale;
|
||||||
|
|
||||||
public Renderable(Sprite sprite, float2 pos, string palette, int z, int zOffset)
|
|
||||||
{
|
|
||||||
Sprite = sprite;
|
|
||||||
Pos = pos;
|
|
||||||
Palette = palette;
|
|
||||||
Z = z;
|
|
||||||
ZOffset = zOffset;
|
|
||||||
Scale = 1f; /* default */
|
|
||||||
}
|
|
||||||
public Renderable(Sprite sprite, float2 pos, string palette, int z, int zOffset, float scale)
|
public Renderable(Sprite sprite, float2 pos, string palette, int z, int zOffset, float scale)
|
||||||
{
|
{
|
||||||
Sprite = sprite;
|
Sprite = sprite;
|
||||||
@@ -171,12 +162,12 @@ namespace OpenRA.Traits
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Renderable(Sprite sprite, float2 pos, string palette, int z)
|
public Renderable(Sprite sprite, float2 pos, string palette, int z)
|
||||||
: this(sprite, pos, palette, z, 0) { }
|
: this(sprite, pos, palette, z, 0, 1f) { }
|
||||||
|
|
||||||
|
|
||||||
public Renderable(Sprite sprite, float2 pos, string palette, int z, float scale)
|
public Renderable(Sprite sprite, float2 pos, string palette, int z, float scale)
|
||||||
: this(sprite, pos, palette, z, 0, scale) { }
|
: this(sprite, pos, palette, z, 0, scale) { }
|
||||||
|
|
||||||
|
public Renderable WithScale(float newScale) { return new Renderable(Sprite, Pos, Palette, Z, ZOffset, newScale); }
|
||||||
public Renderable WithPalette(string newPalette) { return new Renderable(Sprite, Pos, newPalette, Z, ZOffset, Scale); }
|
public Renderable WithPalette(string newPalette) { return new Renderable(Sprite, Pos, newPalette, Z, ZOffset, Scale); }
|
||||||
public Renderable WithZOffset(int newOffset) { return new Renderable(Sprite, Pos, Palette, Z, newOffset, Scale); }
|
public Renderable WithZOffset(int newOffset) { return new Renderable(Sprite, Pos, Palette, Z, newOffset, Scale); }
|
||||||
public Renderable WithPos(float2 newPos) { return new Renderable(Sprite, newPos, Palette, Z, ZOffset, Scale); }
|
public Renderable WithPos(float2 newPos) { return new Renderable(Sprite, newPos, Palette, Z, ZOffset, Scale); }
|
||||||
|
|||||||
@@ -100,12 +100,7 @@ namespace OpenRA.Traits
|
|||||||
public static Renderable Centered(Actor self, Sprite s, float2 location)
|
public static Renderable Centered(Actor self, Sprite s, float2 location)
|
||||||
{
|
{
|
||||||
var pal = self.Owner == null ? "player0" : self.Owner.Palette;
|
var pal = self.Owner == null ? "player0" : self.Owner.Palette;
|
||||||
var scale = self.TraitOrDefault<Scale>();
|
var loc = location - 0.5f * s.size;
|
||||||
var scaleModifier = 1f;
|
|
||||||
if (scale != null)
|
|
||||||
scaleModifier = scale.Info.Value;
|
|
||||||
|
|
||||||
var loc = location - 0.5f * s.size * scaleModifier;
|
|
||||||
|
|
||||||
return new Renderable(s, loc.Round(), pal, (int)self.CenterLocation.Y);
|
return new Renderable(s, loc.Round(), pal, (int)self.CenterLocation.Y);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -82,7 +82,9 @@ namespace OpenRA.Mods.RA.Orders
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
foreach (var r in Preview)
|
foreach (var r in Preview)
|
||||||
r.Sprite.DrawAt(wr,Game.CellSize*topLeft + r.Pos, r.Palette ?? world.LocalPlayer.Palette);
|
r.Sprite.DrawAt(Game.CellSize*topLeft + r.Pos,
|
||||||
|
wr.GetPaletteIndex(r.Palette ?? world.LocalPlayer.Palette),
|
||||||
|
r.Scale*r.Sprite.size);
|
||||||
|
|
||||||
var res = world.WorldActor.Trait<ResourceLayer>();
|
var res = world.WorldActor.Trait<ResourceLayer>();
|
||||||
var isCloseEnough = BuildingInfo.IsCloseEnoughToBase(world, world.LocalPlayer, Building, topLeft);
|
var isCloseEnough = BuildingInfo.IsCloseEnoughToBase(world, world.LocalPlayer, Building, topLeft);
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ namespace OpenRA.Mods.RA.Render
|
|||||||
var anim = new Animation(RenderSimple.GetImage(building, Tileset), () => 0);
|
var anim = new Animation(RenderSimple.GetImage(building, Tileset), () => 0);
|
||||||
anim.PlayRepeating("idle");
|
anim.PlayRepeating("idle");
|
||||||
var rb = building.Traits.Get<RenderBuildingInfo>();
|
var rb = building.Traits.Get<RenderBuildingInfo>();
|
||||||
yield return new Renderable(anim.Image,rb.Origin,rb.Palette,0);
|
yield return new Renderable(anim.Image, rb.Origin + 0.5f*anim.Image.size*(1 - Scale), rb.Palette, 0, Scale);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ namespace OpenRA.Mods.RA.Render
|
|||||||
var anim = new Animation(RenderSimple.GetImage(building, Tileset), () => 0);
|
var anim = new Animation(RenderSimple.GetImage(building, Tileset), () => 0);
|
||||||
anim.PlayRepeating("idle-top");
|
anim.PlayRepeating("idle-top");
|
||||||
var rb = building.Traits.Get<RenderBuildingInfo>();
|
var rb = building.Traits.Get<RenderBuildingInfo>();
|
||||||
yield return new Renderable(anim.Image,rb.Origin,rb.Palette,0);
|
yield return new Renderable(anim.Image, rb.Origin + 0.5f*anim.Image.size*(1 - Scale), rb.Palette, 0, Scale);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -214,8 +214,9 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
var targetCell = unit.Location + xy - sourceLocation;
|
var targetCell = unit.Location + xy - sourceLocation;
|
||||||
foreach (var r in unit.Render())
|
foreach (var r in unit.Render())
|
||||||
r.Sprite.DrawAt(wr, r.Pos - Traits.Util.CenterOfCell(unit.Location) + Traits.Util.CenterOfCell(targetCell),
|
r.Sprite.DrawAt(r.Pos - Traits.Util.CenterOfCell(unit.Location) + Traits.Util.CenterOfCell(targetCell),
|
||||||
r.Palette ?? unit.Owner.Palette);
|
wr.GetPaletteIndex(r.Palette ?? unit.Owner.Palette),
|
||||||
|
r.Scale*r.Sprite.size);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unit tiles
|
// Unit tiles
|
||||||
|
|||||||
Reference in New Issue
Block a user