zoukankan      html  css  js  c++  java
  • (转)[DirectX]拾取—API实现平面交点

      简单总结一下D3D中的拾取问题,所谓拾取就是3D程序中当用户使用鼠标同3D世界内的物体进行交互的时候,如何能正确的实现从用户的鼠标到3D世界中的变换。
        呵呵,如果要是推及到原理的话比较复杂,需要好好总结,先从简单的入手,D3D中提供了很多易用的API,使用这些API的话就可以绕过复杂的数学原理,所以呢,我们先来看实际应用中是怎样实现它的。
        //首先获取世界、视角、投影矩阵
        D3DXMATRIX matWorld,matView,matProj;
        pd3dDevice->GetTransform(D3DTS_WORLD,&matWorld);
        pd3dDevice->GetTransform(D3DTS_VIEW,&matView);
        pd3dDevice->GetTransform(D3DTS_PROJECTION,&matProj);
        //获取平面坐标
        POINT ptCursor;
        GetCursorPos(&ptCursor);
        ScreenToClient(DXUTGetHWND(),&ptCursor);
        D3DXVECTOR3 vScreen((float)ptCursor.x,(float)ptCursor.y,0.0f),vOut;
        //创建视窗接口
        D3DVIEWPORT9 viewPort;
        pd3dDevice->GetViewport( &viewPort );
        //从屏幕空间投影到3D空间
        D3DXVec3Unproject(&vOut,&vScreen,&viewPort,&matProj,&matView,&matWorld);
        D3DXVECTOR3 vMousePt;
        D3DXPLANE plane;
        D3DXVECTOR3 v1(1.0f,1.0f,0.0f);
        D3DXVECTOR3 v2(1.0f,-1.0f,0.0f);
        D3DXVECTOR3 v3(-1.0f,1.0f,0.0f);
        D3DXPlaneFromPoints( &plane,&v1,&v2,&v3);
        D3DXPlaneIntersectLine(&vMousePt,&plane,pCamera->GetEyePt(),&vOut);
        //vMousePt.x,vMousePt.y和vMousePt.z就是鼠标根据视角所投射线同所指定平面的交点
        很简单的一段代码,为了确保它的正确性,测试倒是费了半天劲-。-,全部都是用API来实现的,看程序不难理解,这段程序重点是D3DXVec3Unproject()函数,这个函数的作用便是进行屏幕到空间的投影(还有一个D3DXVec3project()函数是用来进行空间到屏幕的投影的^_^),这个函数需要的是设备的Viewport、决定3D空间的三个矩阵和屏幕的坐标,函数可以算出结果向量,不过测试的时候我发现这个向量好像既不是近裁剪面的投影点也不是远裁剪面的,这个地方确实还是存在疑惑的,不过不影响使用,呵呵。
        其实有了这个向量后面的怎么用就看大家了,上面是通过D3DXPlaneIntersectLine()函数(计算直线与平面交点用函数)来实现的,还可以用D3DXIntersect()来做与三角面片的相交。
        我发现亲自写点东西还是很艰难的,随便一点东西就要写好多,而且还要确保正确,为了能坚持下来,还是尽量拆分开些吧,能保持些积极性,呵呵,今天先写这些。
  • 相关阅读:
    底层因为接受到操作系统信号而停止的解决
    C语言判断文件是否存在
    Linux磁盘设备文件(sda,sdb,sdc…)变化问题
    linux mysql 数据目录文件夹移动及所遇到的问题
    Linux Mysql如何移动MySQL数据库目录位置
    Linux 磁盘挂载和mount共享
    提高VS2010/VS2012编译速度
    C++[类设计] ini配置文件读写类config
    WIN32读写INI文件方法
    MS509Team----------------Cknife
  • 原文地址:https://www.cnblogs.com/lancidie/p/1845772.html
Copyright © 2011-2022 走看看