wuxianshengcong/Library/PackageCache/com.unity.2d.aseprite@1.1.6/Editor/AsepriteSpriteEditorDataProvider.cs
2025-01-02 14:50:41 +08:00

215 lines
8.2 KiB
C#

using UnityEditor.AssetImporters;
using UnityEditor.U2D.Sprites;
namespace UnityEditor.U2D.Aseprite
{
public partial class AsepriteImporter : ScriptedImporter, ISpriteEditorDataProvider
{
SpriteImportMode ISpriteEditorDataProvider.spriteImportMode => spriteImportModeToUse;
UnityEngine.Object ISpriteEditorDataProvider.targetObject => targetObject;
internal UnityEngine.Object targetObject => this;
/// <summary>
/// Implementation for ISpriteEditorDataProvider.pixelsPerUnit.
/// </summary>
float ISpriteEditorDataProvider.pixelsPerUnit => pixelsPerUnit;
internal float pixelsPerUnit => m_TextureImporterSettings.spritePixelsPerUnit;
/// <summary>
/// Implementation for ISpriteEditorDataProvider.GetDataProvider.
/// </summary>
/// <typeparam name="T">Data provider type to retrieve.</typeparam>
/// <returns></returns>
T ISpriteEditorDataProvider.GetDataProvider<T>()
{
return GetDataProvider<T>();
}
internal T GetDataProvider<T>() where T : class
{
if (typeof(T) == typeof(ISpriteBoneDataProvider))
{
return new SpriteBoneDataProvider { dataProvider = this } as T;
}
if (typeof(T) == typeof(ISpriteMeshDataProvider))
{
return new SpriteMeshDataProvider { dataProvider = this } as T;
}
if (typeof(T) == typeof(ISpriteOutlineDataProvider))
{
return new SpriteOutlineDataProvider { dataProvider = this } as T;
}
if (typeof(T) == typeof(ISpritePhysicsOutlineDataProvider))
{
return new SpritePhysicsOutlineProvider { dataProvider = this } as T;
}
if (typeof(T) == typeof(ITextureDataProvider))
{
return new TextureDataProvider { dataProvider = this } as T;
}
if (typeof(T) == typeof(ISecondaryTextureDataProvider))
{
return new SecondaryTextureDataProvider() { dataProvider = this } as T;
}
else
return this as T;
}
/// <summary>
/// Implementation for ISpriteEditorDataProvider.HasDataProvider.
/// </summary>
/// <param name="type">Data provider type to query.</param>
/// <returns>True if data provider is supported, false otherwise.</returns>
bool ISpriteEditorDataProvider.HasDataProvider(System.Type type)
{
return HasDataProvider(type);
}
internal bool HasDataProvider(System.Type type)
{
if (type == typeof(ISpriteBoneDataProvider) ||
type == typeof(ISpriteMeshDataProvider) ||
type == typeof(ISpriteOutlineDataProvider) ||
type == typeof(ISpritePhysicsOutlineDataProvider) ||
type == typeof(ITextureDataProvider) ||
type == typeof(ISecondaryTextureDataProvider))
{
return true;
}
else
return type.IsAssignableFrom(GetType());
}
/// <summary>
/// Implementation for ISpriteEditorDataProvider.Apply.
/// </summary>
void ISpriteEditorDataProvider.Apply()
{
Apply();
}
/// <summary>
/// Implementation for ISpriteEditorDataProvider.InitSpriteEditorDataProvider.
/// </summary>
void ISpriteEditorDataProvider.InitSpriteEditorDataProvider()
{
InitSpriteEditorDataProvider();
}
void InitSpriteEditorDataProvider() { }
/// <summary>
/// Implementation for ISpriteEditorDataProvider.GetSpriteRects.
/// </summary>
/// <returns>An array of SpriteRect for the current import mode.</returns>
SpriteRect[] ISpriteEditorDataProvider.GetSpriteRects()
{
return GetSpriteRects();
}
internal SpriteRect[] GetSpriteRects()
{
if (spriteImportModeToUse == SpriteImportMode.Multiple)
{
switch (m_AsepriteImporterSettings.fileImportMode)
{
case FileImportModes.SpriteSheet:
{
var spriteRects = new SpriteRect[m_SpriteSheetImportData.Count];
for (var i = 0; i < spriteRects.Length; i++)
{
spriteRects[i] = new SpriteMetaData(m_SpriteSheetImportData[i]);
}
return spriteRects;
}
case FileImportModes.AnimatedSprite:
default:
{
var spriteRects = new SpriteRect[m_AnimatedSpriteImportData.Count];
for (var i = 0; i < spriteRects.Length; i++)
{
spriteRects[i] = new SpriteMetaData(m_AnimatedSpriteImportData[i]);
}
return spriteRects;
}
}
}
return new[] { new SpriteMetaData(m_SingleSpriteImportData[0]) };
}
/// <summary>
/// Implementation for ISpriteEditorDataProvider.SetSpriteRects.
/// </summary>
/// <param name="spriteRects">Set the SpriteRect data for the current import mode.</param>
void ISpriteEditorDataProvider.SetSpriteRects(SpriteRect[] spriteRects)
{
SetSpriteRects(spriteRects);
}
internal void SetSpriteRects(SpriteRect[] spriteRects)
{
var spriteImportData = GetSpriteImportData();
if (spriteImportModeToUse == SpriteImportMode.Multiple)
{
for (var i = 0; i < spriteImportData.Count; i++)
{
var found = false;
foreach (var spriteRect in spriteRects)
{
if (spriteRect.spriteID != spriteImportData[i].spriteID)
continue;
found = true;
break;
}
if (found)
continue;
spriteImportData.RemoveAt(i);
--i;
}
foreach (var sr in spriteRects)
{
SpriteMetaData importData = null;
foreach (var metaData in spriteImportData)
{
if (metaData.spriteID != sr.spriteID)
continue;
importData = metaData;
break;
}
if (importData == null)
spriteImportData.Add(new SpriteMetaData(sr));
else
{
importData.name = sr.name;
importData.alignment = sr.alignment;
importData.border = sr.border;
importData.pivot = sr.pivot;
importData.rect = sr.rect;
}
}
}
else if (spriteRects.Length == 1 && (spriteImportModeToUse == SpriteImportMode.Single || spriteImportModeToUse == SpriteImportMode.Polygon))
{
if (spriteImportData[0].spriteID == spriteRects[0].spriteID)
{
spriteImportData[0].name = spriteRects[0].name;
spriteImportData[0].alignment = spriteRects[0].alignment;
m_TextureImporterSettings.spriteAlignment = (int)spriteRects[0].alignment;
m_TextureImporterSettings.spriteBorder = spriteImportData[0].border = spriteRects[0].border;
m_TextureImporterSettings.spritePivot = spriteImportData[0].pivot = spriteRects[0].pivot;
spriteImportData[0].rect = spriteRects[0].rect;
}
else
{
spriteImportData[0] = new SpriteMetaData(spriteRects[0]);
}
}
}
}
}