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


C++ D3DXMatrixRotationZ函數代碼示例

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


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

示例1: D3DXMatrixIdentity

/**
* Updates the roll matrix, seems to be senseless right now, just calls D3DXMatrixRotationZ().
* @param roll Angle of rotation, in radians.
***/
void ViewAdjustment::UpdateRoll(float roll)
{
	D3DXMatrixIdentity(&rollMatrix);
	D3DXMatrixRotationZ(&rollMatrix, roll);
	D3DXMatrixRotationZ(&rollMatrixNegative, -roll);
	D3DXMatrixRotationZ(&rollMatrixHalf, roll * 0.5f);
}
開發者ID:DrBeef,項目名稱:Perception,代碼行數:11,代碼來源:ViewAdjustment.cpp

示例2: D3DXMatrixRotationZ

D3DXMATRIX CParticle::GetRotateMatrix()
{
	D3DXMATRIX d3dRotX,d3dRotY,d3dRotZ;
	D3DXMatrixRotationZ(&d3dRotX,D3DXToRadian(m_d3dCurRotation[0]));
	D3DXMatrixRotationZ(&d3dRotY,D3DXToRadian(m_d3dCurRotation[1]));
	D3DXMatrixRotationZ(&d3dRotZ,D3DXToRadian(m_d3dCurRotation[2]));
	return d3dRotX*d3dRotY*d3dRotZ;
}
開發者ID:ianalcid08,項目名稱:FinalProject,代碼行數:8,代碼來源:Particle.cpp

示例3: D3DXMatrixRotationZ

void Tree::LineRender(D3DXVECTOR3 start, D3DXVECTOR3 dir, int deep)
{
	Line line;
	line.Draw(start, start + dir);

	float d = 0.8;
	float angle = 30;	//変更

	D3DXMATRIX right, left;
	D3DXVECTOR3 vec;
	D3DXVECTOR3 vR, vL;

	//start = start + dir;

	vec = dir;
	D3DXMatrixRotationZ(&right, D3DXToRadian(-angle));
	D3DXVec3TransformCoord(&vec, &dir, &right);
	vec *= d;
	line.Draw(start + dir, start + dir + vec);
	vR = vec;

	vec = dir;
	D3DXMatrixRotationZ(&left, D3DXToRadian(angle));
	D3DXVec3TransformCoord(&vec, &dir, &left);
	vec *= d;
	line.Draw(start + dir, start + dir + vec);
	vL = vec;

	if (deep >= 1)
	{
		vec = vR;
		D3DXMatrixRotationZ(&right, D3DXToRadian(-angle));
		D3DXVec3TransformCoord(&vec, &vec, &right);
		vec *= d;
		LineRender(start + dir + vR, vec, deep - 1);

		vec = vL;
		D3DXMatrixRotationZ(&left, D3DXToRadian(angle));
		D3DXVec3TransformCoord(&vec, &vec, &left);
		vec *= d;
		LineRender(start + dir + vL, vec, deep - 1);
	}

	//start = start + vec;
	//Hello
	//メッセージ

}
開發者ID:140447ESASHISEIYA,項目名稱:Test,代碼行數:48,代碼來源:Tree.cpp

示例4: int

void GegnerColumn::DoDraw(void)
{
    D3DXMATRIX	matWorld, matRot, matTrans, matTrans2;	// Rotations und Translations Matrizen
    int			Winkel;									// Rotationswinkel

    Winkel = int(AnimCount);

    // Winkel angleichen, damit er immer zwischen 0° und 360° bleibt
    //
    if (Winkel > 360) Winkel -= 360;
    if (Winkel < 0)	  Winkel += 360;
    D3DXMatrixRotationZ  (&matRot, DegreetoRad[Winkel]);

    D3DXMatrixTranslation(&matTrans, float (-(xPos-pTileEngine->XOffset+40)),float (-(yPos-pTileEngine->YOffset+100)), 0.0f);		// Transformation zum Ursprung
    D3DXMatrixTranslation(&matTrans2,float   (xPos-pTileEngine->XOffset+40), float (  yPos-pTileEngine->YOffset+100),  0.0f);		// Transformation wieder zurück

    D3DXMatrixIdentity	 (&matWorld);
    D3DXMatrixMultiply	 (&matWorld, &matWorld, &matTrans);		// Verschieben
    D3DXMatrixMultiply	 (&matWorld, &matWorld, &matRot);			// rotieren
    D3DXMatrixMultiply	 (&matWorld, &matWorld, &matTrans2);		// und wieder zurück verschieben

    // rotierte Matrix setzen
#if defined(PLATFORM_DIRECTX)
    lpD3DDevice->SetTransform(D3DTS_WORLD, &matWorld);
#elif defined(PLATFORM_SDL)
    g_matModelView = matWorld * g_matView;
#if defined(USE_GL1)
    load_matrix( GL_MODELVIEW, g_matModelView.data() );
#endif
#endif


    pGegnerGrafix[GegnerArt]->RenderSprite ((float)(xPos-pTileEngine->XOffset),
                                            (float)(yPos-pTileEngine->YOffset), 0, 0xFFFFFFFF);

    // Normale Projektions-Matrix wieder herstellen
    D3DXMatrixRotationZ (&matWorld, 0.0f);
#if defined(PLATFORM_DIRECTX)
    lpD3DDevice->SetTransform(D3DTS_WORLD, &matWorld);
#elif defined(PLATFORM_SDL)
    g_matModelView = matWorld * g_matView;
#if defined(USE_GL1)
    load_matrix( GL_MODELVIEW, g_matModelView.data() );
#endif
#endif

    SetScreenShake();
}
開發者ID:NebuPookins,項目名稱:hurrican,代碼行數:48,代碼來源:Trigger_Column.cpp

示例5: D3DXMatrixTranslation

void GameObject::Update( float fDT )
{
	if( m_pMeshObject )
	{
		if( !m_bUseMatrix )
		{
			D3DXMATRIX MatrixTrans;			
			D3DXMatrixTranslation( &MatrixTrans, m_vPosition.x, m_vPosition.y, m_vPosition.z );

			D3DXMATRIX MatrixRotateX, MatrixRotateY, MatrixRotateZ;
			D3DXMatrixRotationX( &MatrixRotateX, m_AngleXYZ.x );
			D3DXMatrixRotationY( &MatrixRotateY, m_AngleXYZ.y );
			D3DXMatrixRotationZ( &MatrixRotateZ, m_AngleXYZ.z );
			D3DXMATRIX MatrixRotate  = MatrixRotateX * MatrixRotateY * MatrixRotateZ;
			m_MatrixRelease = MatrixRotate * MatrixTrans;

			// если есть предок, то сначала берём его матрицу
			if( m_pObjectParent )
				m_MatrixRelease = m_MatrixRelease * m_pObjectParent->GetReleaseMatrix();
		}		
	}

	for( std::list< GameObject* >::iterator iter = m_ObjectChild.begin(); iter != m_ObjectChild.end(); ++iter )
	{
		(*iter)->Update( fDT );
	}	
}
開發者ID:Dimiondark,項目名稱:testxo,代碼行數:27,代碼來源:GameObject.cpp

示例6: SetTransform

//---------------------------------------
//NAME : SetTransform()
//DESC : 坐標轉換
//---------------------------------------
void SetTransform()
{
	//設置世界變換矩陣
	D3DXMATRIX matWorld,Rx,Ry,Rz;
	D3DXMatrixIdentity(&matWorld);//單位矩陣
	D3DXMatrixRotationX(&Rx,::timeGetTime()/1000.f);//繞x軸旋轉
	D3DXMatrixRotationY(&Ry,::timeGetTime()/1000.f);//繞y軸旋轉
	D3DXMatrixRotationZ(&Rz,::timeGetTime()/1000.f);//繞z軸旋轉

	matWorld=Rx*Ry*Rz*matWorld;
	g_pd3dDevice->SetTransform(D3DTS_WORLD,&matWorld);

	//設置取景變換矩陣
	D3DXMATRIX matView;
	D3DXVECTOR3 vEye(0.0f,0.0f,-30.0f);
	D3DXVECTOR3 vAt(0.0f,0.0f,0.0f);
	D3DXVECTOR3 vUp(0.0f,1.0f,0.0f);
	D3DXMatrixLookAtLH(&matView,&vEye,&vAt,&vUp);
	g_pd3dDevice->SetTransform(D3DTS_VIEW,&matView);

	//設置投影變換矩陣
	D3DXMATRIX matProj;
	D3DXMatrixPerspectiveFovLH(&matProj,D3DX_PI/4.0f,1.0f,1.0f,1000.0f);
	g_pd3dDevice->SetTransform(D3DTS_PROJECTION,&matProj);
}
開發者ID:haozzzzzzzz,項目名稱:Direct3D_Transform,代碼行數:29,代碼來源:transform.cpp

示例7: D3DXMatrixScaling

void MenuObjects::Update()
{
	if(mScale.x > 1.0f)
	{
		mScale.x -= gDeltaTime * 0.5f;
		mScale.y -= gDeltaTime * 0.5f;
		mScale.z -= gDeltaTime * 0.5f;
	}
	if(miniSelector == mId - 1)
	{
		mRotated = false;
	}

	if(miniSelector != mId - 1)
	{
		if(((int)(mRotation.y * (180 / PI)) % 90) == 0)
		{
			mRotated = true;
		}
	}
	D3DXMatrixScaling(&S, mScale.x, mScale.y, mScale.z);
	D3DXMatrixRotationX(&Rx, mRotation.x);
	D3DXMatrixRotationY(&Ry, mRotation.y);
	D3DXMatrixRotationZ(&Rz, mRotation.z);
	D3DXMatrixTranslation(&T, mPosition.x, mPosition.y, mPosition.z);
	W = S * Rx * Ry * Rz * T;
}
開發者ID:WhaleCurrent,項目名稱:Projektet,代碼行數:27,代碼來源:MenuObjects.cpp

示例8: D3DXMatrixIdentity

void MyMesh::RotateZ(FLOAT q)
{
	D3DXMATRIX rot;
	D3DXMatrixIdentity(&rot);
	D3DXMatrixRotationZ(&rot, q);
	rotationMatrix = rotationMatrix * rot;
}
開發者ID:koguz,項目名稱:DirectX-Space-Game,代碼行數:7,代碼來源:MyMesh.cpp

示例9: SetMatrix

void SetMatrix(void)
{
	//世界變換矩陣的設置  
	D3DXMATRIX matWorld, rx, ry, rz;
	D3DXMatrixIdentity(&matWorld);
	D3DXMatrixRotationX(&rx, PI * (timeGetTime() / 1000.0f));
	D3DXMatrixRotationY(&ry, PI * (timeGetTime() / 1000.0f) / 2.0f);
	D3DXMatrixRotationZ(&rz, PI * (timeGetTime() / 1000.0f) / 3.0f);
	matWorld = rx * ry * rz * matWorld;
	g_pDevice->SetTransform(D3DTS_WORLD, &matWorld);

	//取景變換矩陣的設置  
	D3DXMATRIX matView;
	D3DXVECTOR3 eye(0.0f, 0.0f, -50.0f);
	D3DXVECTOR3 at(0.0f, 0.0f, 0.0f);
	D3DXVECTOR3 up(0.0f, 1.0f, 0.0f);
	D3DXMatrixLookAtLH(&matView, &eye, &at, &up);
	g_pDevice->SetTransform(D3DTS_VIEW, &matView);

	//投影變換矩陣的設置  
	D3DXMATRIX matProjection;
	D3DXMatrixPerspectiveFovLH(&matProjection, PI / 4.0f, 800.0f / 600.0f, 1.0f, 1000.0f);
	g_pDevice->SetTransform(D3DTS_PROJECTION, &matProjection);

	//視口變換的設置 
	D3DVIEWPORT9 vp;
	vp.X = 0;
	vp.Y = 0;
	vp.Width = SCREEN_WIDTH;
	vp.Height = SCREEN_HEIGHT;
	vp.MinZ = 0.0f;
	vp.MaxZ = 1.0f;
	g_pDevice->SetViewport(&vp);
}
開發者ID:liyongfa,項目名稱:DirectX,代碼行數:34,代碼來源:demo4.cpp

示例10: D3DXMatrixIdentity

void RenderModel::render() {
	// negative id are for invisible/container objects
	if(modelId >= 0)
	{
		Point_t pos = ref->getPos();
		Rot_t rot = ref->getRot();

		//Get translation/rotation matrix
		D3DXMATRIX trans, rotX, rotY, rotZ, scaleMat;
		D3DXMatrixIdentity(&trans);
		D3DXMatrixIdentity(&rotX);
		D3DXMatrixIdentity(&rotY);
		D3DXMatrixIdentity(&rotZ);

		D3DXMatrixTranslation(&trans, pos.x, pos.y, pos.z);
		D3DXMatrixRotationX(&rotX, rot.x);
		D3DXMatrixRotationY(&rotY, rot.y);
		D3DXMatrixRotationZ(&rotZ, rot.z);

		D3DXMatrixScaling(&scaleMat,scale.x,scale.y,scale.z);  

		//DC::get()->print("(%f,%f,%f), (%f,%f,%f)\n", pos.x, pos.y, pos.z, rot.x, rot.y, rot.z);

		//Render
		RE::get()->animate(modelId, scaleMat * rotX * rotY * rotZ * trans);
	}
}
開發者ID:Sudoka,項目名稱:NinjaCoders125,代碼行數:27,代碼來源:RenderModel.cpp

示例11: D3DXMatrixRotationX

/*
 * constructor
 */
Transformable::Transformable(void) {
	D3DXMatrixRotationX(&rotateX, D3DXToRadian(0.0f));
	D3DXMatrixRotationY(&rotateY, D3DXToRadian(0.0f));
	D3DXMatrixRotationZ(&rotateZ, D3DXToRadian(0.0f));
	D3DXMatrixScaling(&scale, 1.0f, 1.0f, 1.0f);
	D3DXMatrixTranslation(&translate, 0.0f, 0.0f, 0.0f);
}
開發者ID:WhatIsHeDoing,項目名稱:Lego,代碼行數:10,代碼來源:Transformable.cpp

示例12: renderchain_set_mvp

static void renderchain_set_mvp(void *data, unsigned vp_width,
      unsigned vp_height, unsigned rotation)
{
#if defined(HAVE_CG) || defined(HAVE_GLSL) || defined(HAVE_HLSL)
   video_shader_ctx_mvp_t mvp;
#endif
   d3d_video_t      *d3d = (d3d_video_t*)data;
   LPDIRECT3DDEVICE d3dr = (LPDIRECT3DDEVICE)d3d->dev;

#if defined(_XBOX360) && defined(HAVE_HLSL)
   hlsl_set_proj_matrix(XMMatrixRotationZ(rotation * (M_PI / 2.0)));

   mvp.data   = d3d;
   mvp.matrix = NULL;

   video_shader_driver_set_mvp(mvp);
#elif defined(HAVE_D3D8)
   D3DXMATRIX p_out, p_rotate, mat;
   D3DXMatrixOrthoOffCenterLH(&mat, 0, vp_width,  vp_height, 0, 0.0f, 1.0f);
   D3DXMatrixIdentity(&p_out);
   D3DXMatrixRotationZ(&p_rotate, rotation * (M_PI / 2.0));

   d3d_set_transform(d3dr, D3DTS_WORLD, &p_rotate);
   d3d_set_transform(d3dr, D3DTS_VIEW, &p_out);
   d3d_set_transform(d3dr, D3DTS_PROJECTION, &p_out);
#endif
}
開發者ID:arakerlu,項目名稱:RetroArch,代碼行數:27,代碼來源:xdk_renderchain.cpp

示例13: D3DXMatrixIdentity

VOID CameraWorkBase::SetMatrix( LPD3DXVECTOR3 _pvecScale, LPD3DXVECTOR3 _pvecRotate, LPD3DXVECTOR3 _pvecTranslate )
{
	//	Set World Matrix
	D3DXMATRIX matScale;
	D3DXMatrixIdentity( &matScale );
	D3DXMatrixScaling( &matScale, _pvecScale->x, _pvecScale->y, _pvecScale->z );

	D3DXMATRIX matRotateX;
	D3DXMatrixIdentity( &matRotateX );
	D3DXMatrixRotationX( &matRotateX, _pvecRotate->x );

	D3DXMATRIX matRotateY;
	D3DXMatrixIdentity( &matRotateY );
	D3DXMatrixRotationY( &matRotateY, _pvecRotate->y );

	D3DXMATRIX matRotateZ;
	D3DXMatrixIdentity( &matRotateZ );
	D3DXMatrixRotationZ( &matRotateZ, _pvecRotate->z );

	D3DXMATRIX matTranslate;
	D3DXMatrixIdentity( &matTranslate );
	D3DXMatrixTranslation( &matTranslate, _pvecTranslate->x, _pvecTranslate->y, _pvecTranslate->z );

	D3DXMATRIX matWorld;
	D3DXMatrixIdentity( &matWorld );
	matWorld = matScale * matRotateX * matRotateY * matRotateZ * matTranslate;

	m_pd3dDevice->SetTransform( D3DTS_WORLD, &matWorld );
}
開發者ID:yoonhada,項目名稱:nlinelast,代碼行數:29,代碼來源:CameraWorkBase.cpp

示例14: D3DXMatrixScaling

void RollingBall::drawObject(IDirect3DDevice9 *d3dDev)
{
	D3DXMATRIX worldMat, viewMat, matTransform, matProjection, matScale, matTranslate,  matRotation;

	if(actor == NULL)
	{
		return;
	}
	
	//scaling
	D3DXMatrixScaling(&matScale,1.0f, 1.0f, 1.0f);
	worldMat = matScale;

	//rotation
	if(xRot)
		D3DXMatrixRotationX(&matRotation, getRotX());
	else
		D3DXMatrixRotationZ(&matRotation, getRotZ());
	worldMat *= matRotation;

	//translation
	D3DXMatrixTranslation(&matTranslate, getX(), getY(), getZ());
	worldMat *= matTranslate;

	//final matrix = ISROT, identity * scale * rotation * orbit * translation
	d3dDev->SetTransform(D3DTS_WORLD, &worldMat);
	//set texture
	d3dDev->SetTexture(0, texture);
	
	//draw object
	mesh->DrawSubset(0);
}
開發者ID:nickapopolis,項目名稱:Labyrinthian,代碼行數:32,代碼來源:RollingBall.cpp

示例15: SetBlockPosition

void SetBlockPosition ( BRUSH* pBrush, float fX, float fY, float fZ, float fScale )
{
		D3DXMATRIX	matTranslation;										// translation ( position )
	D3DXMATRIX	matRotation, matRotateX, matRotateY, matRotateZ;	// rotation
	D3DXMATRIX	matScale;											// scale
	D3DXMATRIX	matViewInverse;
	D3DXMATRIX	matView;
	
	// use this for the inverse function
	float fDet;

	// apply scaling to the object
	D3DXMatrixScaling ( &matScale, fScale, fScale, fScale );
	
	// apply translation to the object
	D3DXMatrixTranslation ( &matTranslation, fX, fY, fZ );

	// setup rotation matrices
	D3DXMatrixRotationX ( &matRotateX, D3DXToRadian ( 0.0f ) );	// x rotation
	D3DXMatrixRotationY ( &matRotateY, D3DXToRadian ( 0.0f ) );	// y rotation
	D3DXMatrixRotationZ ( &matRotateZ, D3DXToRadian ( 0.0f ) );	// z rotation

	// build final rotation matrix
	matRotation = matRotateX * matRotateY * matRotateZ;

	pBrush->Matrix = matRotation * matScale * matTranslation;

}
開發者ID:Fliper12,項目名稱:darkbasicpro,代碼行數:28,代碼來源:xmain.cpp


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