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

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

?? barrier.cpp

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

cBarrier::cBarrier()
{
  m_NumBarriers = 0;
  m_BarrierParent = NULL;
}

cBarrier::~cBarrier()
{
  Free();
}

long cBarrier::GetNextLong(FILE *fp)
{
  char Buf[1024];
  long Pos = 0;
  int c;

  // Read until EOF or EOL
  while(1) {
    if((c = fgetc(fp)) == EOF)
      break;
    if(c == 0x0a || (c == ' ' && Pos))
      break;
    if((c >= '0' && c <= '9') || c == '.' || c == '-')
      Buf[Pos++] = c;
  }
  if(!Pos)
    return -1;
  Buf[Pos] = 0;

  return atol(Buf);
}

float cBarrier::GetNextFloat(FILE *fp)
{
  char Buf[1024];
  long Pos = 0;
  int c;

  // Read until EOF or EOL
  while(1) {
    if((c = fgetc(fp)) == EOF)
      break;
    if(c == 0x0a || (c == ' ' && Pos))
      break;
    if((c >= '0' && c <= '9') || c == '.' || c == '-')
      Buf[Pos++] = c;
  }
  Buf[Pos] = 0;

  return (float)atof(Buf);
}

BOOL cBarrier::SetMesh(long ID,                               \
                       cGraphics *Graphics, cMesh *Mesh)
{
  sBarrier *BarrierPtr;
  long Count = 0;

  // Loop through all Barriers looking for ID
  if((BarrierPtr = m_BarrierParent) != NULL) {
    while(BarrierPtr != NULL) {

      // If matched ID then set mesh
      if(BarrierPtr->ID == ID) {
        BarrierPtr->Object.Create(Graphics, Mesh);
        Count++;
      }

      // Go to next flag
      BarrierPtr = BarrierPtr->Next;
    }
  }

  // Return TRUE if any meshes set
  return (Count) ? TRUE : FALSE;
}

BOOL cBarrier::SetAnim(long ID, cAnimation *Anim,             \
                       char *Name, long Time)
{
  sBarrier *BarrierPtr;
  long Count = 0;

  // Loop through all Barriers looking for ID
  if((BarrierPtr = m_BarrierParent) != NULL) {
    while(BarrierPtr != NULL) {

      // If matched ID then set animation
      if(BarrierPtr->ID == ID) {
        BarrierPtr->Object.SetAnimation(Anim, Name, Time);
        Count++;
      }

      // Go to next flag
      BarrierPtr = BarrierPtr->Next;
    }
  }

  // Return TRUE if any animations set
  return (Count) ? TRUE : FALSE;
}

BOOL cBarrier::Render(unsigned long Time, cFrustum *Frustum)
{
  sBarrier *BarrierPtr;
  float Radius;

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

  // Loop through all Barriers looking for ID
  if((BarrierPtr = m_BarrierParent) != NULL) {
    while(BarrierPtr != NULL) {

      // Get radius and perform frustum check
      BarrierPtr->Object.GetBounds(NULL,NULL,NULL,NULL,       \
                                   NULL,NULL,&Radius);
      if(Frustum->CheckSphere(BarrierPtr->XPos,               \
                              BarrierPtr->YPos,               \
                              BarrierPtr->ZPos, Radius)) {

        // Position object
        BarrierPtr->Object.Move(BarrierPtr->XPos,             \
                                BarrierPtr->YPos,             \
                                BarrierPtr->ZPos);
        BarrierPtr->Object.Rotate(BarrierPtr->XRot,           \
                                  BarrierPtr->YRot,           \
                                  BarrierPtr->ZRot);

        // Update animation
        BarrierPtr->Object.UpdateAnimation(Time, TRUE);

        // Render object
        BarrierPtr->Object.Render();
      }

      // Go to next flag
      BarrierPtr = BarrierPtr->Next;
    }
  }

  return TRUE;
}

BOOL cBarrier::Load(char *Filename)
{
  FILE *fp;
  long Type, ID;
  BOOL Enabled;
  float x1, y1, z1, x2, y2, z2, x3, z3, Radius;
  float XPos, YPos, ZPos, XRot, YRot, ZRot;
  
  // Remove all current Barriers
  Free();

  // Open file
  if((fp=fopen(Filename, "rb"))==NULL)
    return FALSE;

  // Start looping, reading in until EOF reached
  while(1) {
    // Get ID of Barrier
    if((ID = GetNextLong(fp)) == -1)
      break;

    // Get type
    Type = GetNextLong(fp);

    // Get enabled status
    Enabled = (GetNextLong(fp)) ? TRUE : FALSE;

    // Get coordinates and rotation
    XPos = GetNextFloat(fp);
    YPos = GetNextFloat(fp);
    ZPos = GetNextFloat(fp);
    XRot = GetNextFloat(fp);
    YRot = GetNextFloat(fp);
    ZRot = GetNextFloat(fp);

    // Read in rest depending on type
    switch(Type) {
      case Barrier_Sphere:
        x1 = GetNextFloat(fp);
        y1 = GetNextFloat(fp);
        z1 = GetNextFloat(fp);
        Radius = GetNextFloat(fp);
        AddSphere(ID, Enabled, XPos, YPos, ZPos,              \
                  XRot, YRot, ZRot, x1, y1, z1, Radius);
        break;
      
      case Barrier_Box:
        x1 = GetNextFloat(fp);
        y1 = GetNextFloat(fp);
        z1 = GetNextFloat(fp);
        x2 = GetNextFloat(fp);
        y2 = GetNextFloat(fp);
        z2 = GetNextFloat(fp);
        AddBox(ID, Enabled, XPos, YPos, ZPos,                 \
               XRot, YRot, ZRot, x1, y1, z1, x2, y2, z2);
        break;
      
      case Barrier_Cylinder:
        x1 = GetNextFloat(fp);
        y1 = GetNextFloat(fp);
        z1 = GetNextFloat(fp);
        Radius = GetNextFloat(fp);
        y2 = GetNextFloat(fp);
        AddCylinder(ID, Enabled, XPos, YPos, ZPos,            \
                    XRot, YRot, ZRot, x1, y1, z1, Radius, y2);
        break;
      
      case Barrier_Triangle:
        x1 = GetNextFloat(fp);
        z1 = GetNextFloat(fp);
        x2 = GetNextFloat(fp);
        z2 = GetNextFloat(fp);
        x3 = GetNextFloat(fp);
        z3 = GetNextFloat(fp);
        y1 = GetNextFloat(fp);
        y2 = GetNextFloat(fp);
        AddTriangle(ID, Enabled, XPos, YPos, ZPos,            \
                    XRot, YRot, ZRot,                         \
                    x1, z1, x2, z2, x3, z3, y1, y2);
        break;

      default: fclose(fp);    // Some error occurred
               Free();
               return FALSE;
    }
  }

  fclose(fp);

  return (m_NumBarriers) ? TRUE : FALSE;
}

BOOL cBarrier::Save(char *Filename)
{
  FILE *fp;
  sBarrier *BarrierPtr;

  if(!m_NumBarriers)
    return FALSE;
  if((BarrierPtr = m_BarrierParent) == NULL)
    return FALSE;
  
  // Open file
  if((fp=fopen(Filename, "wb"))==NULL)
    return FALSE;

  // Write out all Barriers
  while(BarrierPtr != NULL) {
    // Write out ID and Type of Barrier
    fprintf(fp, "%lu ", BarrierPtr->ID);
    fprintf(fp, "%lu ", BarrierPtr->Type);

    // Write out Enabled flag
    fprintf(fp, "%lu ", (BarrierPtr->Enabled) ? 1 : 0);

    // Write out coordinates and rotation
    fprintf(fp, "%lf %lf %lf %lf %lf %lf ",                   \
      BarrierPtr->XPos, BarrierPtr->YPos, BarrierPtr->ZPos,   \
      BarrierPtr->XRot, BarrierPtr->YRot, BarrierPtr->ZRot);

    // Write out remaining data depending on type
    switch(BarrierPtr->Type) {
      case Barrier_Sphere:
        fprintf(fp, "%lf %lf %lf %lf\r\n",                    \
                BarrierPtr->x1, BarrierPtr->y1,               \
                BarrierPtr->z1, BarrierPtr->Radius);
        break;
      
      case Barrier_Box:
        fprintf(fp, "%lf %lf %lf %lf %lf %lf\r\n",            \
           BarrierPtr->x1, BarrierPtr->y1, BarrierPtr->z1,    \
           BarrierPtr->x2, BarrierPtr->y2, BarrierPtr->z2);
        break;
      
      case Barrier_Cylinder:
        fprintf(fp, "%lf %lf %lf %lf %lf\r\n",                \
            BarrierPtr->x1, BarrierPtr->y1, BarrierPtr->z1,   \
            BarrierPtr->Radius, BarrierPtr->y2);
        break;
      
      case Barrier_Triangle:
        fprintf(fp, "%lf %lf %lf %lf %lf %lf %lf %lf\r\n",    \
                BarrierPtr->x1, BarrierPtr->z1,               \
                BarrierPtr->x2, BarrierPtr->z2,               \
                BarrierPtr->x3, BarrierPtr->z3,               \
                BarrierPtr->y1, BarrierPtr->y2);
        break;
    }
  }

  fclose(fp);

  return TRUE;
}

sBarrier *cBarrier::AddBarrier(long Type, long ID,            \
                        BOOL Enabled,                         \
                        float XPos, float YPos, float ZPos,   \
                        float XRot, float YRot, float ZRot)
{
  // Allocate a new Barrier structure and link in
  sBarrier *Barrier = new sBarrier();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久精品| 91麻豆国产自产在线观看| 亚洲一二三四区| 亚洲精品国产成人久久av盗摄 | 亚洲日本在线视频观看| 国产女主播一区| 亚洲欧洲精品天堂一级| 亚洲三级电影网站| 亚洲欧美色一区| 一区二区在线免费观看| 亚洲国产日韩综合久久精品| 一区二区三区欧美日韩| 亚洲最新在线观看| 日本在线不卡视频| 国产美女精品在线| 不卡一区二区中文字幕| 色先锋aa成人| 91精品午夜视频| 2021中文字幕一区亚洲| 国产欧美久久久精品影院| 中文字幕一区免费在线观看| 一区二区三区色| 日韩精品视频网站| 国产精品资源站在线| 粉嫩av一区二区三区在线播放| 成人小视频免费观看| 色噜噜狠狠色综合欧洲selulu| 欧美丝袜丝交足nylons图片| 日韩一区二区三区电影在线观看| 久久―日本道色综合久久| 国产精品毛片a∨一区二区三区| 亚洲日本韩国一区| 久久机这里只有精品| 不卡一二三区首页| 欧美电影影音先锋| 国产精品色婷婷久久58| 亚洲图片有声小说| 成人天堂资源www在线| 欧美日韩中文国产| 国产精品三级在线观看| 日韩有码一区二区三区| av成人老司机| 久久久久久免费网| 天天色综合成人网| 波多野结衣亚洲| 精品少妇一区二区| 亚洲一卡二卡三卡四卡无卡久久| 久久99久久99精品免视看婷婷 | 青青草原综合久久大伊人精品优势 | 极品美女销魂一区二区三区| av毛片久久久久**hd| 91精品在线免费观看| 亚洲免费观看高清完整| 激情久久五月天| 欧美日韩高清不卡| 亚洲女厕所小便bbb| 国产精品自在在线| 欧美大尺度电影在线| 亚洲一二三区在线观看| 波多野结衣在线一区| 久久久不卡网国产精品二区| 日韩精品电影一区亚洲| 欧美日韩精品一区二区天天拍小说 | 波多野结衣的一区二区三区| 精品欧美久久久| 日韩专区一卡二卡| 欧美日韩亚洲综合| 性做久久久久久久久| 在线免费观看一区| 亚洲久本草在线中文字幕| 成人黄色片在线观看| 国产三级一区二区| 国产精品自拍毛片| 国产女主播视频一区二区| 国产精品一区一区三区| 国产午夜亚洲精品午夜鲁丝片 | 中文字幕精品在线不卡| 天堂av在线一区| 欧美三级日韩在线| 亚洲一区二区三区免费视频| 91色porny| 亚洲综合在线视频| 欧美色综合影院| 五月激情丁香一区二区三区| 欧美日韩黄色一区二区| 蜜臀av一区二区| 欧美www视频| 国产不卡一区视频| 亚洲一区在线观看网站| 欧美日韩国产三级| 秋霞国产午夜精品免费视频| 日韩免费一区二区| 国产一区二区伦理片| 国产欧美精品在线观看| 成人免费视频免费观看| 亚洲欧洲日韩综合一区二区| 日本道精品一区二区三区| 亚洲一区二区三区四区在线观看| 欧美日韩免费在线视频| 麻豆精品蜜桃视频网站| 国产欧美综合在线观看第十页| 99久久夜色精品国产网站| 亚洲免费视频中文字幕| 欧美一区二区三区精品| 成人晚上爱看视频| 日韩综合在线视频| 国产欧美一区视频| 91国偷自产一区二区使用方法| 日韩国产一二三区| 亚洲国产精品精华液ab| 欧美三级电影网| 国产99精品国产| 亚洲6080在线| 久久久久国产免费免费| 91久久精品一区二区三区| 理论电影国产精品| 亚洲精品一二三| 精品日韩欧美在线| 欧美在线一二三四区| 国产精品一区二区在线看| 一区二区不卡在线播放| 久久久国产综合精品女国产盗摄| 色综合av在线| 国产综合色产在线精品 | 欧美三级日本三级少妇99| 九九视频精品免费| 亚洲一级在线观看| 国产精品免费av| 亚洲裸体在线观看| 精品99久久久久久| 欧美日韩久久不卡| 色偷偷成人一区二区三区91| 国产高清精品久久久久| 天天av天天翘天天综合网| 国产精品国产三级国产aⅴ中文 | 国产一区二区在线观看视频| 亚洲一区影音先锋| 亚洲少妇屁股交4| 国产视频视频一区| 欧美v日韩v国产v| 欧美丰满一区二区免费视频 | 一区二区在线电影| 国产精品理伦片| 久久美女艺术照精彩视频福利播放| 欧美日韩国产123区| 欧美在线免费观看亚洲| 色综合中文字幕| 99久久99久久综合| jvid福利写真一区二区三区| 成人综合婷婷国产精品久久蜜臀| 国内外精品视频| 国产一区亚洲一区| 国产福利不卡视频| 国产精品69毛片高清亚洲| 韩国精品久久久| 国产成人免费网站| 99久久婷婷国产综合精品电影| 国产成人在线看| aa级大片欧美| 91福利在线播放| 欧美日韩精品欧美日韩精品一| 欧美喷水一区二区| 日韩欧美一卡二卡| 久久精品人人爽人人爽| 国产欧美日韩不卡| 亚洲精品网站在线观看| 亚洲一区二区三区四区不卡| 亚洲成人精品影院| 免费看黄色91| 国产精品一区在线观看乱码| 国产suv精品一区二区三区| 成人综合婷婷国产精品久久| 96av麻豆蜜桃一区二区| 欧美系列一区二区| 日韩精品一区在线| 日本一区二区三级电影在线观看| 日本一区二区视频在线| 亚洲精品你懂的| 青青草成人在线观看| 国产91丝袜在线播放九色| 91麻豆精品视频| 日韩区在线观看| 国产精品九色蝌蚪自拍| 水蜜桃久久夜色精品一区的特点| 精品在线播放午夜| 99精品一区二区| 日韩精品一区二区三区在线| 中文字幕av一区二区三区| 亚洲不卡一区二区三区| 国产精品888| 欧美日韩一区二区三区四区五区| 精品免费国产一区二区三区四区| 亚洲国产高清aⅴ视频| 亚洲成人自拍一区| 成人夜色视频网站在线观看| 在线播放亚洲一区| 国产精品成人一区二区三区夜夜夜| 视频在线在亚洲| 94-欧美-setu| 久久久久久久综合日本|