當前位置: 首頁>>代碼示例>>C++>>正文


C++ D3DXVec3Dot函數代碼示例

本文整理匯總了C++中D3DXVec3Dot函數的典型用法代碼示例。如果您正苦於以下問題:C++ D3DXVec3Dot函數的具體用法?C++ D3DXVec3Dot怎麽用?C++ D3DXVec3Dot使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了D3DXVec3Dot函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: acos

void Tank::orientTurret(float deltaX,float deltaY, float time)
{
	float anglelimit = acos(D3DXVec3Dot(&D3DXVECTOR3(0,1,0), m_tankState->GetUp()));

	yaw += deltaX*0.01f;
	if ((deltaY < 0 && pitch > -0.60 + anglelimit) || (deltaY > 0 && pitch <0.60 + anglelimit))
		pitch += deltaY*0.005f;
}
開發者ID:francislavoie,項目名稱:COMP3501-Fall2013,代碼行數:8,代碼來源:Tank.cpp

示例2: orthogonalizeAndNormalizeTangent

		void orthogonalizeAndNormalizeTangent(const D3DXVECTOR3 &tangent, const D3DXVECTOR3& normal, D3DXVECTOR3& tangentOut){
			float d = D3DXVec3Dot(&normal, &tangent);
			
			D3DXVECTOR3 newTangent = tangent - d * normal;
			D3DXVec3Normalize(&newTangent, &newTangent);
			tangentOut = newTangent;
			
		}
開發者ID:Manaluusua,項目名稱:Dx11Sandbox,代碼行數:8,代碼來源:MathUtil.cpp

示例3: D3DXVec3Dot

float CRouter::GetDistance(const D3DXVECTOR3 *vPosA, const D3DXVECTOR3 *vPosB)
{
	D3DXVECTOR3 vDif = *vPosB - *vPosA;
	D3DXVECTOR3 vPos = *vPosA;
	float fDot = D3DXVec3Dot(&vDif, &vPos);
	float fCos = fDot/(D3DXVec3Length(&vDif)*D3DXVec3Length(&vPos));
	return D3DXVec3Length(&vPos)*(sqrt(1 - fCos*fCos));
}
開發者ID:flair2005,項目名稱:vr-bike,代碼行數:8,代碼來源:Router.cpp

示例4: D3DXVec3Dot

D3DXQUATERNION Sun::QuatFromBallPoints(const D3DXVECTOR3 &vFrom, const D3DXVECTOR3 &vTo)
{
	D3DXVECTOR3 vPart;
	float fDot = D3DXVec3Dot(&vFrom, &vTo);
	D3DXVec3Cross(&vPart, &vFrom, &vTo);

	return D3DXQUATERNION(vPart.x, vPart.y, vPart.z, fDot);
}
開發者ID:ueverything,項目名稱:mmo-resourse,代碼行數:8,代碼來源:Sun.cpp

示例5: MoveBack

// Move camera backwards
void Camera::MoveBack(GameTime& gameTime)
{
	D3DXVECTOR3 forward;
	
	forward = mDirection - (D3DXVec3Dot(&mDirection, &mWorldUp) * mWorldUp);
	D3DXVec3Normalize(&forward, &forward);
	mPosition -= forward * C_MOVE_SPEED * (float)gameTime.GetTimeSinceLastTick().Seconds;
}
開發者ID:KimRestad,項目名稱:3D-II-Lab2,代碼行數:9,代碼來源:Camera.cpp

示例6: D3DXVec3Dot

void BoundingBox::getAxisProjection(D3DXVECTOR3 axis, BoundingBox* box, float& min, float& max)
{
	float val;

	min = D3DXVec3Dot(&axis, &(box->getVertex(0)));
	max = D3DXVec3Dot(&axis, &(box->getVertex(0)));

	for (int i=0; i<8; i++)
	{
		D3DXVECTOR3 as = box->getVertex(i);
		val = D3DXVec3Dot(&axis, &(box->getVertex(i)));
		if (val < min)
			min = val;
		if (val > max)
			max = val;
	}
}
開發者ID:s0n4m,項目名稱:ISM,代碼行數:17,代碼來源:BoundingBox.cpp

示例7: D3DXVec3Dot

D3DXQUATERNION ArcBall::QuatFromBallPoints(const D3DXVECTOR3 &vFrom, const D3DXVECTOR3 &vTo)
{
	D3DXVECTOR3 vPart;
	float fDot = D3DXVec3Dot( &vFrom, &vTo );	// rotation angle
	D3DXVec3Cross( &vPart, &vFrom, &vTo );		// rotation axis

	return D3DXQUATERNION( vPart.x, vPart.y, vPart.z, fDot );
}
開發者ID:Clearlove1992,項目名稱:GraphicsDemos,代碼行數:8,代碼來源:ArcBall.cpp

示例8: calcSphereTriangleDistance

static inline void calcSphereTriangleDistance(
    Sphere* sphere,
    Vector* normal,
    Vector* v0, Vector* v1, Vector* v2,
    Vector* collPoint,
    float* distance 
)
{
    // project sphere center onto plane of triangle.
    Vector* center = &sphere->center;
    Vector  projPoint;
    float   dist2plane = D3DXVec3Dot( v0, normal ) - D3DXVec3Dot( center, normal );
    D3DXVec3Scale( &projPoint, normal, dist2plane );
    D3DXVec3Add( &projPoint, &projPoint, center );

    // does the projected point lie within the collision triangle?
    Vector* vertices[3];
    vertices[0] = v0, vertices[1] = v1, vertices[2] = v2;
    if( isPointWithinTriangle( &projPoint, vertices, normal ) )
    {
        *distance = fabs( dist2plane );
        *collPoint = projPoint;
        return;
    }
    // projected point lies outside the triangle, so find the nearest
    // point on the triangle boundary...
    else
    {
        float currdist;
        Vector closestPoint, temp;
    
        findNearestPointOnLine( &closestPoint, &projPoint, v0, v1 );
        D3DXVec3Subtract( &temp, center, &closestPoint );
        *distance = D3DXVec3Length(&temp), *collPoint = closestPoint;

        findNearestPointOnLine( &closestPoint, &projPoint, v1, v2 );
        D3DXVec3Subtract(&temp, center, &closestPoint);
        currdist = D3DXVec3Length(&temp);
        if( *distance > currdist ) *distance = currdist, *collPoint = closestPoint;

        findNearestPointOnLine( &closestPoint, &projPoint, v0, v2 );
        D3DXVec3Subtract(&temp, center, &closestPoint);
        currdist = D3DXVec3Length(&temp);
        if( *distance > currdist ) *distance = currdist, *collPoint = closestPoint;
    }
}
開發者ID:cheinkn,項目名稱:basextreme,代碼行數:46,代碼來源:collision.cpp

示例9: D3DXVec3Normalize

//**関數***************************************************************************
//	概要	:	反射計算
//*********************************************************************************
void CCalc::Bound3D(CBoundData* boundA , CBoundData* boundB)
{
	D3DXVECTOR3 VelA , VelB;

	D3DXVECTOR3 VecAtoB;					// オブジェクトの方向
	D3DXVECTOR3 VecBtoA;					// オブジェクトの方向

	D3DXVECTOR3 vecBuf;
	float		fBuf;						// 計算用バッファ

	VelA = boundA->m_Velocity;
	VelB = boundB->m_Velocity;
	float fWaA = boundA->m_fMass;
	float fWaB = boundB->m_fMass;
	float fBou = boundA->m_fBounds;

	// オブジェクトの衝突方向を計算
	VecAtoB = boundB->m_Pos - boundA->m_Pos;	// AからBへのベクトル
	D3DXVec3Normalize(&VecAtoB , &VecAtoB);
	VecBtoA = boundA->m_Pos - boundB->m_Pos;	// BからAへのベクトル
	D3DXVec3Normalize(&VecBtoA , &VecBtoA);

	// Aの速度ベクトルを分解
	fBuf = D3DXVec3Dot(&VelA , &VecAtoB);
	VecAtoB = VecAtoB * fBuf;					// 分解したベクトルを保存
	VelA -= VecAtoB;							// 継続して持つベクトルを逃がす
	
	// Bの速度ベクトル
	fBuf = D3DXVec3Dot(&VelB , &VecBtoA);
	VecBtoA = VecBtoA * fBuf;
	VelB -= VecBtoA;

	// ベクトル計算	
	boundA->m_Velocity = ((fWaA - fBou * fWaB) * VecAtoB + ((1 + fBou) * fWaB * VecBtoA)) / (fWaA + fWaB);
	boundB->m_Velocity = ((fWaB - fBou * fWaA) * VecBtoA + ((1 + fBou) * fWaA * VecAtoB)) / (fWaB + fWaA);
	boundA->m_Velocity += VelA;
	boundB->m_Velocity += VelB;

	// 衝突回避位置に移動
	D3DXVECTOR3 vec = boundB->m_Pos - boundA->m_Pos;
	D3DXVec3Normalize(&vec , &vec);
	boundB->m_Pos.x = boundA->m_Pos.x + vec.x * (boundA->m_fRadius + boundB->m_fRadius + 0.5f);
	boundB->m_Pos.y = boundA->m_Pos.y + vec.y * (boundA->m_fRadius + boundB->m_fRadius + 0.5f);
	boundB->m_Pos.z = boundA->m_Pos.z + vec.z * (boundA->m_fRadius + boundB->m_fRadius + 0.5f);
}
開發者ID:FujiokaNaoto,項目名稱:DirectX_Base,代碼行數:48,代碼來源:Calc.cpp

示例10: intersect_plane

bool intersect_plane ( const D3DXVECTOR3& start, const D3DXVECTOR3& dir,  const D3DXVECTOR3& pt, D3DXVECTOR3& ret )
{
	const D3DXVECTOR3& n = cache.normal;
	float denom = D3DXVec3Dot ( &n,&dir );

	if ( denom <= -EPSILON || denom >= EPSILON )
	{
		float numer = D3DXVec3Dot ( &n,&( pt - start ) );
		float u = numer / denom;

		if ( u > 0 && u <= 1.0f )
		{
			ret = start + dir * u;
			return true;
		}
	}
	return false;
}
開發者ID:Fliper12,項目名稱:darkbasicpro,代碼行數:18,代碼來源:Collision.cpp

示例11: Reflect

D3DXVECTOR3	Reflect(const D3DXVECTOR3* pN,	const D3DXVECTOR3* pD)
{
	D3DXVECTOR3	n	= *pN;
	D3DXVECTOR3	d	= *pD;
	D3DXVec3Normalize( &n, &n );
	float fDot	= D3DXVec3Dot( &n, &(-d) );
	
	return	2*fDot*n + d;
}
開發者ID:serialkk,項目名稱:sexyspike3,代碼行數:9,代碼來源:DEFAULT_INLINE.cpp

示例12: D3DXVec3Normalize

void Camera::UpdateViewMatrix()
{
	D3DXVec3Normalize(&m_look, &m_look);
	D3DXVec3Cross(&m_up, &m_look, &m_right);
	D3DXVec3Normalize(&m_up, &m_up);
	D3DXVec3Cross(&m_right, &m_up, &m_look);
	D3DXVec3Normalize(&m_right, &m_right);

	float x = -D3DXVec3Dot(&m_right, &m_position);
	float y = -D3DXVec3Dot(&m_up, &m_position);
	float z = -D3DXVec3Dot(&m_look, &m_position);

	m_matView = D3DXMATRIX(
		m_right.x, m_up.x, m_look.x, 0.0f,
		m_right.y, m_up.y, m_look.y, 0.0f,
		m_right.z, m_up.z, m_look.z, 0.0f,
		x,         y,      z,        1.0f);
}
開發者ID:tcye,項目名稱:DXEngine,代碼行數:18,代碼來源:Camera.cpp

示例13: D3DXVec3Dot

//////////////////////////////////////////////////////////////////////////
//	setDirection
//	(desc) return rotation matrix to match shadow object's normal to input direction
//	+ helper function
//////////////////////////////////////////////////////////////////////////
rmatrix ZShadow::setDirection( rvector& dir_ )
{
	rmatrix xRotMat;
	rmatrix yRotMat;

	rvector xVector = dir_;
	xVector.y = 0;
	float xtheta = D3DXVec3Dot( &mNormal, &xVector );

	rvector yVector = dir_;
	yVector.x = 0;
	float yTheta = D3DXVec3Dot( &mNormal, &yVector );

	D3DXMatrixRotationX( &xRotMat, xtheta );
	D3DXMatrixRotationY( &yRotMat, yTheta );

	return xRotMat*yRotMat;
}
開發者ID:Kallontz,項目名稱:gunz-the-tps-mmorpg,代碼行數:23,代碼來源:ZShadow.cpp

示例14: mPosition

Camera::Camera(D3DXVECTOR3 position, D3DXVECTOR3 direction, D3DXVECTOR3 worldUp, const Frustum& viewFrustum)
	: mPosition(position), mDirection(direction), mWorldUp(worldUp), mZoom(-200.0f)
{
	mPosition = mPosition - (D3DXVec3Dot(&mPosition, &mWorldUp) * mWorldUp);
	mDestination = mPosition;

	D3DXVec3Normalize(&mDirection, &mDirection);
	CreateProjectionMatrix(viewFrustum);
}
開發者ID:rarosu,項目名稱:BTH-Gomoku,代碼行數:9,代碼來源:Camera.cpp

示例15: RayToTriangle

// funkcja z TFQE
// kod do backface cullingu zakomentowany, lepiej daæ to jako osonn¹ funkcjê
// zwraca ujemn¹ wartoœæ jeœli przecina promieñ od ty³u
bool RayToTriangle(const VEC3& _ray_pos, const VEC3& _ray_dir, const VEC3& _v1, const VEC3& _v2, const VEC3& _v3, float& _dist)
{
	////// Nowy, piêkny algorytm :)
	// Znaleziony w Google Code Search:
	// http://www.google.com/codesearch?hl=en&q=+RayTriangleIntersect+show:M63-4o6bYUI:fUr9QIwtaKY:Dw059DARM5E&sa=N&cd=1&ct=rc&cs_p=http://www.angstrom-distribution.org/unstable/sources/ode-snapshot-20060210.tar.bz2&cs_f=ode-snapshot-20060210/ode/src/collision_trimesh_trimesh.cpp#first
	// Dopisa³em do niego Backface Culling, dzia³a bez problemu :D

	VEC3 tvec, pvec, qvec;

	// find vectors for two edges sharing vert0
	VEC3 edge1 = _v2 - _v1;
	VEC3 edge2 = _v3 - _v1;

	// begin calculating determinant - also used to calculate U parameter
	D3DXVec3Cross(&pvec, &_ray_dir, &edge2);

	// if determinant is near zero, ray lies in plane of triangle
	float det = D3DXVec3Dot(&edge1, &pvec);
	//if (BackfaceCulling && det < 0.0f)
	//	return false;
	if (FLOAT_ALMOST_ZERO(det))
		return false;
	float inv_det = 1.0f / det;

	// calculate distance from vert0 to ray origin
	tvec = _ray_pos - _v1;

	// calculate U parameter and test bounds
	float u = D3DXVec3Dot(&tvec, &pvec) * inv_det;
	if (u < 0.0f || u > 1.0f)
		return false;

	// prepare to test V parameter
	D3DXVec3Cross(&qvec, &tvec, &edge1);

	// calculate V parameter and test bounds
	float v = D3DXVec3Dot(&_ray_dir, &qvec) * inv_det;
	if (v < 0.0f || u + v > 1.0f)
		return false;

	// calculate t, ray intersects triangle
	_dist = D3DXVec3Dot(&edge2, &qvec) * inv_det;
	return true;
}
開發者ID:edeksumo,項目名稱:carpg,代碼行數:47,代碼來源:Base.cpp


注:本文中的D3DXVec3Dot函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。