2019-09-28 17:27:48 -04:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace Toolbox.Library.Animations
|
|
|
|
|
{
|
|
|
|
|
public class InterpolationHelper
|
|
|
|
|
{
|
|
|
|
|
public static float Lerp(float LHS, float RHS, float Weight)
|
|
|
|
|
{
|
|
|
|
|
return LHS * (1 - Weight) + RHS * Weight;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static float Herp(float LHS, float RHS, float LS, float RS, float Diff, float Weight)
|
|
|
|
|
{
|
|
|
|
|
float Result;
|
|
|
|
|
|
|
|
|
|
Result = LHS + (LHS - RHS) * (2 * Weight - 3) * Weight * Weight;
|
|
|
|
|
Result += (Diff * (Weight - 1)) * (LS * (Weight - 1) + RS * Weight);
|
|
|
|
|
|
|
|
|
|
return Result;
|
|
|
|
|
}
|
2020-02-06 21:05:35 -05:00
|
|
|
|
|
2023-05-27 19:33:14 -04:00
|
|
|
|
public static float BezierInterpolate(float frame, float FrameL, float frameR,
|
|
|
|
|
float inSlope, float outSlope, float p0, float p1)
|
2020-02-06 21:05:35 -05:00
|
|
|
|
{
|
2023-05-27 19:33:14 -04:00
|
|
|
|
if (frame == FrameL) return p0;
|
|
|
|
|
if (frame == frameR) return p1;
|
2020-02-06 21:05:35 -05:00
|
|
|
|
|
2023-05-27 19:33:14 -04:00
|
|
|
|
float t = (frame - FrameL) / (frameR - FrameL);
|
|
|
|
|
return GetPointBezier(p0, p1, inSlope, outSlope, t);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static float CubicHermiteInterpolate(float frame, float FrameL, float frameR,
|
|
|
|
|
float cf0, float cf1, float cf2, float cf3)
|
|
|
|
|
{
|
|
|
|
|
float t = (frame - FrameL) / (frameR - FrameL);
|
|
|
|
|
return GetPointCubic(cf3, cf2, cf1, cf0, t);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static float GetPointCubic(float cf0, float cf1, float cf2, float cf3, float t)
|
|
|
|
|
{
|
|
|
|
|
return (((cf0 * t + cf1) * t + cf2) * t + cf3);
|
2020-03-09 20:27:56 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static float HermiteInterpolate(float frame, float frame1, float frame2,
|
2023-05-27 19:33:14 -04:00
|
|
|
|
float p0, float p1, float s0, float s1)
|
2020-03-09 20:27:56 -04:00
|
|
|
|
{
|
|
|
|
|
if (frame == frame1) return p0;
|
|
|
|
|
if (frame == frame2) return p1;
|
|
|
|
|
|
2020-02-06 21:05:35 -05:00
|
|
|
|
float t = (frame - frame1) / (frame2 - frame1);
|
2023-05-27 19:33:14 -04:00
|
|
|
|
return GetPointHermite(p0, p1, s0, s1, t);
|
2020-02-06 21:05:35 -05:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-27 19:33:14 -04:00
|
|
|
|
private static float GetPointHermite(float p0, float p1, float s0, float s1, float t)
|
|
|
|
|
{
|
2020-02-06 21:05:35 -05:00
|
|
|
|
float cf0 = (p0 * 2) + (p1 * -2) + (s0 * 1) + (s1 * 1);
|
|
|
|
|
float cf1 = (p0 * -3) + (p1 * 3) + (s0 * -2) + (s1 * -1);
|
|
|
|
|
float cf2 = (p0 * 0) + (p1 * 0) + (s0 * 1) + (s1 * 0);
|
|
|
|
|
float cf3 = (p0 * 1) + (p1 * 0) + (s0 * 0) + (s1 * 0);
|
|
|
|
|
return GetPointCubic(cf0, cf1, cf2, cf3, t);
|
2020-03-09 20:27:56 -04:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-27 19:33:14 -04:00
|
|
|
|
private static float GetPointBezier(float p0, float p1, float p2, float p3, float t)
|
|
|
|
|
{
|
2020-03-09 20:27:56 -04:00
|
|
|
|
float cf0 = (p0 * -1) + (p1 * 3) + (p2 * -3) + (p3 * 1);
|
|
|
|
|
float cf1 = (p0 * 3) + (p1 * -6) + (p2 * 3) + (p3 * 0);
|
|
|
|
|
float cf2 = (p0 * -3) + (p1 * 3) + (p2 * 0) + (p3 * 0);
|
|
|
|
|
float cf3 = (p0 * 1) + (p1 * 0) + (p2 * 0) + (p3 * 0);
|
|
|
|
|
return GetPointCubic(cf0, cf1, cf2, cf3, t);
|
2020-02-06 21:05:35 -05:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-27 19:33:14 -04:00
|
|
|
|
public static float[] CalculateCubicCoef(float frameA, float frameB, float valueA, float valueB, float inSlope, float outSlope)
|
|
|
|
|
{
|
2020-02-06 21:05:35 -05:00
|
|
|
|
return CalculateCubicCoef(frameB - frameA, valueA, valueB, inSlope, outSlope);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static float[] GetCubicSlopes(float time, float delta, float[] coef)
|
|
|
|
|
{
|
|
|
|
|
float outSlope = coef[1] / time;
|
|
|
|
|
float param = coef[3] - (-2 * delta);
|
|
|
|
|
float inSlope = param / time - outSlope;
|
|
|
|
|
return new float[2] { inSlope, outSlope };
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static float[] CalculateCubicCoef(float time, float valueA, float valueB, float inSlope, float outSlope)
|
|
|
|
|
{
|
|
|
|
|
float[] values = new float[4];
|
|
|
|
|
//Cubics have 4 coefficents
|
|
|
|
|
|
|
|
|
|
return values;
|
|
|
|
|
}
|
2019-09-28 17:27:48 -04:00
|
|
|
|
}
|
|
|
|
|
}
|