亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? tritri.c

?? Direct3D游戲編程入門教程源代碼.rar
?? C
字號(hào):
/* Triangle/triangle intersection test routine,
 * by Tomas Moller, 1997.
 * See article "A Fast Triangle-Triangle Intersection Test",
 * Journal of Graphics Tools, 2(2), 1997
 *
 * int tri_tri_intersect(float V0[3],float V1[3],float V2[3],
 *                         float U0[3],float U1[3],float U2[3])
 *
 * parameters: vertices of triangle 1: V0,V1,V2
 *             vertices of triangle 2: U0,U1,U2
 * result    : returns 1 if the triangles intersect, otherwise 0
 *
 */

#include <math.h>


/* if USE_EPSILON_TEST is true then we do a check: 
         if |dv|<EPSILON then dv=0.0;
   else no check is done (which is less robust)
*/
#define USE_EPSILON_TEST TRUE  
#define EPSILON 0.000001


/* some macros */
#define CROSS(dest,v1,v2)                      \
              dest[0]=v1[1]*v2[2]-v1[2]*v2[1]; \
              dest[1]=v1[2]*v2[0]-v1[0]*v2[2]; \
              dest[2]=v1[0]*v2[1]-v1[1]*v2[0];

#define DOT(v1,v2) (v1[0]*v2[0]+v1[1]*v2[1]+v1[2]*v2[2])

#define SUB(dest,v1,v2)          \
            dest[0]=v1[0]-v2[0]; \
            dest[1]=v1[1]-v2[1]; \
            dest[2]=v1[2]-v2[2]; 

/* sort so that a<=b */
#define SORT(a,b)       \
             if(a>b)    \
             {          \
               float c; \
               c=a;     \
               a=b;     \
               b=c;     \
             }

#define ISECT(VV0,VV1,VV2,D0,D1,D2,isect0,isect1) \
              isect0=VV0+(VV1-VV0)*D0/(D0-D1);    \
              isect1=VV0+(VV2-VV0)*D0/(D0-D2);


#define COMPUTE_INTERVALS(VV0,VV1,VV2,D0,D1,D2,D0D1,D0D2,isect0,isect1) \
  if(D0D1>0.0f)                                         \
  {                                                     \
    /* here we know that D0D2<=0.0 */                   \
    /* that is D0, D1 are on the same side, D2 on the other or on the plane */ \
    ISECT(VV2,VV0,VV1,D2,D0,D1,isect0,isect1);          \
  }                                                     \
  else if(D0D2>0.0f)                                    \
  {                                                     \
    /* here we know that d0d1<=0.0 */                   \
    ISECT(VV1,VV0,VV2,D1,D0,D2,isect0,isect1);          \
  }                                                     \
  else if(D1*D2>0.0f || D0!=0.0f)                       \
  {                                                     \
    /* here we know that d0d1<=0.0 or that D0!=0.0 */   \
    ISECT(VV0,VV1,VV2,D0,D1,D2,isect0,isect1);          \
  }                                                     \
  else if(D1!=0.0f)                                     \
  {                                                     \
    ISECT(VV1,VV0,VV2,D1,D0,D2,isect0,isect1);          \
  }                                                     \
  else if(D2!=0.0f)                                     \
  {                                                     \
    ISECT(VV2,VV0,VV1,D2,D0,D1,isect0,isect1);          \
  }                                                     \
  else                                                  \
  {                                                     \
    /* triangles are coplanar */                        \
    return coplanar_tri_tri(N1,V0,V1,V2,U0,U1,U2);      \
  }



/* this edge to edge test is based on Franlin Antonio's gem:
   "Faster Line Segment Intersection", in Graphics Gems III,
   pp. 199-202 */ 
#define EDGE_EDGE_TEST(V0,U0,U1)                      \
  Bx=U0[i0]-U1[i0];                                   \
  By=U0[i1]-U1[i1];                                   \
  Cx=V0[i0]-U0[i0];                                   \
  Cy=V0[i1]-U0[i1];                                   \
  f=Ay*Bx-Ax*By;                                      \
  d=By*Cx-Bx*Cy;                                      \
  if((f>0 && d>=0 && d<=f) || (f<0 && d<=0 && d>=f))  \
  {                                                   \
    e=Ax*Cy-Ay*Cx;                                    \
    if(f>0)                                           \
    {                                                 \
      if(e>=0 && e<=f) return 1;                      \
    }                                                 \
    else                                              \
    {                                                 \
      if(e<=0 && e>=f) return 1;                      \
    }                                                 \
  }                                

#define EDGE_AGAINST_TRI_EDGES(V0,V1,U0,U1,U2) \
{                                              \
  float Ax,Ay,Bx,By,Cx,Cy,e,d,f;               \
  Ax=V1[i0]-V0[i0];                            \
  Ay=V1[i1]-V0[i1];                            \
  /* test edge U0,U1 against V0,V1 */          \
  EDGE_EDGE_TEST(V0,U0,U1);                    \
  /* test edge U1,U2 against V0,V1 */          \
  EDGE_EDGE_TEST(V0,U1,U2);                    \
  /* test edge U2,U1 against V0,V1 */          \
  EDGE_EDGE_TEST(V0,U2,U0);                    \
}

#define POINT_IN_TRI(V0,U0,U1,U2)           \
{                                           \
  float a,b,c,d0,d1,d2;                     \
  /* is T1 completly inside T2? */          \
  /* check if V0 is inside tri(U0,U1,U2) */ \
  a=U1[i1]-U0[i1];                          \
  b=-(U1[i0]-U0[i0]);                       \
  c=-a*U0[i0]-b*U0[i1];                     \
  d0=a*V0[i0]+b*V0[i1]+c;                   \
                                            \
  a=U2[i1]-U1[i1];                          \
  b=-(U2[i0]-U1[i0]);                       \
  c=-a*U1[i0]-b*U1[i1];                     \
  d1=a*V0[i0]+b*V0[i1]+c;                   \
                                            \
  a=U0[i1]-U2[i1];                          \
  b=-(U0[i0]-U2[i0]);                       \
  c=-a*U2[i0]-b*U2[i1];                     \
  d2=a*V0[i0]+b*V0[i1]+c;                   \
  if(d0*d1>0.0)                             \
  {                                         \
    if(d0*d2>0.0) return 1;                 \
  }                                         \
}

int coplanar_tri_tri(float N[3],float V0[3],float V1[3],float V2[3],
                     float U0[3],float U1[3],float U2[3])
{
   float A[3];
   short i0,i1;
   /* first project onto an axis-aligned plane, that maximizes the area */
   /* of the triangles, compute indices: i0,i1. */
   A[0]=fabs(N[0]);
   A[1]=fabs(N[1]);
   A[2]=fabs(N[2]);
   if(A[0]>A[1])
   {
      if(A[0]>A[2])  
      {
          i0=1;      /* A[0] is greatest */
          i1=2;
      }
      else
      {
          i0=0;      /* A[2] is greatest */
          i1=1;
      }
   }
   else   /* A[0]<=A[1] */
   {
      if(A[2]>A[1])
      {
          i0=0;      /* A[2] is greatest */
          i1=1;                                           
      }
      else
      {
          i0=0;      /* A[1] is greatest */
          i1=2;
      }
    }               
                
    /* test all edges of triangle 1 against the edges of triangle 2 */
    EDGE_AGAINST_TRI_EDGES(V0,V1,U0,U1,U2);
    EDGE_AGAINST_TRI_EDGES(V1,V2,U0,U1,U2);
    EDGE_AGAINST_TRI_EDGES(V2,V0,U0,U1,U2);
                
    /* finally, test if tri1 is totally contained in tri2 or vice versa */
    POINT_IN_TRI(V0,U0,U1,U2);
    POINT_IN_TRI(U0,V0,V1,V2);

    return 0;
}


int tri_tri_intersect(float V0[3],float V1[3],float V2[3],
                      float U0[3],float U1[3],float U2[3])
{
  float E1[3],E2[3];
  float N1[3],N2[3],d1,d2;
  float du0,du1,du2,dv0,dv1,dv2;
  float D[3];
  float isect1[2], isect2[2];
  float du0du1,du0du2,dv0dv1,dv0dv2;
  short index;
  float vp0,vp1,vp2;
  float up0,up1,up2;
  float b,c,max;

  /* compute plane equation of triangle(V0,V1,V2) */
  SUB(E1,V1,V0);
  SUB(E2,V2,V0);
  CROSS(N1,E1,E2);
  d1=-DOT(N1,V0);
  /* plane equation 1: N1.X+d1=0 */

  /* put U0,U1,U2 into plane equation 1 to compute signed distances to the plane*/
  du0=DOT(N1,U0)+d1;
  du1=DOT(N1,U1)+d1;
  du2=DOT(N1,U2)+d1;

  /* coplanarity robustness check */
#if USE_EPSILON_TEST==TRUE
  if(fabs(du0)<EPSILON) du0=0.0;
  if(fabs(du1)<EPSILON) du1=0.0;
  if(fabs(du2)<EPSILON) du2=0.0;
#endif
  du0du1=du0*du1;
  du0du2=du0*du2;

  if(du0du1>0.0f && du0du2>0.0f) /* same sign on all of them + not equal 0 ? */
    return 0;                    /* no intersection occurs */

  /* compute plane of triangle (U0,U1,U2) */
  SUB(E1,U1,U0);
  SUB(E2,U2,U0);
  CROSS(N2,E1,E2);
  d2=-DOT(N2,U0);
  /* plane equation 2: N2.X+d2=0 */

  /* put V0,V1,V2 into plane equation 2 */
  dv0=DOT(N2,V0)+d2;
  dv1=DOT(N2,V1)+d2;
  dv2=DOT(N2,V2)+d2;

#if USE_EPSILON_TEST==TRUE
  if(fabs(dv0)<EPSILON) dv0=0.0;
  if(fabs(dv1)<EPSILON) dv1=0.0;
  if(fabs(dv2)<EPSILON) dv2=0.0;
#endif

  dv0dv1=dv0*dv1;
  dv0dv2=dv0*dv2;
        
  if(dv0dv1>0.0f && dv0dv2>0.0f) /* same sign on all of them + not equal 0 ? */
    return 0;                    /* no intersection occurs */

  /* compute direction of intersection line */
  CROSS(D,N1,N2);

  /* compute and index to the largest component of D */
  max=fabs(D[0]);
  index=0;
  b=fabs(D[1]);
  c=fabs(D[2]);
  if(b>max) max=b,index=1;
  if(c>max) max=c,index=2;

        /* this is the simplified projection onto L*/
        vp0=V0[index];
        vp1=V1[index];
        vp2=V2[index];

        up0=U0[index];
        up1=U1[index];
        up2=U2[index];

  /* compute interval for triangle 1 */
  COMPUTE_INTERVALS(vp0,vp1,vp2,dv0,dv1,dv2,dv0dv1,dv0dv2,isect1[0],isect1[1]);

  /* compute interval for triangle 2 */
  COMPUTE_INTERVALS(up0,up1,up2,du0,du1,du2,du0du1,du0du2,isect2[0],isect2[1]);

  SORT(isect1[0],isect1[1]);
  SORT(isect2[0],isect2[1]);

  if(isect1[1]<isect2[0] || isect2[1]<isect1[0]) return 0;
  return 1;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲三级在线观看| 国产无人区一区二区三区| 99精品国产一区二区三区不卡| 男人的j进女人的j一区| 亚洲成a人v欧美综合天堂下载 | 国产一区二区三区美女| 久久精品国产免费| 国内一区二区在线| 国产精品影视天天线| 国产精品一区二区在线看| 国产精品亚洲一区二区三区妖精| 国产乱理伦片在线观看夜一区| 国产成人精品亚洲午夜麻豆| 国产99久久久国产精品潘金| 成人免费视频网站在线观看| 色视频一区二区| 欧美精品色一区二区三区| 日韩欧美中文字幕制服| 欧美成人欧美edvon| 国产精品九色蝌蚪自拍| 一区二区三区四区中文字幕| 午夜久久电影网| 韩国理伦片一区二区三区在线播放| 精品一区二区三区的国产在线播放| 国产一区二区三区四区五区入口| 99精品热视频| 欧美精品乱人伦久久久久久| 日韩欧美中文一区二区| 国产视频一区在线观看| 亚洲精品福利视频网站| 蜜桃视频在线观看一区二区| 成人av在线资源| 欧美日韩一区二区在线视频| 亚洲精品一区二区三区精华液| 久久久精品日韩欧美| 亚洲线精品一区二区三区| 玖玖九九国产精品| 一本色道久久综合亚洲91 | 国产在线乱码一区二区三区| 99久久婷婷国产综合精品电影| 欧美精品一级二级三级| 国产欧美精品一区二区三区四区 | 亚洲激情图片一区| 偷拍自拍另类欧美| 成人福利视频网站| 欧美一区二区三区四区在线观看 | 调教+趴+乳夹+国产+精品| 风间由美中文字幕在线看视频国产欧美| 色婷婷综合久久久久中文一区二区| 日韩欧美国产综合一区| 亚洲一区二区三区四区的| 成人精品国产一区二区4080| 欧美成人精品1314www| 亚洲免费电影在线| 韩日欧美一区二区三区| 欧美剧在线免费观看网站| 亚洲欧美日韩国产成人精品影院 | 亚洲美女免费视频| 国产精品亚洲第一区在线暖暖韩国| 欧美综合一区二区| 成人免费在线观看入口| 国产精品 日产精品 欧美精品| 91精品国产综合久久久蜜臀粉嫩| 亚洲乱码日产精品bd| 高清日韩电视剧大全免费| 精品欧美一区二区久久| 免费在线观看不卡| 7777精品伊人久久久大香线蕉完整版 | 久久日一线二线三线suv| 午夜精品久久久久久| 91高清视频免费看| 日韩美女啊v在线免费观看| 精品一区二区三区久久久| 日韩一级片网站| 日韩二区三区在线观看| 欧美日韩电影在线播放| 亚洲一区二区不卡免费| 在线国产亚洲欧美| 一区二区三区成人| 欧美亚洲国产怡红院影院| 中文字幕中文在线不卡住| 成人a免费在线看| 中文字幕一区二区视频| 91老司机福利 在线| 亚洲福利国产精品| 日韩一级成人av| 国产一区二区三区在线观看免费| 精品国产sm最大网站免费看| 国产一区视频导航| 国产精品色眯眯| 色先锋aa成人| 婷婷六月综合网| 精品少妇一区二区三区视频免付费| 青青青伊人色综合久久| 欧美精品一区二区久久婷婷| 国产精品一二三在| 中文字幕av一区二区三区免费看 | 成+人+亚洲+综合天堂| 国产精品网站在线| 欧美中文字幕一区| 免费不卡在线观看| 中文字幕不卡在线播放| 在线精品视频小说1| 日韩黄色小视频| 久久久久久9999| 欧美在线free| 理论片日本一区| 国产精品嫩草影院av蜜臀| 欧美日韩视频专区在线播放| 久久99久久久久| 亚洲日本va午夜在线电影| 欧美欧美欧美欧美| 国产成人精品三级| 亚洲国产精品久久不卡毛片 | 日本一区二区三区电影| 一本大道久久a久久精品综合| 麻豆精品一区二区三区| 亚洲女同女同女同女同女同69| 欧美肥妇free| 99re8在线精品视频免费播放| 天堂va蜜桃一区二区三区漫画版 | 亚洲图片欧美激情| 日韩欧美国产成人一区二区| 一本色道a无线码一区v| 国产一区啦啦啦在线观看| 亚洲国产精品尤物yw在线观看| 久久精品人人做人人综合| 欧美一级高清片| 欧美日韩国产乱码电影| youjizz国产精品| 国产精品伊人色| 美女高潮久久久| 一级特黄大欧美久久久| 国产精品看片你懂得| 精品精品欲导航| 在线不卡的av| 欧美在线一区二区三区| 一本大道久久a久久综合婷婷| 国产精品77777| 国内外成人在线| 美国十次综合导航| 日韩激情在线观看| 亚洲r级在线视频| 亚洲图片一区二区| 亚洲线精品一区二区三区| 一区二区三区欧美在线观看| 亚洲欧洲性图库| 国产精品美女久久久久久久久| 国产日韩欧美激情| 久久综合av免费| 26uuu色噜噜精品一区二区| 日韩欧美你懂的| 亚洲精品在线网站| 国产亚洲欧美激情| 中文字幕欧美区| 国产精品久久二区二区| 亚洲欧美日韩综合aⅴ视频| 日韩码欧中文字| 亚洲精品久久嫩草网站秘色| 亚洲女同一区二区| 午夜精品一区二区三区免费视频| 亚洲最新视频在线播放| 亚洲成av人影院| 另类调教123区| 国产露脸91国语对白| 成人黄色av电影| 在线免费观看视频一区| 欧美日韩不卡一区二区| 亚洲精品在线观| 国产精品私房写真福利视频| 亚洲精品国产高清久久伦理二区| 亚洲综合一区二区精品导航| 免播放器亚洲一区| 国产91精品在线观看| 99综合电影在线视频| 欧美三级电影在线看| 欧美成人三级在线| 亚洲免费观看高清完整| 石原莉奈一区二区三区在线观看| 精品一区二区三区在线播放| 成人av资源网站| 91麻豆精品国产91久久久资源速度 | 中文字幕av一区二区三区免费看| 欧美国产激情二区三区| 一区二区三区欧美日| 欧美二区乱c少妇| 久久嫩草精品久久久精品一| 亚洲激情图片一区| 强制捆绑调教一区二区| 久久精品72免费观看| 成人午夜激情在线| 亚洲乱码国产乱码精品精可以看| 国产 日韩 欧美大片| 国产亚洲欧美色| 床上的激情91.| 国产日韩欧美精品在线| 成人综合婷婷国产精品久久蜜臀| 久久久噜噜噜久久中文字幕色伊伊| 狠狠狠色丁香婷婷综合久久五月| 欧美一级精品在线|