1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
//========= 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
|