亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? interpolator.cpp

?? 骨骼動畫....把魔獸模型解出的代碼..
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
				if(!TokenStream.ReadVector2(Node.OutTan)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				break;
			}

			case INTERPOLATOR_TYPE_VECTOR3:
			{
				if(!TokenStream.ReadVector3(Node.Vector)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				if(InterpolationType == INTERPOLATION_TYPE_NONE) break;
				if(InterpolationType == INTERPOLATION_TYPE_LINEAR) break;

				if(!TokenStream.ExpectWord("InTan")) return FALSE;
				if(!TokenStream.ReadVector3(Node.InTan)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				if(!TokenStream.ExpectWord("OutTan")) return FALSE;
				if(!TokenStream.ReadVector3(Node.OutTan)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				break;
			}

			case INTERPOLATOR_TYPE_VECTOR4:
			{
				if(!TokenStream.ReadVector4(Node.Vector)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				if(InterpolationType == INTERPOLATION_TYPE_NONE) break;
				if(InterpolationType == INTERPOLATION_TYPE_LINEAR) break;

				if(!TokenStream.ExpectWord("InTan")) return FALSE;
				if(!TokenStream.ReadVector4(Node.InTan)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				if(!TokenStream.ExpectWord("OutTan")) return FALSE;
				if(!TokenStream.ReadVector4(Node.OutTan)) return FALSE;
				if(!TokenStream.ExpectChar(',')) return FALSE;

				break;
			}
		}

		NodeList.push_back(Node);
	}

	if(!TokenStream.ExpectChar('}')) return FALSE;

	Static = FALSE;

	return TRUE;
}


//+-----------------------------------------------------------------------------
//| Retrieves the scalar at a certain timepoint
//+-----------------------------------------------------------------------------
FLOAT INTERPOLATOR::GetScalar(CONST SEQUENCE_TIME& Time)
{
	D3DXVECTOR4 TempVector;

	if(Static) return StaticVector.x;
	if(NodeList.size() <= 0) return 0.0f;

	GetInterpolatedValue(TempVector, Time);

	return TempVector.x;
}


//+-----------------------------------------------------------------------------
//| Retrieves the vector at a certain timepoint
//+-----------------------------------------------------------------------------
D3DXVECTOR2 INTERPOLATOR::GetVector2(CONST SEQUENCE_TIME& Time)
{
	D3DXVECTOR2 Vector2;
	D3DXVECTOR4 TempVector;

	if(Static) return D3DXVECTOR2(StaticVector.x, StaticVector.y);
	if(NodeList.size() <= 0) return D3DXVECTOR2(0.0f, 0.0f);

	GetInterpolatedValue(TempVector, Time);

	Vector2.x = TempVector.x;
	Vector2.y = TempVector.y;

	return Vector2;
}


//+-----------------------------------------------------------------------------
//| Retrieves the vector at a certain timepoint
//+-----------------------------------------------------------------------------
D3DXVECTOR3 INTERPOLATOR::GetVector3(CONST SEQUENCE_TIME& Time)
{
	D3DXVECTOR3 Vector3;
	D3DXVECTOR4 TempVector;

	if(Static) return D3DXVECTOR3(StaticVector.x, StaticVector.y, StaticVector.z);
	if(NodeList.size() <= 0) return D3DXVECTOR3(0.0f, 0.0f, 0.0f);

	GetInterpolatedValue(TempVector, Time);

	Vector3.x = TempVector.x;
	Vector3.y = TempVector.y;
	Vector3.z = TempVector.z;

	return Vector3;
}


//+-----------------------------------------------------------------------------
//| Retrieves the vector at a certain timepoint
//+-----------------------------------------------------------------------------
D3DXVECTOR4 INTERPOLATOR::GetVector4(CONST SEQUENCE_TIME& Time)
{
	D3DXVECTOR4 Vector4;

	if(Static) return StaticVector;
	if(NodeList.size() <= 0) return D3DXVECTOR4(0.0f, 0.0f, 0.0f, 1.0f);

	GetQuaternionValue(Vector4, Time);

	return Vector4;
}


//+-----------------------------------------------------------------------------
//| Sets a static scalar
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::SetStaticScalar(FLOAT NewScalar, CONST std::string& NewName)
{
	Clear();

	Type = INTERPOLATOR_TYPE_SCALAR;
	StaticVector = D3DXVECTOR4(NewScalar, 0.0f, 0.0f, 0.0f);
	Static = TRUE;

	if(NewName != "")
	{
		Name = NewName;
		DefaultVector = StaticVector;
	}
}


//+-----------------------------------------------------------------------------
//| Sets a static integer scalar
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::SetStaticScalarInt(INT NewScalar, CONST std::string& NewName)
{
	Clear();

	Type = INTERPOLATOR_TYPE_SCALAR_INT;
	StaticVector = D3DXVECTOR4(static_cast<FLOAT>(NewScalar), 0.0f, 0.0f, 0.0f);
	Static = TRUE;

	if(NewName != "")
	{
		Name = NewName;
		DefaultVector = StaticVector;
	}
}


//+-----------------------------------------------------------------------------
//| Sets a static vector
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::SetStaticVector2(CONST D3DXVECTOR2& NewVector2, CONST std::string& NewName)
{
	Clear();

	Type = INTERPOLATOR_TYPE_VECTOR2;
	StaticVector = D3DXVECTOR4(NewVector2.x, NewVector2.y, 0.0f, 0.0f);
	Static = TRUE;

	if(NewName != "")
	{
		Name = NewName;
		DefaultVector = StaticVector;
	}
}


//+-----------------------------------------------------------------------------
//| Sets a static vector
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::SetStaticVector3(CONST D3DXVECTOR3& NewVector3, CONST std::string& NewName)
{
	Clear();

	Type = INTERPOLATOR_TYPE_VECTOR3;
	StaticVector = D3DXVECTOR4(NewVector3.x, NewVector3.y, NewVector3.z, 0.0f);
	Static = TRUE;

	if(NewName != "")
	{
		Name = NewName;
		DefaultVector = StaticVector;
	}
}


//+-----------------------------------------------------------------------------
//| Sets a static vector
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::SetStaticVector4(CONST D3DXVECTOR4& NewVector4, CONST std::string& NewName)
{
	Clear();

	Type = INTERPOLATOR_TYPE_VECTOR4;
	StaticVector = NewVector4;
	Static = TRUE;

	if(NewName != "")
	{
		Name = NewName;
		DefaultVector = StaticVector;
	}
}


//+-----------------------------------------------------------------------------
//| Retrieves the interpolated value
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::GetInterpolatedValue(D3DXVECTOR4& Vector, CONST SEQUENCE_TIME& Time)
{
	FLOAT Factor;
	FLOAT InverseFactor;
	SEQUENCE_TIME TempTime;
	MODEL_GLOBAL_SEQUENCE* GlobalSequence;
	std::list<INTERPOLATOR_NODE>::iterator Node1;
	std::list<INTERPOLATOR_NODE>::iterator Node2;

	if(GlobalSequenceNode.IsAttached())
	{
		GlobalSequence = GlobalSequenceNode.GetObjectData();
		TempTime.IntervalStart = 0;
		TempTime.IntervalEnd = GlobalSequence->Data().Duration;
		TempTime.Time = GlobalSequence->Data().Time;
	}
	else
	{
		TempTime = Time;
	}

	GetSurroundingNodes(TempTime, Node1, Node2);

	if(Node1 == NodeList.end())
	{
		Vector = DefaultVector;
		return;
	}

	if(Node2 == NodeList.end())
	{
		Vector = Node1->Vector;
		return;
	}

	if(Node1->Time >= Node2->Time)
	{
		Vector = Node1->Vector;
		return;
	}

	Factor = static_cast<FLOAT>(TempTime.Time - Node1->Time) / static_cast<FLOAT>(Node2->Time - Node1->Time);
	InverseFactor = (1.0f - Factor);

	switch(InterpolationType)
	{
		case INTERPOLATION_TYPE_NONE:
		{
			Vector = Node1->Vector;
			break;
		}

		case INTERPOLATION_TYPE_LINEAR:
		{
			Vector = (InverseFactor * Node1->Vector) + (Factor * Node2->Vector);
			break;
		}

		case INTERPOLATION_TYPE_HERMITE:
		{
			FLOAT Factor1;
			FLOAT Factor2;
			FLOAT Factor3;
			FLOAT Factor4;
			FLOAT FactorTimesTwo;

			FactorTimesTwo = Factor * Factor;

			Factor1 = FactorTimesTwo * (2.0f * Factor - 3.0f) + 1;
			Factor2 = FactorTimesTwo * (Factor - 2.0f) + Factor;
			Factor3 = FactorTimesTwo * (Factor - 1.0f);
			Factor4 = FactorTimesTwo * (3.0f - 2.0f * Factor);

			Vector = (Factor1 * Node1->Vector) + (Factor2 * Node1->OutTan) + (Factor3 * Node2->InTan) + (Factor4 * Node2->Vector);

			break;
		}

		case INTERPOLATION_TYPE_BEZIER:
		{
			FLOAT Factor1;
			FLOAT Factor2;
			FLOAT Factor3;
			FLOAT Factor4;
			FLOAT FactorTimesTwo;
			FLOAT InverseFactorTimesTwo;

			FactorTimesTwo = Factor * Factor;
			InverseFactorTimesTwo = InverseFactor * InverseFactor;

			Factor1 = InverseFactorTimesTwo * InverseFactor;
			Factor2 = 3.0f * Factor * InverseFactorTimesTwo;
			Factor3 = 3.0f * FactorTimesTwo * InverseFactor;
			Factor4 = FactorTimesTwo * Factor;

			Vector = (Factor1 * Node1->Vector) + (Factor2 * Node1->OutTan) + (Factor3 * Node2->InTan) + (Factor4 * Node2->Vector);

			break;
		}
	}
}


//+-----------------------------------------------------------------------------
//| Retrieves the interpolated quaternion value
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::GetQuaternionValue(D3DXVECTOR4& Vector, CONST SEQUENCE_TIME& Time)
{
	FLOAT Factor;
	SEQUENCE_TIME TempTime;
	MODEL_GLOBAL_SEQUENCE* GlobalSequence;
	std::list<INTERPOLATOR_NODE>::iterator Node1;
	std::list<INTERPOLATOR_NODE>::iterator Node2;

	if(GlobalSequenceNode.IsAttached())
	{
		GlobalSequence = GlobalSequenceNode.GetObjectData();
		TempTime.IntervalStart = 0;
		TempTime.IntervalEnd = GlobalSequence->Data().Duration;
		TempTime.Time = GlobalSequence->Data().Time;
	}
	else
	{
		TempTime = Time;
	}

	GetSurroundingNodes(TempTime, Node1, Node2);

	if(Node1 == NodeList.end())
	{
		if(Node2 == NodeList.end())
		{
			Vector = DefaultVector;
		}
		else
		{
			Vector = Node2->Vector;
		}
		return;
	}

	if(Node2 == NodeList.end())
	{
		Vector = Node1->Vector;
		return;
	}

	if(Node1->Time >= Node2->Time)
	{
		Vector = Node1->Vector;
		return;
	}

	Factor = static_cast<FLOAT>(TempTime.Time - Node1->Time) / static_cast<FLOAT>(Node2->Time - Node1->Time);

	switch(InterpolationType)
	{
		case INTERPOLATION_TYPE_NONE:
		{
			Vector = Node1->Vector;
			break;
		}

		case INTERPOLATION_TYPE_LINEAR:
		{
			D3DXQUATERNION* Quaternion;
			D3DXQUATERNION* Quaternion1;
			D3DXQUATERNION* Quaternion2;

			Quaternion = reinterpret_cast<D3DXQUATERNION*>(&Vector);
			Quaternion1 = reinterpret_cast<D3DXQUATERNION*>(&Node1->Vector);
			Quaternion2 = reinterpret_cast<D3DXQUATERNION*>(&Node2->Vector);

			D3DXQuaternionSlerp(Quaternion, Quaternion1, Quaternion2, Factor);

			break;
		}

		case INTERPOLATION_TYPE_HERMITE:
		case INTERPOLATION_TYPE_BEZIER:
		{
			D3DXQUATERNION* Quaternion;
			D3DXQUATERNION* Quaternion1;
			D3DXQUATERNION* Quaternion2;
			D3DXQUATERNION* Quaternion3;
			D3DXQUATERNION* Quaternion4;
			D3DXQUATERNION QuaternionA;
			D3DXQUATERNION QuaternionB;
			D3DXQUATERNION QuaternionC;

			Quaternion = reinterpret_cast<D3DXQUATERNION*>(&Vector);
			Quaternion1 = reinterpret_cast<D3DXQUATERNION*>(&Node1->Vector);
			Quaternion2 = reinterpret_cast<D3DXQUATERNION*>(&Node1->InTan);
			Quaternion3 = reinterpret_cast<D3DXQUATERNION*>(&Node2->Vector);
			Quaternion4 = reinterpret_cast<D3DXQUATERNION*>(&Node2->OutTan);

			D3DXQuaternionSquadSetup(&QuaternionA, &QuaternionB, &QuaternionC, Quaternion1, Quaternion2, Quaternion3, Quaternion4);
			D3DXQuaternionSquad(Quaternion, Quaternion1, &QuaternionA, &QuaternionB, &QuaternionC, Factor);

			break;
		}
	}
}


//+-----------------------------------------------------------------------------
//| Retrieves the surrounding nodes
//+-----------------------------------------------------------------------------
VOID INTERPOLATOR::GetSurroundingNodes(CONST SEQUENCE_TIME& Time, std::list<INTERPOLATOR_NODE>::iterator& Node1, std::list<INTERPOLATOR_NODE>::iterator& Node2)
{
	Node1 = NodeList.end();
	Node2 = NodeList.begin();

	while(TRUE)
	{
		if(Node2 == NodeList.end()) break;
		if(Time.Time < Node2->Time) break;

		Node1 = Node2;
		Node2++;
	}

	if((Node1 != NodeList.end()) && (Node1->Time < Time.IntervalStart)) Node1 = NodeList.end();
	if((Node2 != NodeList.end()) && (Node2->Time > Time.IntervalEnd)) Node2 = NodeList.end();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久aaaa| 久久国产剧场电影| 亚洲电影视频在线| 国产剧情一区二区| 欧美日韩精品欧美日韩精品一综合| 欧美电影精品一区二区| 国产精品一二三区| 日韩一区二区三区免费看| 日韩专区中文字幕一区二区| 91麻豆精品秘密| 精品久久一区二区| 亚洲伊人伊色伊影伊综合网| 成人一区在线看| 青青草91视频| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 久久免费午夜影院| 亚洲成人7777| 一本大道久久精品懂色aⅴ| 久久久久成人黄色影片| 麻豆成人91精品二区三区| 欧美视频一区二| 一区二区三区在线影院| 91捆绑美女网站| 国产精品盗摄一区二区三区| 国产成人鲁色资源国产91色综| 日韩精品一区二区三区三区免费| 亚洲一二三区在线观看| 色婷婷久久久久swag精品| 亚洲欧洲中文日韩久久av乱码| 国产成人小视频| 国产日韩欧美精品电影三级在线| 玖玖九九国产精品| 精品对白一区国产伦| 久久99精品久久只有精品| 日韩免费成人网| 国产一区91精品张津瑜| 国产视频一区不卡| 成人丝袜18视频在线观看| 国产精品乱码人人做人人爱| 成人av在线一区二区三区| 中文字幕中文乱码欧美一区二区| 成人午夜av电影| 一区二区三区四区不卡视频| 精品视频全国免费看| 日日夜夜免费精品| 欧美成人三级在线| 国产精品996| 亚洲天堂免费看| 在线综合视频播放| 国产精品一二二区| 有坂深雪av一区二区精品| 欧美日韩成人在线一区| 狂野欧美性猛交blacked| 国产精品久久久久三级| 欧美专区亚洲专区| 看电影不卡的网站| 亚洲欧美经典视频| 91精品国产乱码久久蜜臀| 国产成人午夜视频| 亚洲一区二区三区自拍| 久久综合中文字幕| 在线一区二区观看| 国产一区二区在线电影| 一区二区三区影院| 精品91自产拍在线观看一区| www.欧美色图| 婷婷综合五月天| 国产精品免费视频观看| 欧美日本乱大交xxxxx| 不卡一卡二卡三乱码免费网站| 亚洲一区在线观看网站| 久久九九全国免费| 欧美精品久久久久久久多人混战 | 日韩免费高清电影| 99国产精品久久久久久久久久| 日韩二区三区四区| **性色生活片久久毛片| 日韩精品一区二区在线| 91麻豆自制传媒国产之光| 精品制服美女丁香| 亚洲国产精品天堂| 中文字幕中文字幕一区| 精品捆绑美女sm三区| 欧美午夜一区二区三区| 波多野结衣亚洲| 国产综合久久久久影院| 日韩高清不卡一区| 亚洲品质自拍视频| 国产女人18水真多18精品一级做| 欧美撒尿777hd撒尿| 成人av手机在线观看| 精久久久久久久久久久| 亚洲成av人片在线观看| 最新久久zyz资源站| 久久精品人人做人人爽97| 欧美一级高清大全免费观看| 欧洲一区二区三区免费视频| 成人18视频在线播放| 丰满岳乱妇一区二区三区| 蜜臀av一区二区三区| 亚洲成av人片一区二区三区| 亚洲黄网站在线观看| 成人免费一区二区三区在线观看| 久久精品一区二区三区不卡牛牛 | 久久久久国产一区二区三区四区| 欧美日本不卡视频| 91久久精品午夜一区二区| 99re这里只有精品首页| 国产成人精品在线看| 久99久精品视频免费观看| 肉色丝袜一区二区| 久久国产视频网| 美女视频第一区二区三区免费观看网站| 亚洲妇女屁股眼交7| 亚洲6080在线| 男男成人高潮片免费网站| 午夜精品福利久久久| 婷婷国产v国产偷v亚洲高清| 亚洲成人av一区二区| 亚洲一区在线观看免费观看电影高清| 亚洲午夜免费电影| 亚洲国产美国国产综合一区二区| 一区二区成人在线| 亚洲高清久久久| 美女高潮久久久| 国产乱人伦偷精品视频不卡| 国产v综合v亚洲欧| 99久久99久久精品免费观看| 91久久精品一区二区| 7777精品伊人久久久大香线蕉完整版| 欧美精品第一页| 精品美女在线观看| 欧美高清在线一区| 亚洲香肠在线观看| 婷婷成人激情在线网| 精品在线一区二区| 国产成人午夜99999| 91在线精品秘密一区二区| 欧美日韩一区二区三区在线看| 91精品国产综合久久久久久久久久| 欧美成va人片在线观看| 欧美午夜精品一区二区三区| 欧美xxxx在线观看| 国产精品久久久久久久久动漫 | 久久福利视频一区二区| 国产91在线|亚洲| 欧美天堂亚洲电影院在线播放| 日韩你懂的在线播放| 1000精品久久久久久久久| 日韩高清电影一区| 97成人超碰视| 欧美成人午夜电影| 一二三四区精品视频| 蜜臀av一区二区在线观看 | 91精品久久久久久久99蜜桃| 日本一区二区三区久久久久久久久不| 亚洲精品第1页| 国产精品系列在线观看| 欧美色图片你懂的| 国产精品丝袜久久久久久app| 亚洲国产成人av好男人在线观看| 激情图片小说一区| 欧美三级一区二区| 国产欧美一区二区精品性 | 亚洲丝袜精品丝袜在线| 美女脱光内衣内裤视频久久影院| 成人av网址在线观看| 日韩精品一区二| 三级影片在线观看欧美日韩一区二区| 成人永久免费视频| 久久精品男人的天堂| 天天综合网 天天综合色| 成人动漫av在线| 精品福利在线导航| 日韩成人精品在线观看| 在线视频你懂得一区| 国产精品黄色在线观看| 国产一区二区三区不卡在线观看| 欧美精品一二三四| 亚洲精品福利视频网站| 91网站最新地址| 欧美国产精品劲爆| 国产又粗又猛又爽又黄91精品| 欧美日韩成人在线| 亚洲午夜激情网站| 色综合天天综合网天天狠天天| 国产欧美视频在线观看| 激情图区综合网| 久久亚洲二区三区| 久草精品在线观看| 精品国产欧美一区二区| 日本在线不卡一区| 正在播放亚洲一区| 日本美女一区二区三区视频| 欧美人妇做爰xxxⅹ性高电影| 亚洲最大成人网4388xx| 欧美伊人久久大香线蕉综合69 | 国产精品剧情在线亚洲| 国产一区二区不卡在线| 国产亚洲美州欧州综合国|