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

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

?? cameraclass.pas

?? 在Delphi利用opengl調用3ds文件并且添加背景帖圖。
?? PAS
字號:
unit CameraClass;

interface

  Uses OpenGL, Windows;

  type TVector3f = Record
    X, Y, Z : glFloat;
  end;

  type TCamera = Object
    Position : TVector3f;      // The camera's position
    View     : TVector3f;      // The camera's View
    UpVector : TVector3f;      // The camera's UpVector
    procedure PositionCamera(positionX, positionY, positionZ : glFloat;
			     viewX, viewY, viewZ : glFloat;
			     upVectorX, upVectorY, upVectorZ : glFloat);
    procedure RotateView(const X, Y, Z : glFloat);
    procedure MoveCameraByMouse();
    procedure RotateAroundPoint(const Center : TVector3f; const X, Y, Z : glFloat);
    procedure StrafeCamera(speed : glFloat);
    procedure MoveCamera(speed : glFloat);
  end;

  var SCREEN_WIDTH, SCREEN_HEIGHT : Integer;


implementation


{ TCamera }


{------------------------------------------------------------------------}
{--- This function sets the camera's position and view and up vVector ---}
{------------------------------------------------------------------------}
procedure TCamera.PositionCamera(positionX, positionY, positionZ, viewX,
  viewY, viewZ, upVectorX, upVectorY, upVectorZ: glFloat);
begin
  Position.X := PositionX;
  Position.Y := PositionY;
  Position.Z := PositionZ;

  View.X     := ViewX;
  View.Y     := ViewY;
  View.Z     := ViewZ;

  UpVector.X := UpVectorX;
  UpVector.Y := UpVectorY;
  UpVector.Z := UpVectorZ;
end;


{-----------------------------------------------------------------------------}
{--- This will move the camera forward or backward depending on the speed  ---}
{-----------------------------------------------------------------------------}
procedure TCamera.MoveCamera(speed: glFloat);
var V : TVector3f;
begin
  // Get our view vVector (The direciton we are facing)
  V.X := View.X - Position.X;              // This gets the direction of the X
  V.Y := View.Y - Position.Y;              // This gets the direction of the Y
  V.Z := View.Z - Position.Z;              // This gets the direction of the Z

  Position.X := Position.X + V.X * speed;  // Add our acceleration to our position's X
  Position.Y := Position.Y + V.Y * speed;  // Add our acceleration to our position's Y
  Position.Z := Position.Z + V.Z * speed;  // Add our acceleration to our position's Z
  View.X := View.X + V.X * speed;          // Add our acceleration to our view's X
  View.Y := View.Y + V.Y * speed;          // Add our acceleration to our view's Y
  View.Z := View.Z + V.Z * speed;          // Add our acceleration to our view's Z
end;


{-----------------------------------------------------------}
{--- The mouse look function. Use mouse to look around   ---}
{-----------------------------------------------------------}
procedure TCamera.MoveCameraByMouse;
var mousePos : TPoint;
    middleX, middleY : Integer;
    deltaY, rotateY : glFloat;
begin
  middleX := SCREEN_WIDTH SHR 1;       // This is a binary shift to get half the width
  middleY := SCREEN_HEIGHT SHR 1;      // This is a binary shift to get half the height

  // Get the mouse's current X,Y position
  GetCursorPos(mousePos);

  // If our cursor is still in the middle, we never moved... so don't update the screen
  if (mousePos.X = middleX) AND (mousePos.Y = middleY) then
    exit;

  // Set the mouse position to the middle of our window
  SetCursorPos(middleX, middleY);

  // Get the direction the mouse moved in, but bring the number down to a reasonable amount
  rotateY := (middleX - mousePos.X)/500;
  deltaY  := (middleY - mousePos.Y)/1000;

  // Multiply the direction vVector for Y by an acceleration (The higher the faster is goes).
  View.Y := View.Y + deltaY*5;

  // Check if the distance of our view exceeds 60 from our position, if so, stop it. (UP)
  if View.Y - Position.Y > 10 then
     View.Y := Position.Y + 10;

  // Check if the distance of our view exceeds -60 from our position, if so, stop it. (DOWN)
  if View.Y - Position.Y < -10 then
     View.Y := Position.Y - 10;

  // Here we rotate the view along the X avis depending on the direction (Left of Right)
  RotateView(0, -rotateY, 0);
end;




{---------------------------------------------------------------------}
{--- This strafes the camera left and right depending on the speed ---}
{---------------------------------------------------------------------}
procedure TCamera.StrafeCamera(speed: glFloat);
var Cross, ViewVector : TVector3f;
begin
  // Initialize a variable for the cross product result
  Cross.X :=0;
  Cross.Y :=0;
  Cross.Z :=0;

  // Get the view vVector of our camera and store it in a local variable
  ViewVector.X := View.X - Position.X;
  ViewVector.Y := View.Y - Position.Y;
  ViewVector.Z := View.Z - Position.Z;

  // Calculate the cross product of our up vVector and view vVector
  Cross.X := (UpVector.Y * ViewVector.Z) - (UpVector.Z * ViewVector.Y);   // (V1.Y * V2.Z) - (V1.Z * V2.Y)
  Cross.Y := (UpVector.Z * ViewVector.X) - (UpVector.X * ViewVector.Z);   // (V1.Z * V2.X) - (V1.X * V2.Z)
  Cross.Z := (UpVector.X * ViewVector.Y) - (UpVector.Y * ViewVector.X);   // (V1.X * V2.Y) - (V1.Y * V2.X)

  // Add the resultant vVector to our position
  Position.X := Position.X + Cross.X * speed;
  Position.Z := Position.Z + Cross.Z * speed;

  // Add the resultant vVector to our view
  View.X := View.X + Cross.X * speed;
  View.Z := View.Z + Cross.Z * speed;
end;


{-----------------------------------------------------------}
{--- This rotates the view around the position           ---}
{-----------------------------------------------------------}
procedure TCamera.RotateView(const X, Y, Z: glFloat);
var vVector : TVector3f;
begin
  // Get our view vVector (The direction we are facing)
  vVector.X := View.X - Position.X;          // This gets the direction of the X
  vVector.Y := View.Y - Position.Y;          // This gets the direction of the Y
  vVector.Z := View.Z - Position.Z;          // This gets the direction of the Z

  // If we pass in a negative X Y or Z, it will rotate the opposite way,
  // so we only need one function for a left and right, up or down rotation.
  if X <> 0 then
  begin
    View.Z := Position.Z + sin(X)*vVector.Y + cos(X)*vVector.Z;
    View.Y := Position.Y + cos(X)*vVector.Y - sin(X)*vVector.Z;
  end;

  if Y <> 0 then
  begin
    View.Z := Position.Z + sin(Y)*vVector.X + cos(Y)*vVector.Z;
    View.X := Position.X + cos(Y)*vVector.X - sin(Y)*vVector.Z;
  end;

  if Z <> 0 then
  begin
    View.X := Position.X + sin(Z)*vVector.Y + cos(Z)*vVector.X;
    View.Y := Position.Y + cos(Z)*vVector.Y - sin(Z)*vVector.X
  end;
end;


{-------------------------------------------------------------}
{--- This rotates the camera position around a given point ---}
{-------------------------------------------------------------}
procedure TCamera.RotateAroundPoint(const Center: TVector3f; const X, Y, Z: glFloat);
var viewVector : TVector3f;
begin
  // Get the viewVector from our position to the center we are rotating around
  viewVector.X := Position.X - Center.X;          // This gets the direction of the X
  viewVector.Y := Position.Y - Center.Y;          // This gets the direction of the Y
  viewVector.Z := Position.Z - Center.Z;          // This gets the direction of the Z

  // Rotate the position up or down, then add it to the center point
  if X <> 0 then
  begin
    Position.Z := Center.Z + sin(X)*viewVector.Y + cos(X)*viewVector.Z;
    Position.Y := Center.Y + cos(X)*viewVector.Y - sin(X)*viewVector.Z;
  end;

  if Y <> 0 then
  begin
    Position.Z := Center.Z + sin(Y)*viewVector.X + cos(Y)*viewVector.Z;
    Position.X := Center.X + cos(Y)*viewVector.X - sin(Y)*viewVector.Z;
  end;

  if Z <> 0 then
  begin
    Position.X := Center.X + sin(Z)*viewVector.Y + cos(Z)*viewVector.X;
    Position.Y := Center.Y + cos(Z)*viewVector.Y - sin(Z)*viewVector.X
  end;
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
老司机精品视频线观看86| 高清国产一区二区| 欧美日韩一区中文字幕| 日韩黄色在线观看| 色综合久久综合网| 亚洲成人精品一区| 久久这里只有精品6| 国产91在线看| 天堂va蜜桃一区二区三区漫画版| 91精品国产综合久久福利| 久久国产精品99久久人人澡| 日韩一区二区在线观看视频 | 亚洲欧美中日韩| 91国产丝袜在线播放| 另类中文字幕网| 成人欧美一区二区三区| 91麻豆国产精品久久| 日本美女一区二区三区| 国产欧美日韩另类一区| 欧美一区日韩一区| 欧美专区日韩专区| av影院午夜一区| 精品伊人久久久久7777人| 午夜一区二区三区视频| 亚洲欧洲在线观看av| 精品国产乱码久久久久久免费 | 精品久久一二三区| 欧美精品 日韩| 国产精品自在欧美一区| 午夜电影一区二区| 亚洲自拍与偷拍| 亚洲二区视频在线| 亚洲电影一区二区| 亚洲成国产人片在线观看| 国产精品免费aⅴ片在线观看| 国产亚洲成年网址在线观看| 精品国产免费视频| 亚洲精品一线二线三线| 国产亚洲成av人在线观看导航 | 成人avav影音| 亚洲黄色免费网站| 国产精品三级av| www激情久久| 亚洲色欲色欲www在线观看| 日韩久久一区二区| 日韩影院免费视频| 黑人巨大精品欧美一区| 99国产麻豆精品| 欧美视频在线一区| 精品国精品自拍自在线| 中文字幕一区二区日韩精品绯色 | 亚洲欧美日本在线| 婷婷夜色潮精品综合在线| 老司机精品视频线观看86| 国产成人av在线影院| 欧美午夜免费电影| 国产精品免费人成网站| 成人欧美一区二区三区在线播放| 亚洲视频一二三| 精品综合免费视频观看| 色av成人天堂桃色av| 欧美成人bangbros| 亚洲自拍偷拍麻豆| 99精品桃花视频在线观看| 日韩欧美第一区| 日韩 欧美一区二区三区| 不卡欧美aaaaa| 欧美激情一区二区三区全黄| 青青草原综合久久大伊人精品 | 精品久久一区二区三区| 一区二区三区免费在线观看| 美女视频黄 久久| 欧美日韩午夜在线视频| 亚洲自拍偷拍av| 99精品在线观看视频| 中文字幕欧美一区| 91亚洲午夜精品久久久久久| 中文字幕免费观看一区| 高清不卡在线观看| 日本一区二区三区免费乱视频| 久久国产婷婷国产香蕉| 精品乱人伦小说| 国产不卡视频在线观看| 久久久久久久网| 97精品电影院| 亚洲第一搞黄网站| 欧美一区二区免费| 国产精品1区2区| 亚洲天天做日日做天天谢日日欢 | 一区二区三区高清不卡| 欧美性生活影院| 狠狠色丁香婷综合久久| 国产精品福利一区| 欧美日韩视频在线第一区| 久久激情综合网| 国产精品九色蝌蚪自拍| 在线观看日韩毛片| 国产精品亚洲专一区二区三区| 国产精品精品国产色婷婷| 欧美一卡二卡在线观看| 色婷婷综合久久久中文一区二区| 美腿丝袜亚洲一区| 亚洲成人在线网站| 国产欧美中文在线| 欧美三级日韩在线| av电影天堂一区二区在线观看| 日韩和欧美的一区| 亚洲在线一区二区三区| 国产精品久久久久天堂| 精品国产污网站| 欧美成人综合网站| 欧美麻豆精品久久久久久| 91丨porny丨在线| 91丨porny丨蝌蚪视频| 成人永久aaa| 97精品国产97久久久久久久久久久久 | 国产精品一区二区在线观看网站| 日韩精品成人一区二区三区| 亚洲综合激情网| 性久久久久久久| 日本网站在线观看一区二区三区| 亚洲欧洲日韩一区二区三区| 国产精品久久久久久久久免费相片| 久久久亚洲高清| 国产精品青草综合久久久久99| 亚洲精品在线免费观看视频| 久久精品免费在线观看| 国产精品女上位| 亚洲美女视频一区| 七七婷婷婷婷精品国产| 国产一区二区三区免费播放| 99免费精品视频| 欧美一三区三区四区免费在线看| 欧美一区二区福利视频| 椎名由奈av一区二区三区| 亚洲亚洲人成综合网络| 国产中文字幕精品| 91网站在线播放| 国产人久久人人人人爽| 午夜精品免费在线观看| 精品一区二区久久| 91女人视频在线观看| 日韩限制级电影在线观看| 亚洲三级理论片| 国产一区二区三区不卡在线观看| 色噜噜狠狠成人网p站| 日韩三级免费观看| 亚洲欧美日韩在线| 国产精品一区二区果冻传媒| 6080国产精品一区二区| 一区二区三区中文字幕电影| 国产一区二区美女| 久久综合九色综合97_久久久| 亚洲久草在线视频| zzijzzij亚洲日本少妇熟睡| 日韩一级高清毛片| 日本欧美一区二区三区乱码 | 国产精品资源在线看| 欧美一区二区高清| 午夜精品一区二区三区三上悠亚 | 国内精品自线一区二区三区视频| 欧美色图片你懂的| 日韩福利电影在线观看| 欧美日韩一区二区三区在线| 亚洲综合一区二区| 在线观看www91| 美腿丝袜在线亚洲一区 | 亚洲精品在线观看网站| 粉嫩av亚洲一区二区图片| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国产精品久久久久影视| 在线观看国产一区二区| 日韩成人免费在线| 国产欧美日韩另类视频免费观看| 成人免费视频免费观看| 日韩电影在线免费观看| 国产欧美视频在线观看| 欧美中文字幕不卡| 黄一区二区三区| 亚洲女人****多毛耸耸8| 欧美一区二区私人影院日本| 成人性色生活片免费看爆迷你毛片| 亚洲欧美在线视频| 日韩亚洲欧美成人一区| 99久久国产综合精品色伊| 蜜桃视频一区二区三区| 国产精品77777| 亚洲人成网站精品片在线观看| 欧美精品一二三区| 国产精品情趣视频| 欧美一区二区久久| 欧美日韩情趣电影| 色av成人天堂桃色av| 亚洲欧美在线视频| 日本一区二区三区视频视频| 日韩一区二区三区三四区视频在线观看| 成人动漫一区二区在线| 国产精品99久久久久久有的能看| 首页亚洲欧美制服丝腿| 亚洲成年人影院|