Replace Sequence EmbeddedPalette with HasEmbeddedPalette.
This commit is contained in:
@@ -212,10 +212,10 @@ namespace OpenRA.Mods.Common.Graphics
|
|||||||
[Desc("")]
|
[Desc("")]
|
||||||
public static float2 DepthSpriteOffset => float2.Zero;
|
public static float2 DepthSpriteOffset => float2.Zero;
|
||||||
|
|
||||||
[Desc("Use the palette embedded in the defined sprite. (Note: The name given here is actually irrelevant)")]
|
[Desc("Make a custom palette embedded in the sprite available to the PaletteFromEmbeddedSpritePalette trait.")]
|
||||||
public static string EmbeddedPalette => null;
|
public static bool HasEmbeddedPalette => false;
|
||||||
|
|
||||||
public readonly uint[] EmbeddedPaletteData;
|
public readonly uint[] EmbeddedPalette;
|
||||||
|
|
||||||
protected virtual string GetSpriteSrc(ModData modData, string 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)
|
||||||
{
|
{
|
||||||
@@ -436,16 +436,16 @@ namespace OpenRA.Mods.Common.Graphics
|
|||||||
}).ToArray();
|
}).ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
var exportPalette = LoadField<string>(d, nameof(EmbeddedPalette), null);
|
var hasEmbeddedPalette = LoadField<bool>(d, nameof(HasEmbeddedPalette), HasEmbeddedPalette);
|
||||||
if (exportPalette != null)
|
if (hasEmbeddedPalette)
|
||||||
{
|
{
|
||||||
var src = GetSpriteSrc(modData, tileSet, sequence, animation, info.Value, d);
|
var src = GetSpriteSrc(modData, tileSet, sequence, animation, info.Value, d);
|
||||||
|
|
||||||
var metadata = cache.FrameMetadata(src);
|
var metadata = cache.FrameMetadata(src);
|
||||||
var i = Frames != null ? Frames[0] : Start;
|
var i = Frames != null ? Frames[0] : Start;
|
||||||
var palettes = metadata?.GetOrDefault<EmbeddedSpritePalette>();
|
var palettes = metadata?.GetOrDefault<EmbeddedSpritePalette>();
|
||||||
if (palettes == null || !palettes.TryGetPaletteForFrame(i, out EmbeddedPaletteData))
|
if (palettes == null || !palettes.TryGetPaletteForFrame(i, out EmbeddedPalette))
|
||||||
throw new YamlException($"Cannot export palettes from {src}: frame {i} does not define an embedded palette");
|
throw new YamlException($"Cannot export palette from {src}: frame {i} does not define an embedded palette");
|
||||||
}
|
}
|
||||||
|
|
||||||
var boundSprites = SpriteBounds(sprites, Frames, Start, Facings, Length, Stride, transpose);
|
var boundSprites = SpriteBounds(sprites, Frames, Start, Facings, Length, Stride, transpose);
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
ImmutablePalette IProvidesCursorPaletteInfo.ReadPalette(IReadOnlyFileSystem fileSystem)
|
ImmutablePalette IProvidesCursorPaletteInfo.ReadPalette(IReadOnlyFileSystem fileSystem)
|
||||||
{
|
{
|
||||||
var sequence = (DefaultSpriteSequence)Game.ModData.DefaultSequences.Values.First().GetSequence(Image, Sequence);
|
var sequence = (DefaultSpriteSequence)Game.ModData.DefaultSequences.Values.First().GetSequence(Image, Sequence);
|
||||||
return new ImmutablePalette(sequence.EmbeddedPaletteData);
|
return new ImmutablePalette(sequence.EmbeddedPalette);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -59,7 +59,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
public void LoadPalettes(WorldRenderer wr)
|
public void LoadPalettes(WorldRenderer wr)
|
||||||
{
|
{
|
||||||
var sequence = (DefaultSpriteSequence)wr.World.Map.Rules.Sequences.GetSequence(info.Image, info.Sequence);
|
var sequence = (DefaultSpriteSequence)wr.World.Map.Rules.Sequences.GetSequence(info.Image, info.Sequence);
|
||||||
wr.AddPalette(info.Name, new ImmutablePalette(sequence.EmbeddedPaletteData), info.AllowModifiers);
|
wr.AddPalette(info.Name, new ImmutablePalette(sequence.EmbeddedPalette), info.AllowModifiers);
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerable<string> PaletteNames { get { yield return info.Name; } }
|
public IEnumerable<string> PaletteNames { get { yield return info.Name; } }
|
||||||
|
|||||||
@@ -0,0 +1,31 @@
|
|||||||
|
#region Copyright & License Information
|
||||||
|
/*
|
||||||
|
* Copyright 2007-2022 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, either version 3 of
|
||||||
|
* the License, or (at your option) any later version. For more
|
||||||
|
* information, see COPYING.
|
||||||
|
*/
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace OpenRA.Mods.Common.UpdateRules.Rules
|
||||||
|
{
|
||||||
|
public class ReplaceSequenceEmbeddedPalette : UpdateRule
|
||||||
|
{
|
||||||
|
public override string Name => "Replace Sequence EmbeddedPalette with HasEmbeddedPalette.";
|
||||||
|
|
||||||
|
public override string Description => "The EmbeddedPalette sequence option was replaced with a boolean HasEmbeddedPalette.";
|
||||||
|
|
||||||
|
public override IEnumerable<string> UpdateSequenceNode(ModData modData, MiniYamlNode sequenceNode)
|
||||||
|
{
|
||||||
|
foreach (var sequence in sequenceNode.Value.Nodes)
|
||||||
|
if (sequence.RemoveNodes("EmbeddedPalette") > 0)
|
||||||
|
sequence.AddNode("HasEmbeddedPalette", true);
|
||||||
|
|
||||||
|
yield break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -93,6 +93,7 @@ namespace OpenRA.Mods.Common.UpdateRules
|
|||||||
new AttackFrontalFacingTolerance(),
|
new AttackFrontalFacingTolerance(),
|
||||||
new RenameCloakTypes(),
|
new RenameCloakTypes(),
|
||||||
new SplitNukePowerMissileImage(),
|
new SplitNukePowerMissileImage(),
|
||||||
|
new ReplaceSequenceEmbeddedPalette(),
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -441,7 +441,7 @@ moveflsh:
|
|||||||
Tick: 80
|
Tick: 80
|
||||||
BlendMode: Multiply
|
BlendMode: Multiply
|
||||||
ZOffset: 2047
|
ZOffset: 2047
|
||||||
EmbeddedPalette: moveflash
|
HasEmbeddedPalette: True
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
spicea: BLOXBASE.R8
|
spicea: BLOXBASE.R8
|
||||||
@@ -468,7 +468,7 @@ shroud:
|
|||||||
Length: 14
|
Length: 14
|
||||||
palette: DATA.R8
|
palette: DATA.R8
|
||||||
Start: 38
|
Start: 38
|
||||||
EmbeddedPalette: shroud
|
HasEmbeddedPalette: True
|
||||||
shrouda: DATA.R8
|
shrouda: DATA.R8
|
||||||
Start: 40
|
Start: 40
|
||||||
shroudb: DATA.R8
|
shroudb: DATA.R8
|
||||||
|
|||||||
Reference in New Issue
Block a user