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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? frustum.cpp

?? 3D游戲引擎 Programming Role-Playing Games with DirectX, 2nd Edition by Jim Adams
?? CPP
字號:
#include "Core_Global.h"
#include "Frustum.h"

BOOL cFrustum::Construct(cGraphics *Graphics, float ZDistance)
{
  D3DXMATRIX Matrix, matView, matProj;
  float      ZMin, Q;

  // Error checking
  if(Graphics == NULL)
    return FALSE;

  // Calculate FOV data
  Graphics->GetDeviceCOM()->GetTransform(D3DTS_PROJECTION, &matProj);
  if(ZDistance != 0.0f) {
    // Calculate new projection matrix based on distance provided
    ZMin = -matProj._43 / matProj._33;
    Q = ZDistance / (ZDistance - ZMin);
    matProj._33 = Q;
    matProj._43 = -Q * ZMin;
  }
  Graphics->GetDeviceCOM()->GetTransform(D3DTS_VIEW, &matView);
  D3DXMatrixMultiply(&Matrix, &matView, &matProj);

  // Calculate the planes
  m_Planes[0].a = Matrix._14 + Matrix._13; // Near
  m_Planes[0].b = Matrix._24 + Matrix._23;
  m_Planes[0].c = Matrix._34 + Matrix._33;
  m_Planes[0].d = Matrix._44 + Matrix._43;
  D3DXPlaneNormalize(&m_Planes[0], &m_Planes[0]);

  m_Planes[1].a = Matrix._14 - Matrix._13; // Far
  m_Planes[1].b = Matrix._24 - Matrix._23;
  m_Planes[1].c = Matrix._34 - Matrix._33;
  m_Planes[1].d = Matrix._44 - Matrix._43;
  D3DXPlaneNormalize(&m_Planes[1], &m_Planes[1]);

  m_Planes[2].a = Matrix._14 + Matrix._11; // Left
  m_Planes[2].b = Matrix._24 + Matrix._21;
  m_Planes[2].c = Matrix._34 + Matrix._31;
  m_Planes[2].d = Matrix._44 + Matrix._41;
  D3DXPlaneNormalize(&m_Planes[2], &m_Planes[2]);

  m_Planes[3].a = Matrix._14 - Matrix._11; // Right
  m_Planes[3].b = Matrix._24 - Matrix._21;
  m_Planes[3].c = Matrix._34 - Matrix._31;
  m_Planes[3].d = Matrix._44 - Matrix._41;
  D3DXPlaneNormalize(&m_Planes[3], &m_Planes[3]);

  m_Planes[4].a = Matrix._14 - Matrix._12; // Top
  m_Planes[4].b = Matrix._24 - Matrix._22;
  m_Planes[4].c = Matrix._34 - Matrix._32;
  m_Planes[4].d = Matrix._44 - Matrix._42;
  D3DXPlaneNormalize(&m_Planes[4], &m_Planes[4]);

  m_Planes[5].a = Matrix._14 + Matrix._12; // Bottom
  m_Planes[5].b = Matrix._24 + Matrix._22;
  m_Planes[5].c = Matrix._34 + Matrix._32;
  m_Planes[5].d = Matrix._44 + Matrix._42;
  D3DXPlaneNormalize(&m_Planes[5], &m_Planes[5]);

  return TRUE;
}

BOOL cFrustum::CheckPoint(float XPos, float YPos, float ZPos)
{
  short i;

  // Make sure point is in frustum
  for(i=0;i<6;i++) {
    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XPos, YPos, ZPos)) < 0.0f)
      return FALSE;
  }

  return TRUE;
}

BOOL cFrustum::CheckCube(float XCenter, float YCenter, float ZCenter, float Size, BOOL *CompletelyContained)
{
  short i;
  DWORD TotalIn = 0;

  // Count the number of points inside the frustum
  for(i=0;i<6;i++) {

    DWORD Count = 8;
    BOOL  PointIn = TRUE;
    
    // Test all eight points against plane
    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-Size, YCenter-Size, ZCenter-Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+Size, YCenter-Size, ZCenter-Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-Size, YCenter+Size, ZCenter-Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+Size, YCenter+Size, ZCenter-Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-Size, YCenter-Size, ZCenter+Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+Size, YCenter-Size, ZCenter+Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-Size, YCenter+Size, ZCenter+Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+Size, YCenter+Size, ZCenter+Size)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    // If none contained, return FALSE
    if(Count == 0)
      return FALSE;

    // Update counter if they were all in front of plane
    TotalIn += (PointIn == TRUE) ? 1:0;
  }

  // Store BOOL flag if completely contained
  if(CompletelyContained != NULL)
    *CompletelyContained = (TotalIn == 6) ? TRUE:FALSE;

  return TRUE;
}

BOOL cFrustum::CheckRectangle(float XCenter, float YCenter, float ZCenter, float XSize, float YSize, float ZSize, BOOL *CompletelyContained)
{
  short i;

  DWORD TotalIn = 0;

  // Count the number of points inside the frustum
  for(i=0;i<6;i++) {

    DWORD Count = 8;
    BOOL  PointIn = TRUE;
    
    // Test all eight points against plane
    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-XSize, YCenter-YSize, ZCenter-ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+XSize, YCenter-YSize, ZCenter-ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-XSize, YCenter+YSize, ZCenter-ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+XSize, YCenter+YSize, ZCenter-ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-XSize, YCenter-YSize, ZCenter+ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+XSize, YCenter-YSize, ZCenter+ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter-XSize, YCenter+YSize, ZCenter+ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter+XSize, YCenter+YSize, ZCenter+ZSize)) < 0.0f) {
      PointIn = FALSE;
      Count--;
    }

    // If none contained, return FALSE
    if(Count == 0)
      return FALSE;

    // Update counter if they were all in front of plane
    TotalIn += (PointIn == TRUE) ? 1:0;
  }

  // Store BOOL flag if completely contained
  if(CompletelyContained != NULL)
    *CompletelyContained = (TotalIn == 6) ? TRUE:FALSE;

  return TRUE;
}

BOOL cFrustum::CheckSphere(float XCenter, float YCenter, float ZCenter, float Radius)
{
  short i;

  // Make sure radius is in frustum
  for(i=0;i<6;i++) {
    if(D3DXPlaneDotCoord(&m_Planes[i], &D3DXVECTOR3(XCenter, YCenter, ZCenter)) < -Radius)
      return FALSE;
  }
  return TRUE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品乱码久久久久久 | 精品久久人人做人人爽| 亚洲高清免费观看 | 欧美日韩三级一区二区| 亚洲妇熟xx妇色黄| 6080日韩午夜伦伦午夜伦| 五月天亚洲婷婷| 日韩视频一区二区三区在线播放| 青草av.久久免费一区| 精品欧美一区二区三区精品久久| 精品一区二区三区在线播放| 国产亚洲美州欧州综合国| 成人av中文字幕| 亚洲制服丝袜在线| 日韩视频在线观看一区二区| 国产suv精品一区二区6| 亚洲欧美日本韩国| 8v天堂国产在线一区二区| 国内精品久久久久影院薰衣草| 久久久久99精品一区| 一本大道av伊人久久综合| 午夜不卡av在线| 国产亚洲一区字幕| 在线视频中文字幕一区二区| 麻豆精品精品国产自在97香蕉| 国产视频一区二区三区在线观看 | 日本免费在线视频不卡一不卡二| 欧美成人官网二区| 97精品久久久午夜一区二区三区| 午夜精品123| 国产精品免费av| 91精品国产综合久久久蜜臀粉嫩| 国产99久久久国产精品| 亚洲成人动漫在线免费观看| 亚洲精品一区二区在线观看| 色综合一个色综合| 激情欧美一区二区| 亚洲精品国产高清久久伦理二区| 欧美大片国产精品| 91偷拍与自偷拍精品| 久久99久国产精品黄毛片色诱| 中文字幕综合网| 久久男人中文字幕资源站| 欧美性生活久久| 国产精品一区2区| 亚洲成人www| 综合中文字幕亚洲| 久久这里都是精品| 4438x成人网最大色成网站| 成人黄页毛片网站| 精东粉嫩av免费一区二区三区| 怡红院av一区二区三区| 国产午夜精品在线观看| 欧美一区二区精品| 欧美影院午夜播放| 日韩美女视频一区二区在线观看| 在线影视一区二区三区| 粉嫩av一区二区三区在线播放| 蜜臀av一区二区在线观看| 亚洲午夜一区二区三区| 亚洲免费观看高清完整版在线观看熊| 久久久久97国产精华液好用吗| 91精品国产黑色紧身裤美女| 欧美日韩国产综合一区二区三区| 91丨九色丨蝌蚪富婆spa| 成人自拍视频在线| 丰满亚洲少妇av| 国产精品1区2区| 国产精品99久久久久久有的能看 | 蜜臀久久99精品久久久久久9| 亚洲国产精品一区二区www在线| 中文字幕一区二区三区不卡在线 | 中文欧美字幕免费| 久久久久久综合| 精品电影一区二区| 精品国产乱子伦一区| 日韩欧美国产综合| 日韩欧美国产综合| 久久综合九色综合97婷婷女人 | 日本不卡高清视频| 婷婷国产v国产偷v亚洲高清| 亚洲一区二区欧美| 五月天欧美精品| 蜜桃精品视频在线| 九九九精品视频| 国产成人综合精品三级| 国产成人av自拍| a4yy欧美一区二区三区| 日本乱码高清不卡字幕| 欧美亚洲动漫制服丝袜| 在线播放一区二区三区| 日韩你懂的电影在线观看| 26uuu国产在线精品一区二区| 国产亚洲一区二区在线观看| 国产欧美日韩中文久久| 自拍偷拍国产亚洲| 五月婷婷综合网| 精品无人码麻豆乱码1区2区| 国产**成人网毛片九色| 99久久精品国产观看| 欧美日免费三级在线| 日韩免费看的电影| 国产精品网友自拍| 亚洲在线中文字幕| 久久精品国产在热久久| 国产成人在线看| 欧洲一区在线观看| 精品福利一二区| 亚洲视频精选在线| 秋霞午夜av一区二区三区| 国产一区二区三区电影在线观看| 成人ar影院免费观看视频| 欧美日韩视频一区二区| 久久久精品日韩欧美| 一级女性全黄久久生活片免费| 免费成人av在线| av中文字幕不卡| 欧美精品日韩一区| 国产精品久久久99| 日韩精品一区第一页| 成人免费高清在线| 在线综合视频播放| 亚洲免费视频成人| 另类小说色综合网站| 色婷婷久久久综合中文字幕| 日韩久久久精品| 亚洲欧美另类久久久精品2019| 蜜桃一区二区三区四区| 色狠狠综合天天综合综合| 精品电影一区二区三区| 亚洲第一福利一区| 99视频精品全部免费在线| 日韩一区二区三区电影| 亚洲一区二区在线免费观看视频| 国产专区欧美精品| 欧美日韩久久久一区| 中文字幕一区二区三区不卡| 精品制服美女久久| 欧美丰满高潮xxxx喷水动漫| 国产精品福利一区| 国产精品伊人色| 日韩一区二区三区在线| 一区二区三区毛片| 成人久久18免费网站麻豆 | 精品国产乱码久久久久久久 | 亚洲综合成人网| 不卡的av在线播放| 国产色综合久久| 激情五月婷婷综合| 91精品国产麻豆| 午夜影院在线观看欧美| 91久久奴性调教| 亚洲欧美日韩成人高清在线一区| 丰满白嫩尤物一区二区| 26uuu久久天堂性欧美| 久久国产成人午夜av影院| 欧美肥妇毛茸茸| 天天综合色天天| 精品污污网站免费看| 亚洲国产综合91精品麻豆| 日本高清成人免费播放| 亚洲私人影院在线观看| 99视频热这里只有精品免费| 国产精品理论在线观看| 成人永久看片免费视频天堂| 久久精品视频一区| 国产精品一区一区| 国产欧美1区2区3区| 粉嫩嫩av羞羞动漫久久久| 欧美经典一区二区| 丁香一区二区三区| 国产精品国产三级国产aⅴ无密码| 国产成人精品免费视频网站| 国产色爱av资源综合区| 福利一区二区在线| 中文字幕亚洲一区二区av在线 | 亚洲欧美偷拍卡通变态| av男人天堂一区| 一区二区三区在线观看网站| 91在线丨porny丨国产| 又紧又大又爽精品一区二区| 欧美午夜免费电影| 青青草成人在线观看| 26uuu成人网一区二区三区| 成人在线一区二区三区| 亚洲精品综合在线| 中文字幕在线一区免费| 欧美亚洲一区三区| 日韩电影免费在线观看网站| 日韩精品中文字幕在线不卡尤物 | 午夜久久电影网| 日韩一区二区中文字幕| 国产精品一区二区你懂的| 中文字幕日韩av资源站| 精品视频色一区| 精品一区二区精品| 中文字幕亚洲一区二区av在线| 欧美日韩黄色一区二区| 国产在线国偷精品免费看| 亚洲视频你懂的|