Use tileset ID in sequences instead of the TileSet object.
This commit is contained in:
@@ -42,12 +42,12 @@ namespace OpenRA.Mods.Common.Graphics
|
||||
{
|
||||
public DefaultSpriteSequenceLoader(ModData modData) { }
|
||||
|
||||
public virtual ISpriteSequence CreateSequence(ModData modData, TileSet tileSet, SpriteCache cache, string sequence, string animation, MiniYaml info)
|
||||
public virtual ISpriteSequence CreateSequence(ModData modData, string tileSet, SpriteCache cache, string sequence, string animation, MiniYaml info)
|
||||
{
|
||||
return new DefaultSpriteSequence(modData, tileSet, cache, this, sequence, animation, info);
|
||||
}
|
||||
|
||||
public IReadOnlyDictionary<string, ISpriteSequence> ParseSequences(ModData modData, TileSet tileSet, SpriteCache cache, MiniYamlNode node)
|
||||
public IReadOnlyDictionary<string, ISpriteSequence> ParseSequences(ModData modData, string tileSet, SpriteCache cache, MiniYamlNode node)
|
||||
{
|
||||
var sequences = new Dictionary<string, ISpriteSequence>();
|
||||
var nodes = node.Value.ToDictionary();
|
||||
@@ -143,7 +143,7 @@ namespace OpenRA.Mods.Common.Graphics
|
||||
|
||||
public readonly uint[] EmbeddedPalette;
|
||||
|
||||
protected virtual string GetSpriteSrc(ModData modData, TileSet tileSet, string sequence, string animation, string sprite, Dictionary<string, MiniYaml> d)
|
||||
protected virtual string GetSpriteSrc(ModData modData, string tileSet, string sequence, string animation, string sprite, Dictionary<string, MiniYaml> d)
|
||||
{
|
||||
return sprite ?? sequence;
|
||||
}
|
||||
@@ -166,7 +166,7 @@ namespace OpenRA.Mods.Common.Graphics
|
||||
return Rectangle.FromLTRB(left, top, right, bottom);
|
||||
}
|
||||
|
||||
public DefaultSpriteSequence(ModData modData, TileSet tileSet, SpriteCache cache, ISpriteSequenceLoader loader, string sequence, string animation, MiniYaml info)
|
||||
public DefaultSpriteSequence(ModData modData, string tileSet, SpriteCache cache, ISpriteSequenceLoader loader, string sequence, string animation, MiniYaml info)
|
||||
{
|
||||
this.sequence = sequence;
|
||||
Name = animation;
|
||||
|
||||
@@ -35,7 +35,7 @@ namespace OpenRA.Mods.Common.Graphics
|
||||
TilesetCodes = yaml.ToDictionary(kv => kv.Value);
|
||||
}
|
||||
|
||||
public override ISpriteSequence CreateSequence(ModData modData, TileSet tileSet, SpriteCache cache, string sequence, string animation, MiniYaml info)
|
||||
public override ISpriteSequence CreateSequence(ModData modData, string tileSet, SpriteCache cache, string sequence, string animation, MiniYaml info)
|
||||
{
|
||||
return new TilesetSpecificSpriteSequence(modData, tileSet, cache, this, sequence, animation, info);
|
||||
}
|
||||
@@ -43,24 +43,22 @@ namespace OpenRA.Mods.Common.Graphics
|
||||
|
||||
public class TilesetSpecificSpriteSequence : DefaultSpriteSequence
|
||||
{
|
||||
public TilesetSpecificSpriteSequence(ModData modData, TileSet tileSet, SpriteCache cache, ISpriteSequenceLoader loader, string sequence, string animation, MiniYaml info)
|
||||
public TilesetSpecificSpriteSequence(ModData modData, string tileSet, SpriteCache cache, ISpriteSequenceLoader loader, string sequence, string animation, MiniYaml info)
|
||||
: base(modData, tileSet, cache, loader, sequence, animation, info) { }
|
||||
|
||||
string ResolveTilesetId(TileSet tileSet, Dictionary<string, MiniYaml> d)
|
||||
string ResolveTilesetId(string tileSet, Dictionary<string, MiniYaml> d)
|
||||
{
|
||||
var tsId = tileSet.Id;
|
||||
|
||||
if (d.TryGetValue("TilesetOverrides", out var yaml))
|
||||
{
|
||||
var tsNode = yaml.Nodes.FirstOrDefault(n => n.Key == tsId);
|
||||
var tsNode = yaml.Nodes.FirstOrDefault(n => n.Key == tileSet);
|
||||
if (tsNode != null)
|
||||
tsId = tsNode.Value.Value;
|
||||
tileSet = tsNode.Value.Value;
|
||||
}
|
||||
|
||||
return tsId;
|
||||
return tileSet;
|
||||
}
|
||||
|
||||
protected override string GetSpriteSrc(ModData modData, TileSet tileSet, string sequence, string animation, string sprite, Dictionary<string, MiniYaml> d)
|
||||
protected override string GetSpriteSrc(ModData modData, string tileSet, string sequence, string animation, string sprite, Dictionary<string, MiniYaml> d)
|
||||
{
|
||||
var loader = (TilesetSpecificSpriteSequenceLoader)Loader;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user