本文整理匯總了C++中D3DXVec3TransformNormal函數的典型用法代碼示例。如果您正苦於以下問題:C++ D3DXVec3TransformNormal函數的具體用法?C++ D3DXVec3TransformNormal怎麽用?C++ D3DXVec3TransformNormal使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了D3DXVec3TransformNormal函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: D3DXVec3TransformCoord
void ReflRender::BeginRT(Engine& engine, const RtFlags& flags)
{
const DWORD cClipPlanes[6] = {D3DCLIPPLANE0, D3DCLIPPLANE1, D3DCLIPPLANE2, D3DCLIPPLANE3, D3DCLIPPLANE4, D3DCLIPPLANE5};
_MyBase::BeginRT(engine, flags);
CameraDesc desc = engine.GetContext().GetCamera().GetDesc();
D3DXVec3TransformCoord(&desc.pos, &desc.pos, &_reflMat);
D3DXVec3TransformNormal(&desc.dir, &desc.dir, &_reflMat);
D3DXVec3TransformNormal(&desc.up, &desc.up, &_reflMat);
desc.up = -desc.up;
_reflCamera.SetDesc(desc);
//reflCamera.AdjustFarPlane(sceneBox, maxFarDist);
engine.GetContext().ApplyCamera(&_reflCamera);
DWORD enableClipPlanes = cClipPlanes[0];
engine.GetDriver().GetDevice()->SetClipPlane(0, _reflPlane);
LSL_ASSERT(_clipPlanes.size() <= 5);
for (unsigned i = 0; i < _clipPlanes.size(); ++i)
{
enableClipPlanes |= cClipPlanes[i + 1];
engine.GetDriver().GetDevice()->SetClipPlane(i + 1, _clipPlanes[i]);
}
engine.GetContext().SetRenderState(rsClipPlaneEnable, enableClipPlanes);
ApplyRT(engine, flags);
}
示例2: D3DXMatrixRotationZ
void CElementManager::CreateCircle(const D3DXVECTOR3& pos, FLOAT intensity, const SMap *map,
FLOAT lastTime, FLOAT length, INT max, DWORD color, BOOL isPlayer)
{
D3DXVECTOR3 dir;
D3DXMATRIX trans;
if (intensity > 1.f) intensity = 1.f;
INT cnt = static_cast<INT>(max*intensity+0.5f);
D3DXMatrixRotationZ(&trans, 2*D3DX_PI/cnt);
UINT t;
do {
rand_s(&t);
dir.x = t%10-5.f;
rand_s(&t);
dir.y = t%10-5.f;
} while (dir.x == 0.f && dir.y == 0.f);
dir.z = 0.f;
D3DXVec3Normalize(&dir, &dir);
if (isPlayer)
for (INT i(0); i < cnt; ++i) {
D3DXVec3TransformNormal(&dir, &dir, &trans);
m_pEcho.push_back(new CLine(pos, dir,
intensity, map, intensity <= 2.f/9, lastTime, length, color));
}
else
for (INT i(0); i < cnt; ++i) {
D3DXVec3TransformNormal(&dir, &dir, &trans);
m_pAmbience.push_back(new CLine(pos, dir,
intensity, map, intensity <= 2.f/9, lastTime, length, color));
}
}
示例3: D3DXVec3TransformCoord
void BoundingBox::Transform(const D3DXMATRIX& m)
{
D3DXVec3TransformCoord(¢er, ¢er, &m);
D3DXVec3TransformNormal(&vx, &vx, &m);
D3DXVec3TransformNormal(&vy, &vy, &m);
D3DXVec3TransformNormal(&vz, &vz, &m);
}
示例4: D3DXVECTOR3
//just rotate lights a little in place
void Scene::UpdateLights(double fTime)
{
D3DXVECTOR3 offAngleVec3 = D3DXVECTOR3(1, -4, 0);
D3DXMATRIX rotY;
D3DXVECTOR3 dir;
D3DXVec3Normalize(&offAngleVec3, &offAngleVec3);
D3DXMatrixRotationY(&rotY, (float)(fTime / 4.f) * 3.14159265f);
D3DXVec3TransformNormal(&dir, &offAngleVec3, &rotY);
m_lights[0].vLightDir = dir;
D3DXVec3Normalize(&offAngleVec3, &offAngleVec3);
D3DXMatrixRotationY(&rotY, (float)(-fTime / 3.f) * 3.14159265f);
D3DXVec3TransformNormal(&dir, &offAngleVec3, &rotY);
m_lights[1].vLightDir = dir;
D3DXVec3Normalize(&offAngleVec3, &offAngleVec3);
D3DXMatrixRotationY(&rotY, (float)(fTime / 2.f) * 3.14159265f);
D3DXVec3TransformNormal(&dir, &offAngleVec3, &rotY);
m_lights[2].vLightDir = dir;
D3DXVec3Normalize(&offAngleVec3, &offAngleVec3);
D3DXMatrixRotationY(&rotY, (float)(-fTime / 4.f) * 3.14159265f);
D3DXVec3TransformNormal(&dir, &offAngleVec3, &rotY);
m_lights[3].vLightDir = dir;
}
示例5: D3DXMatrixRotationAxis
void Camera::Pitch( float angle )
{
D3DXMATRIX R;
D3DXMatrixRotationAxis(&R, &mRight, angle);
D3DXVec3TransformNormal(&mUp, &mUp, &R);
D3DXVec3TransformNormal(&mLook, &mLook, &R);
}
示例6: D3DXMatrixRotationAxis
void Camera::Pitch(float _angle)
{
D3DXMATRIX p;
D3DXMatrixRotationAxis(&p, &right, _angle);
D3DXVec3TransformNormal(&up, &up, &p);
D3DXVec3TransformNormal(&look, &look, &p);
}
示例7: D3DXMatrixRotationY
void Camera::RotateY( float angle )
{
D3DXMATRIX R;
D3DXMatrixRotationY(&R, angle);
D3DXVec3TransformNormal(&mRight, &mRight, &R);
D3DXVec3TransformNormal(&mUp, &mUp, &R);
D3DXVec3TransformNormal(&mLook, &mLook, &R);
}
示例8: D3DXMatrixRotationY
void Camera::rotateY(float angle)
{
D3DXMATRIX rotation;
D3DXMatrixRotationY(&rotation,angle);
D3DXVec3TransformNormal(&right,&right,&rotation);
D3DXVec3TransformNormal(&up,&up,&rotation);
D3DXVec3TransformNormal(&look,&look,&rotation);
}
示例9: D3DXMatrixRotationAxis
void Camera::pitch(float angle)
{
D3DXMATRIX rotation;
D3DXMatrixRotationAxis(&rotation,&right,angle);
D3DXVec3TransformNormal(&up,&up,&rotation);
D3DXVec3TransformNormal(&look,&look,&rotation);
}
示例10: D3DXMatrixRotationY
void Camera::RotateY(float _angle)
{
D3DXMATRIX r;
D3DXMatrixRotationY(&r, _angle);
D3DXVec3TransformNormal(&right, &right, &r);
D3DXVec3TransformNormal(&up, &up, &r);
D3DXVec3TransformNormal(&look, &look, &r);
}
示例11: D3DXMatrixTranslation
Ray OBB::GetContactPoint(Ray &ray) {
D3DXMATRIX p, r, world, invWorld;
D3DXMatrixTranslation(&p, m_pos.x, m_pos.y, m_pos.z);
D3DXMatrixRotationQuaternion(&r, &m_rot);
D3DXMatrixMultiply(&world, &r, &p);
D3DXMatrixInverse(&invWorld, NULL, &world);
D3DXVECTOR3 org, dir;
D3DXVec3TransformCoord(&org, &ray.m_org, &invWorld);
D3DXVec3TransformNormal(&dir, &ray.m_dir, &invWorld);
D3DXPLANE planes[] = {D3DXPLANE(0.0f, 0.0f, -1.0f, -m_size.z),
D3DXPLANE(0.0f, 0.0f, 1.0f, -m_size.z),
D3DXPLANE(0.0f, -1.0f, 0.0f, -m_size.y),
D3DXPLANE(0.0f, 1.0f, 0.0f, -m_size.y),
D3DXPLANE(-1.0f, 0.0f, 0.0f, -m_size.x),
D3DXPLANE(1.0f, 0.0f, 0.0f, -m_size.x)
};
D3DXVECTOR3 result, normal;
int numPlanes = 0;
int numIntersections = 0;
for (int i=0; i<6; i++) {
float d = org.x * planes[i].a +
org.y * planes[i].b +
org.z * planes[i].c;
if (d > -planes[i].d) {
D3DXVECTOR3 r;
if (D3DXPlaneIntersectLine(&r, &planes[i], &org, &(org + dir * 1000.0f)) != NULL) {
numPlanes++;
if (abs(r.x) <= m_size.x &&
abs(r.y) <= m_size.y &&
abs(r.z) <= m_size.z) {
D3DXVec3TransformCoord(&r, &r, &world);
result = r;
normal = D3DXVECTOR3(planes[i].a, planes[i].b, planes[i].c);
numIntersections++;
}
}
}
}
if (numIntersections == 0) {
//Warning! OBB No Intersections!
return Ray(ray.m_org, -ray.m_dir);
}
D3DXVec3Normalize(&normal, &normal);
D3DXVec3TransformNormal(&normal, &normal, &world);
return Ray(result, normal);
}
示例12: D3DXMatrixRotationAxis
void CPlayer::Rotate(float x, float y, float z)
{
D3DXMATRIX mtxRotate;
DWORD nCurrentCameraMode = m_pCamera->GetMode();
// 1인칭 카메라 또는 3인칭 카메라의 경우 플레이어의 회전은 약간의 제약이 따름
if ((nCurrentCameraMode == FIRST_PERSON_CAMERA) || (nCurrentCameraMode == THIRD_PERSON_CAMERA))
{
// 로컬 x축을 중심으로 회전 회전각도는 -89.0 ~ 89.0 사이로 제한.
//if (x != 0.0f)
//{
// m_fPitch += x;
// if (m_fPitch > +89.0f) { x -= (m_fPitch - 89.0f); m_fPitch = +89.0f; }
// if (m_fPitch < -89.9f) { x -= (m_fPitch + 89.0f); m_fPitch = -89.0f; }
//}
//// 로컬 y축을 중심으로 회전 회전각도 제한없음
//if (y != 0.0f)
//{
// //m_fYaw += y;
// if (m_fYaw > 360.0f) m_fYaw -= 360.0f;
// if (m_fYaw < 0.0f) m_fYaw += 360.0f;
//}
//// 로컬 z축 회전 몸통을 좌우로 기울이는 것 회전각도는 -20 ~ 20 사이로 제한
//// z는 현재 m_fRoll에서 실제 회전하는 각도 z만큼 회전
//if (z != 0.0f)
//{
// m_fRoll += z;
// if (m_fRoll > 20.0f) { z -= (m_fRoll - 20.0f); m_fRoll = +20.0f; }
// if (m_fRoll < -20.0f) { z -= (m_fRoll + 20.0f); m_fRoll = -20.0f; }
//}
// 카메라를 x y z 만큼 회전. 플레이어가 회전하면 카메라가 회전
m_pCamera->Rotate(x, y, z);
if (y != 0.0f)
{
D3DXMatrixRotationAxis(&mtxRotate, &m_d3dxvUp, (float)D3DXToRadian(y));
D3DXVec3TransformNormal(&m_d3dxvLook, &m_d3dxvLook, &mtxRotate);
D3DXVec3TransformNormal(&m_d3dxvRight, &m_d3dxvRight, &mtxRotate);
}
}
// 회전으로 인해 플레이어의 로컬 축이 서로 직교하지 않을수 잇으므로 z축을 기준으로
// 서로 직교하고 단위벡터가 되도록 한다.
D3DXVec3Normalize(&m_d3dxvLook, &m_d3dxvLook);
D3DXVec3Cross(&m_d3dxvRight, &m_d3dxvUp, &m_d3dxvLook);
D3DXVec3Normalize(&m_d3dxvRight, &m_d3dxvRight);
D3DXVec3Cross(&m_d3dxvUp, &m_d3dxvLook, &m_d3dxvRight);
D3DXVec3Normalize(&m_d3dxvUp, &m_d3dxvUp);
RegenerateWorldMatrix();
}
示例13: D3DXMatrixRotationYawPitchRoll
void DX10_Camera_FirstPerson::Process(float _dt)
{
// Get mouse input
//m_pDirectInput->DetectMouseInput(&m_yawChange, &m_pitchChange);
m_yaw += m_yawChange * _dt;
m_pitch += m_pitchChange * _dt;
// Prevent Gimbal Lock
if (m_pitch > m_maxRotation)
{
m_pitch = m_maxRotation;
}
if (m_pitch < m_minRotation)
{
m_pitch = m_minRotation;
}
// Create a full rotation matrix
D3DXMatrixRotationYawPitchRoll(&m_rotationMatrix, m_yaw, m_pitch, 0);
D3DXVec3TransformCoord(&m_target, &m_defaultForward, &m_rotationMatrix);
D3DXVec3Normalize(&m_target, &m_target);
// Calculate a Yaw rotation matrix
D3DXMATRIX RotateYTempMatrix;
D3DXMatrixRotationY(&RotateYTempMatrix, m_yaw);
// Update the Local camera Axis around the Y axis
D3DXVec3TransformNormal(&m_right, &m_defaultRight, &RotateYTempMatrix);
D3DXVec3TransformNormal(&m_up, &m_up, &RotateYTempMatrix);
D3DXVec3TransformNormal(&m_forward, &m_defaultForward, &RotateYTempMatrix);
// Adjust the position
m_position += m_moveStrafe * m_right * _dt;
m_position += m_moveForwards * m_forward * _dt;
m_position += m_moveFly * m_up * _dt;
// reset the the movement values
m_moveStrafe = 0.0f;
m_moveForwards = 0.0f;
m_moveFly = 0.0f;
m_yawChange = 0.0f;
m_pitchChange = 0.0f;
// Pick a target in front of the camera
m_target = m_position + m_target;
// Create the View matrix
D3DXMatrixLookAtLH(&m_matView, &m_position, &m_target, &m_up);
m_pRenderer->SetViewMatrix(m_matView);
m_pRenderer->SetEyePosition(m_position);
}
示例14: D3DXMatrixRotationAxis
void FpsCamera::rotate(float x, float y)
{
Matrix rotateX, rotateY;
D3DXMatrixRotationAxis(&rotateX, &m_right, x * m_delta);
D3DXMatrixRotationY(&rotateY, y * m_delta);
Matrix total;
D3DXMatrixMultiply(&total, &rotateX, &rotateY);
D3DXVec3TransformNormal(&m_right, &m_right, &total);
D3DXVec3TransformNormal(&m_up, &m_up, &total);
D3DXVec3TransformNormal(&m_view, &m_view, &total);
normalize();
buildView();
}
示例15: assert
void RayIntersection::intersect(engine::IAtomic* atomic, engine::CollisionCallBack callBack, void* data)
{
_callBack = callBack;
_callBackData = data;
_bsp = NULL;
_bspSector = NULL;
_atomic = dynamic_cast<Atomic*>( atomic ); assert( _atomic );
assert( _atomic->_geometry->getOcTreeRoot() );
_geometry = _atomic->_geometry;
_vertices = _geometry->getVertices();
_triangles = _geometry->getTriangles();
if( _atomic->_frame->isDirtyHierarchy() )
{
_atomic->_frame->synchronizeSafe();
}
// transform ray to atomic space
Matrix iLTM;
D3DXMatrixInverse( &iLTM, NULL, &_atomic->_frame->LTM );
D3DXVec3TransformCoord( &_asRay.start, &_ray.start, &iLTM );
D3DXVec3TransformNormal( &_asRay.end, &_ray.end, &iLTM );
collideAtomicOcTreeSector( _geometry->getOcTreeRoot() );
}