using System;
using UnityEngine;
using UnityEngine.Scripting.APIUpdating;
using UnityEngine.U2D;
namespace UnityEditor.U2D.Animation
{
/// An interface that allows Sprite Editor Modules to edit Character data for user custom importer.
/// Implement this interface for [[ScriptedImporter]] to leverage on Sprite Editor Modules to edit Character data.
[MovedFrom("UnityEditor.U2D.Experimental.Animation")]
public interface ICharacterDataProvider
{
///
/// Returns the CharacterData structure that represents the Character composition.
///
/// CharacterData data
CharacterData GetCharacterData();
///
/// Sets the CharacterData structure that represents to the data provider
///
/// CharacterData to set
void SetCharacterData(CharacterData characterData);
}
///
/// Data structure that represents a character setup
///
[Serializable]
[MovedFrom("UnityEditor.U2D.Experimental.Animation")]
public struct CharacterData
{
///
/// SpriteBones influencing the Character
///
public SpriteBone[] bones;
///
/// Parts of the character
///
public CharacterPart[] parts;
///
/// The dimension of the character required
///
public Vector2Int dimension;
///
/// Character grouping information
///
public CharacterGroup[] characterGroups;
///
/// Character pivot. The value is a normalized value between (0,0) and (1,1) where (1,1) represents the value in CharacterData.dimension
///
public Vector2 pivot;
///
/// Bones are readonly
///
[Obsolete("boneReadOnly is no longer part of CharacterData. To check if character has Main Skeleton assigned to it, please use IMainSkeletonDataProvider instead.")]
public bool boneReadOnly;
}
internal interface ICharacterOrder
{
int order { get; set;}
}
///
/// Data structure representing CharacterPart grouping
///
[Serializable]
[MovedFrom("UnityEditor.U2D.Experimental.Animation")]
public struct CharacterGroup : ICharacterOrder
{
///
/// Name of the CharacterGroup
///
public string name;
///
/// The parent group index it belongs to. Set to -1 if does not have a parent.
///
public int parentGroup;
[SerializeField]
int m_Order;
///
/// The order of the group in the list
///
public int order
{
get => m_Order;
set => m_Order = value;
}
}
///
/// Data structure representing a character part
///
[Serializable]
[MovedFrom("UnityEditor.U2D.Experimental.Animation")]
public struct CharacterPart : ICharacterOrder
{
///
/// Position for the Sprite in the character
///
public RectInt spritePosition;
///
/// Sprite ID
///
public string spriteId;
///
/// Bones influencing the Sprite
///
public int[] bones;
///
/// CharacterGroup that the part belongs to
///
public int parentGroup;
[SerializeField]
int m_Order;
///
/// The order of the part in the list
///
public int order
{
get => m_Order;
set => m_Order = value;
}
}
/// An interface that provides data from the Main Skeleton.
/// Available only when the Main Skeleton has been assigned.
public interface IMainSkeletonDataProvider
{
///
/// Returns Main Skeleton data.
///
/// MainSkeletonData data.
MainSkeletonData GetMainSkeletonData();
}
///
/// Data structure providing the Main Skeleton data.
///
public struct MainSkeletonData
{
///
/// Returns skeleton bones from the Main Skeleton asset.
///
public SpriteBone[] bones;
}
}