Replace Sequence EmbeddedPalette with HasEmbeddedPalette.

This commit is contained in:
Paul Chote
2022-06-26 15:56:49 +01:00
committed by Pavel Penev
parent c1822d1cef
commit 2037e37d4e
5 changed files with 43 additions and 11 deletions

View File

@@ -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);

View File

@@ -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; } }

View File

@@ -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;
}
}
}

View File

@@ -93,6 +93,7 @@ namespace OpenRA.Mods.Common.UpdateRules
new AttackFrontalFacingTolerance(), new AttackFrontalFacingTolerance(),
new RenameCloakTypes(), new RenameCloakTypes(),
new SplitNukePowerMissileImage(), new SplitNukePowerMissileImage(),
new ReplaceSequenceEmbeddedPalette(),
}) })
}; };

View File

@@ -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