forked from shokunin000/te120
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjigglebones.h
82 lines (64 loc) · 2.1 KB
/
jigglebones.h
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
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $Workfile: $
// $NoKeywords: $
//=============================================================================//
#ifndef C_JIGGLEBONES_H
#define C_JIGGLEBONES_H
#ifdef _WIN32
#pragma once
#endif
#include "studio.h"
#include "utlvector.h"
#include "utllinkedlist.h"
//-----------------------------------------------------------------------------
/**
* JiggleData is the instance-specific data for a jiggle bone
*/
struct JiggleData
{
void Init( int initBone, float currenttime, const Vector &initBasePos, const Vector &initTipPos )
{
bone = initBone;
lastUpdate = currenttime;
basePos = initBasePos;
baseLastPos = basePos;
baseVel.Init();
baseAccel.Init();
tipPos = initTipPos;
tipVel.Init();
tipAccel.Init();
lastLeft = Vector( 0, 0, 0 );
lastBoingPos = initBasePos;
boingDir = Vector( 0.0f, 0.0f, 1.0f );
boingVelDir.Init();
boingSpeed = 0.0f;
boingTime = 0.0f;
}
int bone;
float lastUpdate; // based on gpGlobals->realtime
Vector basePos; // position of the base of the jiggle bone
Vector baseLastPos;
Vector baseVel;
Vector baseAccel;
Vector tipPos; // position of the tip of the jiggle bone
Vector tipVel;
Vector tipAccel;
Vector lastLeft; // previous up vector
Vector lastBoingPos; // position of base of jiggle bone last update for tracking velocity
Vector boingDir; // current direction along which the boing effect is occurring
Vector boingVelDir; // current estimation of jiggle bone unit velocity vector for boing effect
float boingSpeed; // current estimation of jiggle bone speed for boing effect
float boingTime;
};
class CJiggleBones
{
public:
JiggleData * GetJiggleData( int bone, float currenttime, const Vector &initBasePos, const Vector &initTipPos );
void BuildJiggleTransformations( int boneIndex, float currentime, const mstudiojigglebone_t *jiggleParams, const matrix3x4_t &goalMX, matrix3x4_t &boneMX );
CUtlLinkedList< JiggleData > m_jiggleBoneState;
};
extern void DevMsgRT( PRINTF_FORMAT_STRING char const* pMsg, ... );
#endif // C_BASEANIMATING_H