我使用DirectX3D 11来创建一个应用程序,我的Camera目标向量由变量xdelta,ydelta和zdelta决定。
我必须在XY中查看我的视图,因为我将鼠标移动到屏幕上,使用RMB& LMB压了。
我认为我需要将鼠标移动中的增量添加到我的VIEW空间,以便它相对于我的视图平移X和Y,而不是X世界和Y世界。
然而,对此我不熟悉,我不确定如何将我的VIEW坐标转换回WORLD坐标。
我希望我遵循所有的格式规则,因为我不会在这里发布足够的内容来准确记住所有格式规则。
任何帮助将不胜感激。下面是我的代码片段。也许还有更好的方法。
if ( m_Input->RMBPressed() == true && m_Input->LMBPressed() == true ) // Pan View
{
if ( curX != mouseX || curY != mouseY ) {
//Get Target Coordinates in View Space
D3DXVECTOR3 targetView = (D3DXVECTOR3 ( mView(2,0), mView(2,1), mView(2,2) );
//Add mouse XY delta vector to target View Coordinates
D3DXVECTOR3 delta ( (float)curX-(float)mouseX,
(float)curY-(float)mouseY, zdelta );
targetView += delta;
//Convert back to World Coordinates
}
}
我尝试采用不同的方法,我认为这是正确的方法,但它似乎仍然无法正常工作。 当我的鼠标移动时,我从屏幕上得到X和Y的增量,并将它们存储在变量" xdelta"和" ydelta"。
然后我创建了一个转换矩阵D3DXMATRIX mTrans;
然后我填充矩阵中的值
// Rotation
mTrans(0,0) = delta.x;
mTrans(1,1) = delta.y;
// Translation
mTrans(0,3) = delta.x;
mTrans(1,3) = delta.y;
现在要获得相应的View坐标,我想我应该将它乘以View Matrix,我称之为mView。
mTrans= mTrans*mView;
现在将这些翻译的值添加到我当前的目标X和Y,这由变量" target_x"和" target_y",相对于我的视图坐标X和Y(即与我当前视图正交),它应该移动我的目标矢量。
target_x += mTrans(0,3);
target_y += mTrans(1,3);
但它没有。它沿着世界X和Y轴移动我的目标,而不是我的视图X和Y轴。
更多SNIPPETS
我确实使用了D3DXMatrixLookAtLH功能,但是我尝试根据鼠标移动来计算目标位置的变化,以获得新的目标来输入该功能。我添加了一些代码片段:
if ( m_Input->RMBPressed() == true && m_Input->LMBPressed() == true ) // Pan View
{
if ( curX != mouseX || curY != mouseY ) {
//Get mouse XY delta vector
D3DXVECTOR3 delta ( (float)curX-(float)mouseX, (float)curY-(float)mouseY, zdelta );
//Create Transformation Matrix
D3DXMATRIX mTemp;
// Rotation
mTemp (0,0) = delta.x;
mTemp (1,1) = delta.y;
mTemp (2,2) = delta.z;
// Translation
mTemp (0,3) = delta.x;
mTemp (1,3) = delta.y;
mTemp (2,3) = delta.z;
//Convert to View Coordinates
mTemp = mTemp*mView;
xdelta += mTemp(0,3);
ydelta += mTemp(1,3);
// Convert Spherical to Cartesian coordinates: mPhi measured from +y
// and mTheta measured counterclockwise from z.
float height = mRadius * cosf(mPhi);
float sideRadius = mRadius * sinf(mPhi);
float x = xdelta + sideRadius * cosf(mTheta);
float z = zdelta + sideRadius * sinf(mTheta);
float y = ydelta + height;
// Build the view matrix.
D3DXVECTOR3 pos(x, y, z);
D3DXVECTOR3 target(xdelta, ydelta, zdelta);
D3DXVECTOR3 up(0.0f, 1.0f, 0.0f); // Y Axis is up. Looking down Z.
D3DXMatrixLookAtLH(&mView, &pos, &target, &up);
首先,感谢您提供的所有信息。它帮助我慢慢了解DirectX矩阵。 我在下面的逻辑中是否正确? 假设我的鼠标在X屏幕上变化为5.0,在Y屏幕上变为5.0。那是我的三角洲。 Z总是0.0。 我可以找到如下的视图坐标。
D3DXVECTOR3 up(0.0f, 1.0f, 0.0f); // Y Axis is up. Looking down Z.
D3DXVECTOR3 delta ( 5.0f, 5.0f, 0.0f );
D3DXVECTOR3 origin ( 0.0f. 0.0f, 0.0f );
D3DMATRIX mTemp;
D3DXMatrixIdentity (&mTemp);
D3DXMatrixLookAtLH (&mTemp, &delta, &origin, &up );
我现在应该在mTemp视图矩阵中存储XY增量的视图坐标吗?
如果是这样,最好的方法是,通过将XY delta视图坐标添加到mView XY坐标,然后转换回世界坐标,获取实际XY世界值,我必须将目标设置为?
我不知道如何实现这一目标。对我来说真的不是那么清楚,我在这个问题上购买的所有书籍都不清楚。
答案 0 :(得分:2)
您可以通过将局部坐标乘以世界矩阵,从本地坐标计算世界坐标。 如果您希望相机移动,而不是仅使用3D矢量定义其当前位置,然后使用D3DXMatrixLookAtLH从当前位置计算视图矩阵。 有关详细信息,请查看本教程:http://www.braynzarsoft.net/index.php?p=D3D11WVP