如何从2D坐标计算3D点?

时间:2015-01-28 00:59:57

标签: math 3d directx directx-11 reverseprojection

我最近遇到了涉及DirectX11和3D坐标计算的困境。我希望将鼠标坐标转换为此3D坐标。我希望在将多边形模型(默认立方体等)或网格对象插入空白空间时,它的行为类似于Maya或Unity。我需要哪些步骤和数学来计算这个坐标?

1 个答案:

答案 0 :(得分:0)

这与您在光线追踪中使用的数学运算相同,可将屏幕坐标转换回3D空间中的光线。

以下是旧版DirectX SDK示例“Pick10”中的D3DXMath代码

const D3DXMATRIX* pmatProj = g_Camera.GetProjMatrix();

POINT ptCursor;
GetCursorPos( &ptCursor );
ScreenToClient( DXUTGetHWND(), &ptCursor );

// Compute the vector of the pick ray in screen space
D3DXVECTOR3 v;
v.x = ( ( ( 2.0f * ptCursor.x ) / pd3dsdBackBuffer->Width ) - 1 ) / pmatProj->_11;
v.y = -( ( ( 2.0f * ptCursor.y ) / pd3dsdBackBuffer->Height ) - 1 ) / pmatProj->_22;
v.z = 1.0f;

// Get the inverse view matrix
const D3DXMATRIX matView = *g_Camera.GetViewMatrix();
const D3DXMATRIX matWorld = *g_Camera.GetWorldMatrix();
D3DXMATRIX mWorldView = matWorld * matView;
D3DXMATRIX m;
D3DXMatrixInverse( &m, NULL, &mWorldView );

// Transform the screen space pick ray into 3D space
vPickRayDir.x = v.x * m._11 + v.y * m._21 + v.z * m._31;
vPickRayDir.y = v.x * m._12 + v.y * m._22 + v.z * m._32;
vPickRayDir.z = v.x * m._13 + v.y * m._23 + v.z * m._33;
vPickRayOrig.x = m._41;
vPickRayOrig.y = m._42;
vPickRayOrig.z = m._43;

我一直想将它转换为DirectXMath并将其重新发布到MSDN代码库一段时间,但它尚未成为堆栈顶部。上面的代码假定左手坐标。

请记住,2D屏幕位置加上变换矩阵仅提供3个自由度中的2个,因此您必须对深度做出一些假设。

还要搜索“以3D方式挑选”这两个词。