Commit 082d740f authored by David Adam's avatar David Adam Committed by Alexandre Julliard

d3dx8: Simplify some functions.

parent 77c857d8
...@@ -1346,15 +1346,15 @@ D3DXVECTOR3* WINAPI D3DXVec3Normalize(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv) ...@@ -1346,15 +1346,15 @@ D3DXVECTOR3* WINAPI D3DXVec3Normalize(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv)
D3DXVECTOR3* WINAPI D3DXVec3Project(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv, CONST D3DVIEWPORT8 *pviewport, CONST D3DXMATRIX *pprojection, CONST D3DXMATRIX *pview, CONST D3DXMATRIX *pworld) D3DXVECTOR3* WINAPI D3DXVec3Project(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv, CONST D3DVIEWPORT8 *pviewport, CONST D3DXMATRIX *pprojection, CONST D3DXMATRIX *pview, CONST D3DXMATRIX *pworld)
{ {
D3DXMATRIX m1, m2; D3DXMATRIX m;
D3DXVECTOR3 out, vec; D3DXVECTOR3 out;
D3DXMatrixMultiply(&m1, pworld, pview); D3DXMatrixMultiply(&m, pworld, pview);
D3DXMatrixMultiply(&m2, &m1, pprojection); D3DXMatrixMultiply(&m, &m, pprojection);
D3DXVec3TransformCoord(&vec, pv, &m2); D3DXVec3TransformCoord(&out, pv, &m);
out.x = pviewport->X + ( 1.0f + vec.x ) * pviewport->Width / 2.0f; out.x = pviewport->X + ( 1.0f + out.x ) * pviewport->Width / 2.0f;
out.y = pviewport->Y + ( 1.0f - vec.y ) * pviewport->Height / 2.0f; out.y = pviewport->Y + ( 1.0f - out.y ) * pviewport->Height / 2.0f;
out.z = pviewport->MinZ + vec.z * ( pviewport->MaxZ - pviewport->MinZ ); out.z = pviewport->MinZ + out.z * ( pviewport->MaxZ - pviewport->MinZ );
*pout = out; *pout = out;
return pout; return pout;
} }
...@@ -1404,16 +1404,16 @@ D3DXVECTOR3* WINAPI D3DXVec3TransformNormal(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 ...@@ -1404,16 +1404,16 @@ D3DXVECTOR3* WINAPI D3DXVec3TransformNormal(D3DXVECTOR3 *pout, CONST D3DXVECTOR3
D3DXVECTOR3* WINAPI D3DXVec3Unproject(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv, CONST D3DVIEWPORT8 *pviewport, CONST D3DXMATRIX *pprojection, CONST D3DXMATRIX *pview, CONST D3DXMATRIX *pworld) D3DXVECTOR3* WINAPI D3DXVec3Unproject(D3DXVECTOR3 *pout, CONST D3DXVECTOR3 *pv, CONST D3DVIEWPORT8 *pviewport, CONST D3DXMATRIX *pprojection, CONST D3DXMATRIX *pview, CONST D3DXMATRIX *pworld)
{ {
D3DXMATRIX m1, m2, m3; D3DXMATRIX m;
D3DXVECTOR3 out, vec; D3DXVECTOR3 out;
D3DXMatrixMultiply(&m1, pworld, pview); D3DXMatrixMultiply(&m, pworld, pview);
D3DXMatrixMultiply(&m2, &m1, pprojection); D3DXMatrixMultiply(&m, &m, pprojection);
D3DXMatrixInverse(&m3, NULL, &m2); D3DXMatrixInverse(&m, NULL, &m);
vec.x = 2.0f * ( pv->x - pviewport->X ) / pviewport->Width - 1.0f; out.x = 2.0f * ( pv->x - pviewport->X ) / pviewport->Width - 1.0f;
vec.y = 1.0f - 2.0f * ( pv->y - pviewport->Y ) / pviewport->Height; out.y = 1.0f - 2.0f * ( pv->y - pviewport->Y ) / pviewport->Height;
vec.z = ( pv->z - pviewport->MinZ) / ( pviewport->MaxZ - pviewport->MinZ ); out.z = ( pv->z - pviewport->MinZ) / ( pviewport->MaxZ - pviewport->MinZ );
D3DXVec3TransformCoord(&out, &vec, &m3); D3DXVec3TransformCoord(&out, &out, &m);
*pout = out; *pout = out;
return pout; return pout;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment