69 lines
2.9 KiB
C#
69 lines
2.9 KiB
C#
// Animancer // https://kybernetik.com.au/animancer // Copyright 2018-2023 Kybernetik //
|
|
|
|
using UnityEngine.Animations;
|
|
using Unity.Collections;
|
|
|
|
namespace Animancer
|
|
{
|
|
/// <summary>[Pro-Only]
|
|
/// A wrapper which allows access to the value of <see cref="float"/> properties that are controlled by animations.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// Documentation: <see href="https://kybernetik.com.au/animancer/docs/manual/ik#animated-properties">Animated Properties</see>
|
|
/// </remarks>
|
|
/// <example><see href="https://kybernetik.com.au/animancer/docs/examples/jobs">Animation Jobs</see></example>
|
|
/// https://kybernetik.com.au/animancer/api/Animancer/AnimatedFloat
|
|
///
|
|
public class AnimatedFloat : AnimatedProperty<AnimatedFloat.Job, float>
|
|
{
|
|
/************************************************************************************************************************/
|
|
|
|
/// <summary>
|
|
/// Allocates room for a specified number of properties to be filled by
|
|
/// <see cref="InitializeProperty(int, Transform, Type, string)"/>.
|
|
/// </summary>
|
|
public AnimatedFloat(IAnimancerComponent animancer, int propertyCount,
|
|
NativeArrayOptions options = NativeArrayOptions.ClearMemory)
|
|
: base(animancer, propertyCount, options)
|
|
{ }
|
|
|
|
/// <summary>Initializes a single property.</summary>
|
|
public AnimatedFloat(IAnimancerComponent animancer, string propertyName)
|
|
: base(animancer, propertyName)
|
|
{ }
|
|
|
|
/// <summary>Initializes a group of properties.</summary>
|
|
public AnimatedFloat(IAnimancerComponent animancer, params string[] propertyNames)
|
|
: base(animancer, propertyNames)
|
|
{ }
|
|
|
|
/************************************************************************************************************************/
|
|
|
|
protected override void CreateJob()
|
|
{
|
|
_Job = new Job() { properties = _Properties, values = _Values };
|
|
}
|
|
|
|
/************************************************************************************************************************/
|
|
|
|
/// <summary>An <see cref="IAnimationJob"/> which reads an array of <see cref="float"/> values.</summary>
|
|
/// https://kybernetik.com.au/animancer/api/Animancer/Job
|
|
///
|
|
public struct Job : IAnimationJob
|
|
{
|
|
public NativeArray<PropertyStreamHandle> properties;
|
|
public NativeArray<float> values;
|
|
|
|
public void ProcessRootMotion(AnimationStream stream) { }
|
|
|
|
public void ProcessAnimation(AnimationStream stream)
|
|
{
|
|
for (int i = properties.Length - 1; i >= 0; i--)
|
|
values[i] = properties[i].GetFloat(stream);
|
|
}
|
|
}
|
|
|
|
/************************************************************************************************************************/
|
|
}
|
|
}
|