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

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

?? opc_boxboxoverlap.h

?? opcode是功能強大
?? H
字號:
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/**
 *	OBB-OBB overlap test using the separating axis theorem.
 *	- original code by Gomez / Gamasutra (similar to Gottschalk's one in RAPID)
 *	- optimized for AABB trees by computing the rotation matrix once (SOLID-fashion)
 *	- the fabs matrix is precomputed as well and epsilon-tweaked (RAPID-style, we found this almost mandatory)
 *	- Class III axes can be disabled... (SOLID & Intel fashion)
 *	- ...or enabled to perform some profiling
 *	- CPU comparisons used when appropriate
 *	- lazy evaluation sometimes saves some work in case of early exits (unlike SOLID)
 *
 *	\param		ea	[in] extents from box A
 *	\param		ca	[in] center from box A
 *	\param		eb	[in] extents from box B
 *	\param		cb	[in] center from box B
 *	\return		true if boxes overlap
 */
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
inline_ BOOL AABBTreeCollider::BoxBoxOverlap(const IceMaths::Point& ea_, const IceMaths::Point& ca_, const IceMaths::Point& eb_, const IceMaths::Point& cb_)
{
	// Applies model scales
	const IceMaths::Point ea = ea_*mScale0;
	const IceMaths::Point ca = ca_*mScale0;
	const IceMaths::Point eb = eb_*mScale1;
	const IceMaths::Point cb = cb_*mScale1;

	// Stats
	mNbBVBVTests++;

	float t,t2;

	// Class I : A's basis vectors
	float Tx = (mR1to0.m[0][0]*cb.x + mR1to0.m[1][0]*cb.y + mR1to0.m[2][0]*cb.z) + mT1to0.x - ca.x;
	t = ea.x + eb.x*mAR.m[0][0] + eb.y*mAR.m[1][0] + eb.z*mAR.m[2][0];
	if(GREATER(Tx, t))	return FALSE;

	float Ty = (mR1to0.m[0][1]*cb.x + mR1to0.m[1][1]*cb.y + mR1to0.m[2][1]*cb.z) + mT1to0.y - ca.y;
	t = ea.y + eb.x*mAR.m[0][1] + eb.y*mAR.m[1][1] + eb.z*mAR.m[2][1];
	if(GREATER(Ty, t))	return FALSE;

	float Tz = (mR1to0.m[0][2]*cb.x + mR1to0.m[1][2]*cb.y + mR1to0.m[2][2]*cb.z) + mT1to0.z - ca.z;
	t = ea.z + eb.x*mAR.m[0][2] + eb.y*mAR.m[1][2] + eb.z*mAR.m[2][2];
	if(GREATER(Tz, t))	return FALSE;

	// Class II : B's basis vectors
	t = Tx*mR1to0.m[0][0] + Ty*mR1to0.m[0][1] + Tz*mR1to0.m[0][2];	t2 = ea.x*mAR.m[0][0] + ea.y*mAR.m[0][1] + ea.z*mAR.m[0][2] + eb.x;
	if(GREATER(t, t2))	return FALSE;

	t = Tx*mR1to0.m[1][0] + Ty*mR1to0.m[1][1] + Tz*mR1to0.m[1][2];	t2 = ea.x*mAR.m[1][0] + ea.y*mAR.m[1][1] + ea.z*mAR.m[1][2] + eb.y;
	if(GREATER(t, t2))	return FALSE;

	t = Tx*mR1to0.m[2][0] + Ty*mR1to0.m[2][1] + Tz*mR1to0.m[2][2];	t2 = ea.x*mAR.m[2][0] + ea.y*mAR.m[2][1] + ea.z*mAR.m[2][2] + eb.z;
	if(GREATER(t, t2))	return FALSE;

	// Class III : 9 cross products
	// Cool trick: always perform the full test for first level, regardless of settings.
	// That way pathological cases (such as the pencils scene) are quickly rejected anyway !
	if(mFullBoxBoxTest || mNbBVBVTests==1)
	{
		t = Tz*mR1to0.m[0][1] - Ty*mR1to0.m[0][2];	t2 = ea.y*mAR.m[0][2] + ea.z*mAR.m[0][1] + eb.y*mAR.m[2][0] + eb.z*mAR.m[1][0];	if(GREATER(t, t2))	return FALSE;	// L = A0 x B0
		t = Tz*mR1to0.m[1][1] - Ty*mR1to0.m[1][2];	t2 = ea.y*mAR.m[1][2] + ea.z*mAR.m[1][1] + eb.x*mAR.m[2][0] + eb.z*mAR.m[0][0];	if(GREATER(t, t2))	return FALSE;	// L = A0 x B1
		t = Tz*mR1to0.m[2][1] - Ty*mR1to0.m[2][2];	t2 = ea.y*mAR.m[2][2] + ea.z*mAR.m[2][1] + eb.x*mAR.m[1][0] + eb.y*mAR.m[0][0];	if(GREATER(t, t2))	return FALSE;	// L = A0 x B2
		t = Tx*mR1to0.m[0][2] - Tz*mR1to0.m[0][0];	t2 = ea.x*mAR.m[0][2] + ea.z*mAR.m[0][0] + eb.y*mAR.m[2][1] + eb.z*mAR.m[1][1];	if(GREATER(t, t2))	return FALSE;	// L = A1 x B0
		t = Tx*mR1to0.m[1][2] - Tz*mR1to0.m[1][0];	t2 = ea.x*mAR.m[1][2] + ea.z*mAR.m[1][0] + eb.x*mAR.m[2][1] + eb.z*mAR.m[0][1];	if(GREATER(t, t2))	return FALSE;	// L = A1 x B1
		t = Tx*mR1to0.m[2][2] - Tz*mR1to0.m[2][0];	t2 = ea.x*mAR.m[2][2] + ea.z*mAR.m[2][0] + eb.x*mAR.m[1][1] + eb.y*mAR.m[0][1];	if(GREATER(t, t2))	return FALSE;	// L = A1 x B2
		t = Ty*mR1to0.m[0][0] - Tx*mR1to0.m[0][1];	t2 = ea.x*mAR.m[0][1] + ea.y*mAR.m[0][0] + eb.y*mAR.m[2][2] + eb.z*mAR.m[1][2];	if(GREATER(t, t2))	return FALSE;	// L = A2 x B0
		t = Ty*mR1to0.m[1][0] - Tx*mR1to0.m[1][1];	t2 = ea.x*mAR.m[1][1] + ea.y*mAR.m[1][0] + eb.x*mAR.m[2][2] + eb.z*mAR.m[0][2];	if(GREATER(t, t2))	return FALSE;	// L = A2 x B1
		t = Ty*mR1to0.m[2][0] - Tx*mR1to0.m[2][1];	t2 = ea.x*mAR.m[2][1] + ea.y*mAR.m[2][0] + eb.x*mAR.m[1][2] + eb.y*mAR.m[0][2];	if(GREATER(t, t2))	return FALSE;	// L = A2 x B2
	}
	return TRUE;
}

//! A dedicated version when one box is constant
inline_ BOOL OBBCollider::BoxBoxOverlap(const IceMaths::Point& extents_, const IceMaths::Point& center_)
{
	// Applies the model's local scale
	const IceMaths::Point extents = extents_ * mLocalScale;
	const IceMaths::Point center  = center_  * mLocalScale;

	// Stats
	mNbVolumeBVTests++;

	float t,t2;

	// Class I : A's basis vectors
	float Tx = mTBoxToModel.x - center.x;	t = extents.x + mBBx1;	if(GREATER(Tx, t))	return FALSE;
	float Ty = mTBoxToModel.y - center.y;	t = extents.y + mBBy1;	if(GREATER(Ty, t))	return FALSE;
	float Tz = mTBoxToModel.z - center.z;	t = extents.z + mBBz1;	if(GREATER(Tz, t))	return FALSE;

	// Class II : B's basis vectors
	t = Tx*mRBoxToModel.m[0][0] + Ty*mRBoxToModel.m[0][1] + Tz*mRBoxToModel.m[0][2];
	t2 = extents.x*mAR.m[0][0] + extents.y*mAR.m[0][1] + extents.z*mAR.m[0][2] + mBoxExtents.x;
	if(GREATER(t, t2))	return FALSE;

	t = Tx*mRBoxToModel.m[1][0] + Ty*mRBoxToModel.m[1][1] + Tz*mRBoxToModel.m[1][2];
	t2 = extents.x*mAR.m[1][0] + extents.y*mAR.m[1][1] + extents.z*mAR.m[1][2] + mBoxExtents.y;
	if(GREATER(t, t2))	return FALSE;

	t = Tx*mRBoxToModel.m[2][0] + Ty*mRBoxToModel.m[2][1] + Tz*mRBoxToModel.m[2][2];
	t2 = extents.x*mAR.m[2][0] + extents.y*mAR.m[2][1] + extents.z*mAR.m[2][2] + mBoxExtents.z;
	if(GREATER(t, t2))	return FALSE;

	// Class III : 9 cross products
	// Cool trick: always perform the full test for first level, regardless of settings.
	// That way pathological cases (such as the pencils scene) are quickly rejected anyway !
	if(mFullBoxBoxTest || mNbVolumeBVTests==1)
	{
		t = Tz*mRBoxToModel.m[0][1] - Ty*mRBoxToModel.m[0][2];	t2 = extents.y*mAR.m[0][2] + extents.z*mAR.m[0][1] + mBB_1;	if(GREATER(t, t2))	return FALSE;	// L = A0 x B0
		t = Tz*mRBoxToModel.m[1][1] - Ty*mRBoxToModel.m[1][2];	t2 = extents.y*mAR.m[1][2] + extents.z*mAR.m[1][1] + mBB_2;	if(GREATER(t, t2))	return FALSE;	// L = A0 x B1
		t = Tz*mRBoxToModel.m[2][1] - Ty*mRBoxToModel.m[2][2];	t2 = extents.y*mAR.m[2][2] + extents.z*mAR.m[2][1] + mBB_3;	if(GREATER(t, t2))	return FALSE;	// L = A0 x B2
		t = Tx*mRBoxToModel.m[0][2] - Tz*mRBoxToModel.m[0][0];	t2 = extents.x*mAR.m[0][2] + extents.z*mAR.m[0][0] + mBB_4;	if(GREATER(t, t2))	return FALSE;	// L = A1 x B0
		t = Tx*mRBoxToModel.m[1][2] - Tz*mRBoxToModel.m[1][0];	t2 = extents.x*mAR.m[1][2] + extents.z*mAR.m[1][0] + mBB_5;	if(GREATER(t, t2))	return FALSE;	// L = A1 x B1
		t = Tx*mRBoxToModel.m[2][2] - Tz*mRBoxToModel.m[2][0];	t2 = extents.x*mAR.m[2][2] + extents.z*mAR.m[2][0] + mBB_6;	if(GREATER(t, t2))	return FALSE;	// L = A1 x B2
		t = Ty*mRBoxToModel.m[0][0] - Tx*mRBoxToModel.m[0][1];	t2 = extents.x*mAR.m[0][1] + extents.y*mAR.m[0][0] + mBB_7;	if(GREATER(t, t2))	return FALSE;	// L = A2 x B0
		t = Ty*mRBoxToModel.m[1][0] - Tx*mRBoxToModel.m[1][1];	t2 = extents.x*mAR.m[1][1] + extents.y*mAR.m[1][0] + mBB_8;	if(GREATER(t, t2))	return FALSE;	// L = A2 x B1
		t = Ty*mRBoxToModel.m[2][0] - Tx*mRBoxToModel.m[2][1];	t2 = extents.x*mAR.m[2][1] + extents.y*mAR.m[2][0] + mBB_9;	if(GREATER(t, t2))	return FALSE;	// L = A2 x B2
	}
	return TRUE;
}

//! A special version for 2 axis-aligned boxes
inline_ BOOL AABBCollider::AABBAABBOverlap(const IceMaths::Point& extents, const IceMaths::Point& center)
{
	// Stats
	mNbVolumeBVTests++;

	float tx = mBox.mCenter.x - center.x;	float ex = extents.x + mBox.mExtents.x;	if(GREATER(tx, ex))	return FALSE;
	float ty = mBox.mCenter.y - center.y;	float ey = extents.y + mBox.mExtents.y;	if(GREATER(ty, ey))	return FALSE;
	float tz = mBox.mCenter.z - center.z;	float ez = extents.z + mBox.mExtents.z;	if(GREATER(tz, ez))	return FALSE;

	return TRUE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男人电影天堂| 国产精品伦理在线| 一区二区三区资源| 国产一区 二区 三区一级| 99re热这里只有精品视频| 日韩精品一区二| 午夜精品福利一区二区蜜股av | 亚洲国产成人av| 国产91丝袜在线播放0| 日韩一区二区精品葵司在线 | 欧美精品一区二区三区高清aⅴ| 亚洲精品自拍动漫在线| 高清成人免费视频| 精品国产第一区二区三区观看体验| 亚洲一区在线看| 91一区一区三区| 国产色综合一区| 国产自产高清不卡| 日韩一二三区视频| 日本系列欧美系列| 欧美日韩一区二区电影| 亚洲精品国产无套在线观| 高清shemale亚洲人妖| 久久新电视剧免费观看| 久久国产尿小便嘘嘘尿| 欧美一区二区三区不卡| 丝袜美腿亚洲一区二区图片| 91福利小视频| 亚洲激情一二三区| 色婷婷亚洲婷婷| 国产精品久久二区二区| 国产成人欧美日韩在线电影| 久久久精品人体av艺术| 国产在线精品一区二区夜色| 欧美不卡一区二区| 蜜桃av噜噜一区二区三区小说| 欧美福利一区二区| 奇米一区二区三区av| 69成人精品免费视频| 亚洲成人av一区二区三区| 欧美亚洲禁片免费| 亚洲mv大片欧洲mv大片精品| 欧美日韩一区二区三区免费看| 亚洲一区二区三区中文字幕 | 国产一区二区精品久久91| 久久在线免费观看| 高清不卡一区二区| 亚洲图片欧美激情| 色综合久久中文字幕| 一区二区三区精品久久久| 在线观看日韩毛片| 天堂成人免费av电影一区| 欧美丰满美乳xxx高潮www| 麻豆国产欧美一区二区三区| 日韩欧美一二三四区| 国产伦精品一区二区三区视频青涩 | 国产真实乱偷精品视频免| 国产日韩一级二级三级| 9人人澡人人爽人人精品| 亚洲精品乱码久久久久| 欧美日本韩国一区二区三区视频| 视频一区中文字幕国产| 日韩欧美一级特黄在线播放| 国产精品99久久久久久有的能看| 亚洲国产精品精华液2区45| 色综合一个色综合亚洲| 婷婷久久综合九色国产成人 | 欧美日韩在线播放三区| 另类小说一区二区三区| 国产欧美一区二区精品性| 91日韩精品一区| 五月天视频一区| 久久这里只精品最新地址| 99久久精品国产一区| 午夜激情一区二区三区| 久久人人超碰精品| 色国产精品一区在线观看| 日本vs亚洲vs韩国一区三区 | 欧美v日韩v国产v| 国产精品一区二区免费不卡| 亚洲柠檬福利资源导航| 欧美电影一区二区| 高清国产一区二区三区| 亚洲第一激情av| 久久久国产精品不卡| 在线免费观看一区| 国产一区二区伦理| 亚洲无人区一区| 久久色成人在线| 在线精品视频小说1| 国产精品一线二线三线| 尤物视频一区二区| 精品对白一区国产伦| 色94色欧美sute亚洲线路一ni| 免费看欧美美女黄的网站| 中文字幕一区三区| 日韩欧美国产一区在线观看| 99久久综合国产精品| 美腿丝袜一区二区三区| 中文字幕一区二区5566日韩| 欧美一个色资源| 色中色一区二区| 国产一区二区三区精品视频| 亚洲午夜私人影院| 日本一区二区三级电影在线观看| 欧美日韩一区 二区 三区 久久精品| 国产高清精品网站| 免费观看91视频大全| 亚洲精品一二三四区| 久久九九国产精品| 欧美精品在线观看播放| 成人av在线播放网站| 久久国产福利国产秒拍| 一区二区理论电影在线观看| 日本一区二区免费在线| 日韩视频免费观看高清完整版在线观看 | 国产精品一区二区在线观看不卡| 一区二区三区产品免费精品久久75| 久久综合九色综合欧美亚洲| 在线观看国产一区二区| jlzzjlzz国产精品久久| 久久99精品国产麻豆不卡| 亚洲成人av中文| 亚洲男人天堂一区| 中文字幕一区二| 国产午夜精品一区二区三区视频 | 7777精品伊人久久久大香线蕉最新版| 成人av一区二区三区| 国产综合成人久久大片91| 美日韩一级片在线观看| 亚洲国产sm捆绑调教视频 | 欧美成人女星排名| 欧美日韩精品欧美日韩精品一综合| 99久久伊人精品| 岛国精品一区二区| 国产成人精品www牛牛影视| 精品亚洲国内自在自线福利| 日韩精品乱码免费| 亚洲一区二区成人在线观看| 亚洲天堂2016| 国产精品美日韩| 中文字幕免费不卡| 国产三级久久久| 国产网红主播福利一区二区| 精品成人免费观看| 日韩欧美在线一区二区三区| 91精品国产色综合久久不卡电影 | 久久欧美中文字幕| 久久午夜老司机| 国产亚洲短视频| 久久久久一区二区三区四区| 欧美精品一区二| 久久只精品国产| 久久久久久久久久久黄色| 久久久精品日韩欧美| 久久蜜桃av一区精品变态类天堂 | 亚洲欧美日韩在线| 日韩一区欧美一区| 亚洲欧洲www| 亚洲男同性视频| 一个色综合av| 夜夜精品浪潮av一区二区三区| 亚洲一区二区三区四区在线免费观看 | 久久夜色精品国产噜噜av| 国产亚洲综合色| 中文字幕成人网| 日韩伦理免费电影| 亚洲自拍偷拍麻豆| 丝袜诱惑亚洲看片| 精品一区二区av| 成人永久看片免费视频天堂| 成人黄动漫网站免费app| www.综合网.com| 色综合中文字幕国产| 欧美色图天堂网| 制服丝袜国产精品| 精品国产亚洲在线| 日本一区二区综合亚洲| 亚洲蜜臀av乱码久久精品| 午夜精品福利在线| 91精品国产综合久久蜜臀| 日韩欧美国产麻豆| 久久精品亚洲国产奇米99| 亚洲激情图片小说视频| 亚洲欧美日韩一区二区| 亚洲午夜久久久久久久久电影院 | 一区二区三区欧美久久| 懂色一区二区三区免费观看| 一区二区三区精密机械公司| 精品国产乱码久久| 在线看一区二区| 国产成人午夜电影网| 热久久免费视频| 亚洲欧美视频一区| 2024国产精品视频| 欧美精品乱码久久久久久 | 99riav一区二区三区| 国产在线不卡一区| 免费人成在线不卡| 亚洲一区二区在线观看视频 |