//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: 
//
//=============================================================================

#ifndef INTERPOLATORTYPES_H
#define INTERPOLATORTYPES_H
#ifdef _WIN32
#pragma once
#endif

class Quaternion;

enum
{
	INTERPOLATE_DEFAULT = 0,
	INTERPOLATE_CATMULL_ROM_NORMALIZEX,
	INTERPOLATE_EASE_IN,								
	INTERPOLATE_EASE_OUT,								
	INTERPOLATE_EASE_INOUT,			
	INTERPOLATE_BSPLINE,							
	INTERPOLATE_LINEAR_INTERP,				
	INTERPOLATE_KOCHANEK_BARTELS,			
	INTERPOLATE_KOCHANEK_BARTELS_EARLY,	
	INTERPOLATE_KOCHANEK_BARTELS_LATE,
	INTERPOLATE_SIMPLE_CUBIC,

	INTERPOLATE_CATMULL_ROM,
	INTERPOLATE_CATMULL_ROM_NORMALIZE,	
	INTERPOLATE_CATMULL_ROM_TANGENT,

	INTERPOLATE_EXPONENTIAL_DECAY,

	INTERPOLATE_HOLD,

	NUM_INTERPOLATE_TYPES,
};

#define MAKE_CURVE_TYPE( left, right )      ( ( right ) & 0xff ) | ( ( ( left ) & 0xff ) << 8 )

#define GET_RIGHT_CURVE(w)           ( ( w ) & 0xff )
#define GET_LEFT_CURVE(w)           ( ( ( w ) >> 8) & 0xff )

// Presets used by faceposer
enum
{
	CURVE_DEFAULT											= MAKE_CURVE_TYPE( INTERPOLATE_DEFAULT, INTERPOLATE_DEFAULT ),
	CURVE_CATMULL_ROM_TO_CATMULL_ROM						= MAKE_CURVE_TYPE( INTERPOLATE_CATMULL_ROM_NORMALIZEX , INTERPOLATE_CATMULL_ROM_NORMALIZEX ), // hotkey 1
	CURVE_EASE_IN_TO_EASE_OUT								= MAKE_CURVE_TYPE( INTERPOLATE_EASE_IN, INTERPOLATE_EASE_OUT ),							// hotkey 2
	CURVE_EASE_IN_TO_EASE_IN								= MAKE_CURVE_TYPE( INTERPOLATE_EASE_IN, INTERPOLATE_EASE_IN ),
	CURVE_EASE_OUT_TO_EASE_OUT								= MAKE_CURVE_TYPE( INTERPOLATE_EASE_OUT, INTERPOLATE_EASE_OUT ),
	CURVE_BSPLINE_TO_BSPLINE								= MAKE_CURVE_TYPE( INTERPOLATE_BSPLINE, INTERPOLATE_BSPLINE ),
	CURVE_LINEAR_INTERP_TO_LINEAR_INTERP					= MAKE_CURVE_TYPE( INTERPOLATE_LINEAR_INTERP, INTERPOLATE_LINEAR_INTERP ),
	CURVE_KOCHANEK_BARTELS_TO_KOCHANEK_BARTELS				= MAKE_CURVE_TYPE( INTERPOLATE_KOCHANEK_BARTELS, INTERPOLATE_KOCHANEK_BARTELS ),
	CURVE_KOCHANEK_BARTELS_EARLY_TO_KOCHANEK_BARTELS_EARLY	= MAKE_CURVE_TYPE( INTERPOLATE_KOCHANEK_BARTELS_EARLY, INTERPOLATE_KOCHANEK_BARTELS_EARLY ),
	CURVE_KOCHANEK_BARTELS_LATE_TO_KOCHANEK_BARTELS_LATE	= MAKE_CURVE_TYPE( INTERPOLATE_KOCHANEK_BARTELS_LATE, INTERPOLATE_KOCHANEK_BARTELS_LATE ),
	CURVE_SIMPLE_CUBIC_TO_SIMPLE_CUBIC						= MAKE_CURVE_TYPE( INTERPOLATE_SIMPLE_CUBIC, INTERPOLATE_SIMPLE_CUBIC ),
	CURVE_LINEAR_TO_HOLD									= MAKE_CURVE_TYPE( INTERPOLATE_LINEAR_INTERP, INTERPOLATE_HOLD ),
	CURVE_HOLD_TO_LINEAR									= MAKE_CURVE_TYPE( INTERPOLATE_HOLD, INTERPOLATE_LINEAR_INTERP ),
};

// Turn enum into string and vice versa
int			Interpolator_CurveTypeForName( const char *name );
const char	*Interpolator_NameForCurveType( int type, bool printname );
void		Interpolator_CurveInterpolatorsForType( int type, int& inbound, int& outbound );
int			Interpolator_CurveTypeForHotkey( int key );

int			Interpolator_InterpolatorForName( char const *name );
char const	*Interpolator_NameForInterpolator( int type, bool printname );

void		Interpolator_GetKochanekBartelsParams( int interpolatorType, float& tension, float& bias, float& continuity );

class Vector;
// Main spline interpolation function, assumes .x holds time and .y holds one dimensional value
void Interpolator_CurveInterpolate( int interpolationType,
	const Vector &vPre,
	const Vector &vStart,
	const Vector &vEnd,
	const Vector &vNext,
	float f,
	Vector &vOut );

// Main spline interpolation function for Vectors, doesn't assume time is in .x and doesn't do normalization
void Interpolator_CurveInterpolate_NonNormalized( int interpolationType,
	const Vector &vPre,
	const Vector &vStart,
	const Vector &vEnd,
	const Vector &vNext,
	float f,
	Vector &vOut );

// Main spline interpolation function for Vectors, doesn't assume time is in .x and doesn't do normalization
void Interpolator_CurveInterpolate_NonNormalized( int interpolationType,
												 const Quaternion &vPre,
												 const Quaternion &vStart,
												 const Quaternion &vEnd,
												 const Quaternion &vNext,
												 float f,
												 Quaternion &vOut );

#endif // INTERPOLATORTYPES_H