MoonTools.Curve/Curve/SplineCurve3D.cs

61 lines
1.4 KiB
C#
Raw Permalink Normal View History

2020-08-26 21:56:32 +00:00
using System.Collections.Immutable;
using System.Numerics;
namespace MoonTools.Curve
{
/// <summary>
/// A concatenation of 3D curves with time values.
/// </summary>
public struct SplineCurve3D
{
2020-12-12 12:43:58 +00:00
private ICurve3D[] Curves { get; }
private float[] Times { get; }
2020-08-26 21:56:32 +00:00
public float TotalTime { get; }
public bool Loop { get; }
2020-12-12 12:43:58 +00:00
public SplineCurve3D(ICurve3D[] curves, float[] times, bool loop = false)
2020-08-26 21:56:32 +00:00
{
TotalTime = 0;
for (int i = 0; i < times.Length; i++)
{
TotalTime += times[i];
}
Curves = curves;
Times = times;
Loop = loop;
}
public Vector3 Point(float t)
{
if (!Loop && t >= TotalTime)
{
var lastIndex = Curves.Length - 1;
return Curves[lastIndex].Point(Times[lastIndex], 0, Times[lastIndex]);
}
t %= TotalTime;
var index = 0;
var startTime = 0f;
var incrementalTime = 0f;
for (int i = 0; i < Times.Length; i++)
{
incrementalTime += Times[i];
if (t < incrementalTime)
{
break;
}
index++;
2020-12-12 12:43:58 +00:00
startTime = incrementalTime;
2020-08-26 21:56:32 +00:00
}
return Curves[index].Point(t - startTime, 0, Times[index]);
}
}
}