You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
CrowdControl/Assets/Plugins/Animancer/Internal/Controller States/Float2ControllerState.cs

272 lines
11 KiB
C#

4 months ago
// Animancer // Copyright 2020 Kybernetik //
using System;
using UnityEngine;
using UnityEngine.Playables;
namespace Animancer
{
/// <summary>[Pro-Only]
/// A <see cref="ControllerState"/> which manages two float parameters.
/// </summary>
/// <remarks>
/// See also: <see cref="Float1ControllerState"/> and <see cref="Float3ControllerState"/>.
/// </remarks>
public sealed class Float2ControllerState : ControllerState
{
/************************************************************************************************************************/
private Parameter _ParameterX;
/// <summary>
/// The name of the parameter which <see cref="ParameterX"/> will get and set.
/// This will be null if the <see cref="ParameterHashX"/> was assigned directly.
/// </summary>
public string ParameterNameX
{
get { return _ParameterX.Name; }
set
{
_ParameterX.Name = value;
_ParameterX.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
}
}
/// <summary>
/// The name hash of the parameter which <see cref="ParameterX"/> will get and set.
/// </summary>
public int ParameterHashX
{
get { return _ParameterX.Hash; }
set
{
_ParameterX.Hash = value;
_ParameterX.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
}
}
/// <summary>
/// Gets and sets a float parameter in the <see cref="ControllerState.Controller"/> using the
/// <see cref="ParameterHashX"/> as the id.
/// </summary>
public float ParameterX
{
get { return Playable.GetFloat(_ParameterX); }
set { Playable.SetFloat(_ParameterX, value); }
}
/************************************************************************************************************************/
private Parameter _ParameterY;
/// <summary>
/// The name of the parameter which <see cref="ParameterY"/> will get and set.
/// This will be null if the <see cref="ParameterHashY"/> was assigned directly.
/// </summary>
public string ParameterNameY
{
get { return _ParameterY.Name; }
set
{
_ParameterY.Name = value;
_ParameterY.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
}
}
/// <summary>
/// The name hash of the parameter which <see cref="ParameterY"/> will get and set.
/// </summary>
public int ParameterHashY
{
get { return _ParameterY.Hash; }
set
{
_ParameterY.Hash = value;
_ParameterY.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
}
}
/// <summary>
/// Gets and sets a float parameter in the <see cref="ControllerState.Controller"/> using the
/// <see cref="ParameterHashY"/> as the id.
/// </summary>
public float ParameterY
{
get { return Playable.GetFloat(_ParameterY); }
set { Playable.SetFloat(_ParameterY, value); }
}
/************************************************************************************************************************/
/// <summary>
/// Gets and sets <see cref="ParameterX"/> and <see cref="ParameterY"/>.
/// </summary>
public new Vector2 Parameter
{
get
{
return new Vector2(ParameterX, ParameterY);
}
set
{
ParameterX = value.x;
ParameterY = value.y;
}
}
/************************************************************************************************************************/
/// <summary>
/// Constructs a new <see cref="Float2ControllerState"/> to play the `controller` without connecting
/// it to the <see cref="PlayableGraph"/>.
/// </summary>
private Float2ControllerState(AnimancerPlayable root, RuntimeAnimatorController controller,
Parameter parameterX, Parameter parameterY, bool resetStatesOnStop = true)
: base(root, controller, resetStatesOnStop)
{
_ParameterX = parameterX;
_ParameterX.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
_ParameterY = parameterY;
_ParameterY.ValidateHasParameter(Controller, AnimatorControllerParameterType.Float);
}
/// <summary>
/// Constructs a new <see cref="Float2ControllerState"/> to play the `controller` and connects it to the
/// the `layer`.
/// </summary>
public Float2ControllerState(AnimancerLayer layer, RuntimeAnimatorController controller,
Parameter parameterX, Parameter parameterY, bool resetStatesOnStop = true)
: this(layer.Root, controller, parameterX, parameterY, resetStatesOnStop)
{
layer.AddChild(this);
}
/// <summary>
/// Constructs a new <see cref="Float2ControllerState"/> to play the `controller` and
/// connects it to the `parent` at the specified `index`.
/// </summary>
public Float2ControllerState(AnimancerNode parent, int index, RuntimeAnimatorController controller,
Parameter parameterX, Parameter parameterY, bool resetStatesOnStop = true)
: this(parent.Root, controller, parameterX, parameterY, resetStatesOnStop)
{
SetParent(parent, index);
}
/************************************************************************************************************************/
/// <summary>The number of parameters being wrapped by this state.</summary>
public override int ParameterCount { get { return 2; } }
/// <summary>Returns the hash of a parameter being wrapped by this state.</summary>
public override int GetParameterHash(int index)
{
switch (index)
{
case 0: return ParameterHashX;
case 1: return ParameterHashY;
default: throw new ArgumentOutOfRangeException("index");
};
}
/************************************************************************************************************************/
#region Transition
/************************************************************************************************************************/
/// <summary>
/// A serializable <see cref="ITransition"/> which can create a <see cref="Float2ControllerState"/>
/// when passed into <see cref="AnimancerPlayable.Play(ITransition)"/>.
/// </summary>
/// <remarks>
/// Unfortunately the tool used to generate this documentation does not currently support nested types with
/// identical names, so only one <c>Transition</c> class will actually have a documentation page.
/// </remarks>
[Serializable]
public new class Transition : Transition<Float2ControllerState>
{
/************************************************************************************************************************/
[SerializeField]
private string _ParameterNameX;
/// <summary>[<see cref="SerializeField"/>]
/// The <see cref="Float2ControllerState.ParameterNameX"/> that will be used for the created state.
/// </summary>
public string ParameterNameX
{
get { return _ParameterNameX; }
set { _ParameterNameX = value; }
}
/************************************************************************************************************************/
[SerializeField]
private string _ParameterNameY;
/// <summary>[<see cref="SerializeField"/>]
/// The <see cref="Float2ControllerState.ParameterNameY"/> that will be used for the created state.
/// </summary>
public string ParameterNameY
{
get { return _ParameterNameY; }
set { _ParameterNameY = value; }
}
/************************************************************************************************************************/
/// <summary>Constructs a new <see cref="Transition"/>.</summary>
public Transition() { }
/// <summary>Constructs a new <see cref="Transition"/> with the specified Animator Controller and parameters.</summary>
public Transition(RuntimeAnimatorController controller, string parameterNameX, string parameterNameY)
{
Controller = controller;
_ParameterNameX = parameterNameX;
_ParameterNameY = parameterNameY;
}
/************************************************************************************************************************/
/// <summary>
/// Creates and returns a new <see cref="Float2ControllerState"/> connected to the `layer`.
/// <para></para>
/// This method also assigns it as the <see cref="AnimancerState.Transition{TState}.State"/>.
/// </summary>
public override Float2ControllerState CreateState(AnimancerLayer layer)
{
return new Float2ControllerState(layer, Controller, _ParameterNameX, _ParameterNameY, KeepStateOnStop);
}
/************************************************************************************************************************/
#region Drawer
#if UNITY_EDITOR
/************************************************************************************************************************/
/// <summary>[Editor-Only] Draws the Inspector GUI for a <see cref="Transition"/>.</summary>
[UnityEditor.CustomPropertyDrawer(typeof(Transition), true)]
public class Drawer : ControllerState.Transition.Drawer
{
/************************************************************************************************************************/
/// <summary>
/// Constructs a new <see cref="Drawer"/> and sets the
/// <see cref="ControllerState.Transition.Drawer.Parameters"/>.
/// </summary>
public Drawer() : base("_ParameterNameX", "_ParameterNameY") { }
/************************************************************************************************************************/
}
/************************************************************************************************************************/
#endif
#endregion
/************************************************************************************************************************/
}
/************************************************************************************************************************/
#endregion
/************************************************************************************************************************/
}
}