青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 132  文章 - 51  trackbacks - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(7)

隨筆分類

隨筆檔案

文章分類

文章檔案

cocos2d-x

OGRE

OPenGL

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

BOOL D3DXIntersectTri(
        CONST D3DXVECTOR3
* p0,                           //頂點1
        CONST D3DXVECTOR3
* p1,
        CONST D3DXVECTOR3
* p2,
        CONST D3DXVECTOR3
* pRayPos,               //射線起始位置
        CONST D3DXVECTOR3
* pRayDir,               //射線方向
        FLOAT
*             pU,                                          //三個點比重
        FLOAT
*             pV,
        FLOAT
*             pDist                                       //射線起點到交點位置
        );

para :其中p0, p1, p2分別指向三角形的三個頂點,position為射線起點,direction為射線方向向量,u,v,為交點重心坐標,因為不可能只點到頂點上,可能點在三角形范圍內,distance為起點到交點距離,成功返回TRUE,失敗返回FALSE。

vPickPos = v0 * ( 1-u-v) + v1*u + v2*v = v0 + u * (v1 - v0) + v * (v3 - v0); 

特別注意:方向向量必須為單位向量,即pRayDir - pRayPos  為單位向量否則,pDist的值和向量長度成正比關系


eg:
    D3DXVECTOR3    rayDir;
    D3DXVECTOR3 vDest( 
10,200,0.f);
    D3DXVECTOR3 vSour( 
10,200,-10.f );
    rayDir 
= vDest - vSour;
    D3DXVec3Normalize( 
&rayDir, &rayDir );                                    //將方向向量化
    BOOL bHit 
= D3DXIntersectTri( &D3DXVECTOR3(0.0f,  0.0f0.5f),
                                
&D3DXVECTOR3(250.0f250.0f0.5f),
                                
&D3DXVECTOR3(0.0f250.0f0.5f),        //pos
                                &D3DXVECTOR3(10,200,-10.f ),            //dir
                                &rayDir, 
                                
&fu, 
                                
&fv, 
                                
&t );

游戲中應用
    float CTerrain::GetZByXY( float fx,float fy  )
    
{
        
//求出第幾個方格
        int x,y;
        x 
= fx / MAPTILESIZE;
        y 
= fy / MAPTILESIZE;
        
if( x < 0 || x >= m_iMapWidth-1  )
            
return 0;
        
if( y < 0 || y >= m_iMapHeight-1 )
            
return 0;    
        
        
//方格四頂點
        D3DXVECTOR3 *pos[4];
        pos[
0= &m_ppPointPos[ y ][ x ];
        pos[
1= &m_ppPointPos[ y ][ x + 1];
        pos[
2= &m_ppPointPos[ y + 1][ x + 1];
        pos[
3= &m_ppPointPos[ y + 1][ x ];

        
float fMaxZ;
        fMaxZ 
= pos[ 0 ]->z ;
        
int iLoop;
        
for( iLoop = 1 ; iLoop < 4 ; iLoop ++ )
        
{
            
if( fMaxZ < pos[ iLoop ]->z )
                fMaxZ 
= pos[ iLoop ]->z;
        }


        
// 求眼睛和地形相交位置,注意單位化方向向量
        D3DXVECTOR3 vEye,vDir(0,0,-1);

        vEye.x 
= fx;
        vEye.y 
= fy;
        vEye.z 
= fMaxZ + 10;

        
float fU,fV,fDis;

        
if!D3DXIntersectTri( pos[0],pos[1] ,pos[2],&vEye,&vDir,            //三角形1
            &fU,&fV,&fDis ) )
        
{    
            
if!D3DXIntersectTri( pos[2],pos[3],pos[0],&vEye,&vDir,        //三角形2
                &fU,&fV,&fDis ) )
            
{
                
return 0.0f;
            }

            
else
            
{
                
return vEye.z - fDis;
            }

        }

        
else
        
{
            
return vEye.z - fDis;
        }

    }


 參考:
地形碰撞計算:
一.如果是鼠標點擊地面,
可將射線固定長度并分段,然后用射線與每一個分段上的點所落在的地面tile(兩個三角形)進行求交,
相交則返回對應位置,否則繼續與下一個段上的點所落在的地面tile求交
/*
      0      1
       ---->
      | \  |
      |  \ |
    2 V ---  3   
*/
這里不討論點擊屏幕求射線方法與射線分段處理,只算求交
如下d3d求交得出uv,再求位置:
 VECTOR3 vPickPos;
 // 右邊:
 if( D3DXIntersectTri(&v0, &v1, &v3, &vOrig, &vDir, &u, &v, NULL) == TRUE)
 {
  vPickPos = v0 + u * (v1 - v0) + v * (v3 - v0); 
  return vPickPos.z;
 }
 // 左邊:
 if( D3DXIntersectTri(&v0, &v3, &v2, &vOrig, &vDir, &u, &v, NULL) == TRUE)
 {
  vPickPos = v0 + u * (v3 - v0) + v * (v2 - v0);  
  return vPickPos.z;
 }

二.如果是僅是求地表某點高度
則可用uv重心求法(注意上述第一點的d3d的那個uv重心求法不太一樣,他的uv跟他的向量走?)
 float u = (fX-(int)fX);
 float v = (fY-(int)fY);

 float p0 = fHeight[0];
 float p1 = fHeight[1];
 float p2 = fHeight[2];
 float p3 = fHeight[3];

 if(u>v){ // 右邊
  return p0 + u * (p1 - p0) + v * (p3 - p1);; 
 }
 else{  // 左邊
  return  p0 + u * (p3 - p2) + v * (p2 - p0);
 }


http://flipcode.spaces.live.com/blog/cns!8E578E7901A88369!1052.entry
posted on 2010-08-18 14:23 風輕云淡 閱讀(1364) 評論(0)  編輯 收藏 引用 所屬分類: DX
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲免费一区二区| 久久国产一区| 久久久视频精品| 欧美一区二区三区成人| 久久成人这里只有精品| 久久不射网站| 欧美黄色一区| 亚洲精品一区二区三区福利| 一区二区成人精品| 亚洲综合不卡| 蜜桃久久av| 欧美性事免费在线观看| 国语对白精品一区二区| 亚洲激情在线观看视频免费| 一区二区三区回区在观看免费视频| 亚洲一区亚洲二区| 牛人盗摄一区二区三区视频| 亚洲伦理一区| 久久久人成影片一区二区三区| 欧美伦理91i| 韩国精品主播一区二区在线观看| 亚洲六月丁香色婷婷综合久久| 亚洲欧美一区二区三区极速播放| 久久综合狠狠综合久久综合88| 亚洲欧洲精品一区二区精品久久久| 亚洲国产日韩美| 午夜一级久久| 欧美日韩免费观看一区二区三区| 国产午夜精品视频| 亚洲最黄网站| 欧美华人在线视频| 欧美一区二区三区喷汁尤物| 欧美精品激情在线观看| 国产综合网站| 亚洲欧美制服另类日韩| 欧美激情1区2区| 久久精品99国产精品酒店日本| 欧美日韩国产丝袜另类| 亚洲国产一区二区精品专区| 久久久久久国产精品一区| 一区二区三区日韩精品视频| 麻豆成人在线| 狠狠做深爱婷婷久久综合一区 | 亚洲片区在线| 久久久久久久91| 国产日韩欧美精品综合| 欧美高清视频一区| 国产亚洲精品自拍| 亚洲欧美国产高清va在线播| 亚洲国产婷婷香蕉久久久久久99 | 一区二区三区毛片| 欧美国产一区二区在线观看| 久久精品国产77777蜜臀| 国产精品一国产精品k频道56| 亚洲永久免费观看| 亚洲精品久久在线| 欧美日本韩国一区二区三区| 一卡二卡3卡四卡高清精品视频| 欧美黄色片免费观看| 久久人人97超碰精品888| 激情成人av在线| 欧美不卡福利| 欧美大片国产精品| 亚洲国产婷婷香蕉久久久久久99| 亚洲丰满在线| 欧美日韩不卡在线| 亚洲视频碰碰| 亚洲一区二区三区涩| 国产深夜精品福利| 男男成人高潮片免费网站| 免费91麻豆精品国产自产在线观看| 亚洲国产日韩精品| 99这里只有精品| 国产精品一香蕉国产线看观看| 久久av资源网站| 久久综合伊人77777麻豆| 亚洲美女在线看| 亚洲一区久久久| 在线观看欧美激情| 99成人精品| 国产一区二区三区奇米久涩| 欧美国产一区二区三区激情无套| 欧美激情亚洲| 欧美亚洲在线视频| 免费欧美日韩| 亚洲欧美精品中文字幕在线| 午夜日韩在线| 亚洲国产婷婷香蕉久久久久久99| 亚洲免费av电影| 国产日韩精品久久久| 欧美激情成人在线视频| 欧美日在线观看| 久久影视三级福利片| 欧美激情第4页| 久久se精品一区精品二区| 欧美国产丝袜视频| 久久久久久久91| 欧美天堂亚洲电影院在线观看| 久久久久91| 国产精品黄视频| 欧美激情视频一区二区三区不卡| 国产精品狠色婷| 亚洲人成小说网站色在线| 国产农村妇女毛片精品久久麻豆| 欧美成人免费播放| 国产九九精品视频| 亚洲精品久久久久久久久久久久| 久久中文欧美| 亚洲欧美激情视频| 欧美a级一区| 久久人人97超碰国产公开结果| 欧美啪啪成人vr| 欧美va亚洲va国产综合| 国产精品一区二区三区乱码| 亚洲国产日韩在线一区模特| 欧美精品18+| 亚洲国产综合在线| 亚洲精品久久久久久久久久久久久 | 一区二区三区免费网站| 欧美一区二区三区喷汁尤物| 999亚洲国产精| 狠狠色丁香婷婷综合| 久久精品国产久精国产一老狼| 欧美亚洲自偷自偷| 国产一区91精品张津瑜| 激情综合久久| 一区二区三区产品免费精品久久75| 亚洲欧美精品| 一本色道久久综合亚洲精品高清| 国产日韩欧美在线| 免费成人黄色片| 亚洲一区二区三区午夜| 欧美福利小视频| 欧美一区二区三区在线视频 | 一区二区久久久久| 精品96久久久久久中文字幕无| 亚洲性感美女99在线| 亚洲欧美日韩中文播放| 欧美午夜剧场| 妖精视频成人观看www| 亚洲视频一区在线| 国产精品免费一区二区三区观看| 日韩一级大片| 亚洲一级在线观看| 国产精品亚洲一区| 欧美一区二区在线视频| 欧美精品一区二区蜜臀亚洲| 亚洲国产天堂久久综合网| 亚洲日本视频| 欧美日韩视频一区二区| 亚洲一区二区成人| 久久亚洲精品一区| 亚洲精品乱码久久久久久久久| 欧美精品日韩三级| 在线综合+亚洲+欧美中文字幕| 欧美一区二区三区免费视| 国自产拍偷拍福利精品免费一| 久久综合色天天久久综合图片| 最新国产の精品合集bt伙计| 亚洲欧美激情在线视频| 黄色在线一区| 欧美日韩亚洲综合在线| 亚洲自拍偷拍一区| 欧美激情2020午夜免费观看| 亚洲一区图片| 在线观看亚洲视频啊啊啊啊| 欧美激情第五页| 亚洲一区二区精品在线| 久久综合久久久| 一区二区免费在线观看| 国产一区二区激情| 欧美日韩精品免费看| 久久精品人人| 亚洲精品一区在线| 久久久人成影片一区二区三区| 亚洲靠逼com| 国内免费精品永久在线视频| 欧美精品一区二区精品网| 欧美一区二区免费| 亚洲精品美女在线观看播放| 久久久久久久一区二区| 一区二区三区视频观看| 国产中文一区| 国产精品大片wwwwww| 美日韩在线观看| 性高湖久久久久久久久| 亚洲精品一区二区三| 久久在线91| 午夜精品一区二区三区电影天堂 | 亚洲一区视频在线观看视频| 欧美国产精品专区| 久久成人久久爱| 亚洲视频在线看| 亚洲狠狠婷婷| 在线观看国产精品网站| 国产片一区二区| 国产精品成人一区二区三区吃奶| 欧美成人影音| 免费观看成人网| 久久综合给合|