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

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

?? planescene.pas

?? DSPack is a set of Components and class to write Multimedia Applications using MS Direct Show and Di
?? PAS
字號:
//------------------------------------------------------------------------------
// File: PlaneScene.h & PlaneScene.cpp
//
// Desc: DirectShow sample code - interface for the TPlaneScene class
//
//  Portions created by Microsoft are
//  Copyright (C) 2002 Microsoft Corporation.
//  All Rights Reserved.
//
//  The initial developer of the Pascal code is Henri GOURVEST
//    Email    : hgourvest@progdigy.com
//    WebSite  : http://www.progdigy.com
//------------------------------------------------------------------------------

unit PlaneScene;

interface
uses Direct3D9;
const
  NUM_VERTICES = 4;

type
  TPosition = record
    x,y,z: Single;
  end;

  TCustomVertex = record
    Position: TPosition;
    Color: D3DCOLOR; // The color
    tu, tv: Single;  // The texture coordinates
  end;

  TPlaneScene = class
  private
    Fvertices: array[0..NUM_VERTICES-1] of TCustomVertex;
    FvertexBuffer: IDirect3DVertexBuffer9;
    Ftime: Int64;
  public
    constructor Create;
    function Init(d3ddev: IDirect3DDevice9): HRESULT;
    function DrawScene(d3ddev: IDirect3DDevice9; texture: IDirect3DTexture9): HRESULT;
    procedure SetSrcRect(fTU, fTV: Single);
  end;
implementation
uses Windows, D3DX9;

const
  D3DFVF_CUSTOMVERTEX = D3DFVF_XYZ or D3DFVF_DIFFUSE or D3DFVF_TEX1;

function MakePosition(x, y, z: Single): TPosition;
begin
  result.x := x;
  result.y := y;
  result.z := z;
end;

{ TPlaneScene }

constructor TPlaneScene.Create;
begin
  Fvertices[0].position := MakePosition(-1.0,  1.0, 0.0); // top left
  Fvertices[1].position := MakePosition(-1.0, -1.0, 0.0); // bottom left
  Fvertices[2].position := MakePosition( 1.0,  1.0, 0.0); // top right
  Fvertices[3].position := MakePosition( 1.0, -1.0, 0.0); // bottom right

  // set up diffusion:
  Fvertices[0].color := $ffffffff;
  Fvertices[1].color := $ff0000ff;
  Fvertices[2].color := $ffffffff;
  Fvertices[3].color := $ff0000ff;

  // set up texture coordinates
  Fvertices[0].tu := 0.0; Fvertices[0].tv := 0.0; // low left
  Fvertices[1].tu := 0.0; Fvertices[1].tv := 1.0; // high left
  Fvertices[2].tu := 1.0; Fvertices[2].tv := 0.0; // low right
  Fvertices[3].tu := 1.0; Fvertices[3].tv := 1.0; // high right
end;

function TPlaneScene.DrawScene(d3ddev: IDirect3DDevice9;
  texture: IDirect3DTexture9): HRESULT;
  function FailRet(hr: HResult): boolean;
  begin
    DrawScene := hr;
    Result := Failed(hr);
  end;
var
  dwCurrentTime: DWord;
  difference: Int64;
  x, y, z: Single;
  mask0, mask3: DWord;
  pData: Pointer;
begin
  if ((d3ddev = nil) or (texture = nil)) then
  begin
    Result := E_POINTER;
    Exit;
  end;

  if( FvertexBuffer = nil) then
  begin
    Result := D3DERR_INVALIDCALL;
    Exit;
  end;

  // get the difference in time
  dwCurrentTime := GetTickCount;
  difference := Ftime - dwCurrentTime;

  // figure out the rotation of the plane
  x := -cos(difference / 2000);
  y :=  cos(difference / 2000);
  z :=  sin(difference / 2000);

  // update the two rotating vertices with the new position
  Fvertices[0].position := MakePosition(x,   y,  z); // top left
  Fvertices[3].position := MakePosition(-x, -y, -z); // bottom right

  // Adjust the color so the blue is always on the bottom.
  // As the corner approaches the bottom, get rid of all the other
  // colors besides blue
  mask0 := Trunc((255 * (( y + 1) / 2)));
  mask3 := Trunc((255 * ((-y + 1) / 2)));
  Fvertices[0].color := $ff0000ff or (mask0 shl 16) or (mask0 shl 8);
  Fvertices[3].color := $ff0000ff or (mask3 shl 16) or (mask3 shl 8);

  // write the new vertex information into the buffer
  if FailRet(FvertexBuffer.Lock(0, sizeof(pData), pData, 0)) then exit;
  move(Fvertices, pData^ , sizeof(Fvertices));
  if FailRet(FvertexBuffer.Unlock) then exit;

  // clear the scene so we don't have any articats left
  d3ddev.Clear(0, nil, D3DCLEAR_TARGET, D3DCOLOR_XRGB(255,255,255), 1.0, 0);

  if FailRet(d3ddev.BeginScene) then exit;
  if FailRet(d3ddev.SetTexture(0, texture)) then exit;

  if FailRet(d3ddev.SetTextureStageState(0, D3DTSS_ALPHAOP, D3DTOP_MODULATE)) then exit;
  if FailRet(d3ddev.SetTextureStageState(0, D3DTSS_ALPHAARG1, D3DTA_TEXTURE)) then exit;
  if FailRet(d3ddev.SetTextureStageState(0, D3DTSS_ALPHAARG2, D3DTA_DIFFUSE)) then exit;
  if FailRet(d3ddev.SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE)) then exit;

  if FailRet(d3ddev.SetStreamSource(0, FvertexBuffer, 0, sizeof(TCustomVertex))) then exit;            //set next source ( NEW )
  if FailRet(d3ddev.SetFVF(D3DFVF_CUSTOMVERTEX)) then exit;
  if FailRet(d3ddev.DrawPrimitive(D3DPT_TRIANGLESTRIP, 0, 2)) then exit;  //draw quad
  if FailRet(d3ddev.SetTexture(0, nil)) then exit;
  if FailRet(d3ddev.EndScene) then exit;
end;

function TPlaneScene.Init(d3ddev: IDirect3DDevice9): HRESULT;
  function FailRet(hr: HResult): boolean;
  begin
    Init := hr;
    Result := Failed(hr);
  end;
var
  backBuffer: IDirect3DSurface9;
  backBufferDesc: TD3DSurfaceDesc;
  matProj, matView: TD3DXMatrix;
  fAspect: Single;
  from, at, up: TD3DXVector3;
begin
  if(d3ddev = nil) then
  begin
    Result := E_POINTER;
    Exit;
  end;

  if FailRet(d3ddev.SetRenderState(D3DRS_CULLMODE, D3DCULL_NONE)) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_LIGHTING, Cardinal(FALSE))) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_ALPHABLENDENABLE, Cardinal(TRUE))) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA)) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_DESTBLEND, D3DBLEND_INVSRCALPHA)) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_ALPHATESTENABLE, Cardinal(TRUE))) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_ALPHAREF, $10)) then exit;
  if FailRet(d3ddev.SetRenderState(D3DRS_ALPHAFUNC, D3DCMP_GREATER)) then exit;

  if FailRet(d3ddev.SetSamplerState(0, D3DSAMP_ADDRESSU, D3DTADDRESS_CLAMP)) then exit;
  if FailRet(d3ddev.SetSamplerState(0, D3DSAMP_ADDRESSV, D3DTADDRESS_CLAMP)) then exit;
  if FailRet(d3ddev.SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR)) then exit;
  if FailRet(d3ddev.SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR)) then exit;
  if FailRet(d3ddev.SetSamplerState(0, D3DSAMP_MIPFILTER, D3DTEXF_LINEAR)) then exit;

  FvertexBuffer := nil;

  d3ddev.CreateVertexBuffer(sizeof(Fvertices),D3DUSAGE_WRITEONLY,D3DFVF_CUSTOMVERTEX,D3DPOOL_MANAGED, FvertexBuffer, nil);

  if FailRet(d3ddev.GetBackBuffer(0, 0, D3DBACKBUFFER_TYPE_MONO, backBuffer)) then exit;

  backBuffer.GetDesc(backBufferDesc);

  // Set the projection matrix

  fAspect := backBufferDesc.Width / backBufferDesc.Height;
  D3DXMatrixPerspectiveFovLH(matProj, D3DX_PI/4, fAspect, 1.0, 100.0);
  if FailRet(d3ddev.SetTransform(D3DTS_PROJECTION, matProj)) then exit;


  from := D3DXVECTOR3(1.0, 1.0, -3.0);
  at   := D3DXVECTOR3(0.0, 0.0,  0.0);
  up   := D3DXVECTOR3(0.0, 1.0,  0.0);

  D3DXMatrixLookAtLH(matView, from, at, up);
  if FailRet(d3ddev.SetTransform(D3DTS_VIEW, matView)) then exit;

  Ftime := GetTickCount;
end;

procedure TPlaneScene.SetSrcRect(fTU, fTV: Single);
begin
  Fvertices[0].tu := 0.0; Fvertices[0].tv := 0.0; // low left
  Fvertices[1].tu := 0.0; Fvertices[1].tv := fTV; // high left
  Fvertices[2].tu := fTU; Fvertices[2].tv := 0.0; // low right
  Fvertices[3].tu := fTU; Fvertices[3].tv := fTV; // high right
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
视频一区二区欧美| 91麻豆精品国产91久久久资源速度 | 色综合天天在线| 福利一区福利二区| 国产乱子轮精品视频| 狠狠色丁香婷婷综合| 久久99热这里只有精品| 久久99国产精品免费网站| 蜜臀91精品一区二区三区| 日本成人在线网站| 久久精品国产久精国产| 韩国女主播成人在线观看| 国产精品主播直播| 成人免费视频网站在线观看| 不卡高清视频专区| 色婷婷激情综合| 欧美视频你懂的| 午夜欧美在线一二页| 午夜影院久久久| 日韩中文字幕麻豆| 国模冰冰炮一区二区| 国产成人午夜精品影院观看视频| 国产精品1024久久| 99久免费精品视频在线观看| 日本精品一区二区三区四区的功能| 色av一区二区| 91精品国产91久久久久久最新毛片| 欧美一区二区三区四区在线观看| 精品处破学生在线二十三| 欧美国产精品中文字幕| 亚洲欧美一区二区三区极速播放 | 国产真实乱子伦精品视频| 国产精华液一区二区三区| 99久久亚洲一区二区三区青草| 色视频成人在线观看免| 777精品伊人久久久久大香线蕉| 欧美电视剧在线看免费| 中文乱码免费一区二区| 亚洲午夜精品在线| 久久国产生活片100| 99久久精品国产一区二区三区| 欧美天堂亚洲电影院在线播放| 日韩一级大片在线观看| 国产精品电影一区二区| 五月天激情综合网| 高清国产午夜精品久久久久久| 91久色porny | 99精品欧美一区二区三区综合在线| 色激情天天射综合网| 日韩美女视频在线| 亚洲欧洲成人自拍| 日韩国产在线一| 成人免费视频免费观看| 一区二区三区在线免费观看| 日本不卡不码高清免费观看| 成人av在线资源网站| 67194成人在线观看| 国产精品久久久一区麻豆最新章节| 婷婷久久综合九色综合绿巨人| 国产精品99久久不卡二区| 欧美视频三区在线播放| 国产欧美久久久精品影院| 日韩制服丝袜先锋影音| 成+人+亚洲+综合天堂| 欧美电影免费提供在线观看| 一区二区三区四区蜜桃| 国产福利一区二区三区视频| 欧美另类变人与禽xxxxx| 欧美韩国日本一区| 久久国产精品99精品国产| 91成人在线观看喷潮| 欧美国产丝袜视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 色欧美日韩亚洲| 国产日产精品1区| 久久精品免费观看| 欧美男男青年gay1069videost| 国产精品欧美一级免费| 韩国三级中文字幕hd久久精品| 欧美日韩国产高清一区二区| 亚洲天堂免费看| 国产成人av福利| 精品国产91久久久久久久妲己 | 国产福利不卡视频| 91精品国产麻豆| 亚洲一区二区av在线| 波多野结衣亚洲| 久久精品无码一区二区三区| 麻豆精品在线视频| 制服丝袜在线91| 亚洲一区在线观看视频| 99视频精品全部免费在线| 国产农村妇女精品| 国产麻豆视频精品| 精品日本一线二线三线不卡| 日本在线不卡视频| 欧美一级在线视频| 五月天中文字幕一区二区| 欧美日韩在线播| 亚洲国产日日夜夜| 欧美日韩一区 二区 三区 久久精品| 亚洲同性同志一二三专区| 成人激情综合网站| 最好看的中文字幕久久| av动漫一区二区| 亚洲婷婷国产精品电影人久久| av在线这里只有精品| 中文字幕在线观看不卡| 波多野结衣中文一区| 中文字幕一区二区三区不卡| 99riav一区二区三区| 亚洲欧美另类小说| 欧美三级韩国三级日本一级| 亚洲aaa精品| 欧美一区二区三区电影| 欧美一级高清大全免费观看| 日本成人在线电影网| 日韩精品影音先锋| 国产一区二区三区四| 亚洲国产精品t66y| 色综合色综合色综合| 亚洲国产精品尤物yw在线观看| 欧美男男青年gay1069videost| 日韩av中文字幕一区二区三区| 欧美videossexotv100| 国产一区二区三区四| 国产精品护士白丝一区av| 91免费在线看| 天堂成人国产精品一区| 日韩精品中文字幕在线不卡尤物| 国产精品影音先锋| 亚洲欧美日韩中文播放 | 亚洲精品视频一区| 欧美日韩国产综合一区二区| 免费三级欧美电影| 国产精品午夜在线| 91久久线看在观草草青青| 丝瓜av网站精品一区二区| 2024国产精品| 一本大道久久a久久综合婷婷| 亚洲国产aⅴ天堂久久| 欧美tk—视频vk| 91同城在线观看| 全国精品久久少妇| 国产精品成人免费在线| 欧美女孩性生活视频| 国产精品18久久久久久久网站| 亚洲欧美电影一区二区| 欧美电影免费观看高清完整版| 成人激情午夜影院| 日本三级韩国三级欧美三级| 国产欧美精品区一区二区三区| 在线观看日韩精品| 国产一区二区影院| 亚洲国产一区二区a毛片| 久久久久久久久久久久久久久99 | 国产精品亚洲一区二区三区妖精 | 免费不卡在线视频| 国产精品电影一区二区| 91精品国产免费久久综合| av不卡一区二区三区| 日本在线不卡视频| 亚洲欧美日韩国产中文在线| 精品国产一二三区| 欧美探花视频资源| 成人成人成人在线视频| 麻豆精品国产91久久久久久| 亚洲情趣在线观看| 久久久久久影视| 7777精品伊人久久久大香线蕉的 | 亚洲乱码国产乱码精品精小说| 欧美一区二区成人| 日本电影欧美片| 国产福利一区二区| 久久精品国产99国产精品| 亚洲国产成人tv| 亚洲视频一区在线观看| 久久精品人人做人人综合| 欧美一区二区免费观在线| 欧美性猛片aaaaaaa做受| kk眼镜猥琐国模调教系列一区二区| 美女视频黄a大片欧美| 亚洲国产视频一区| 亚洲欧洲制服丝袜| 欧美国产一区二区| 精品电影一区二区| 91精品国产高清一区二区三区蜜臀 | 精品亚洲porn| 日韩一区精品字幕| 亚洲一二三区视频在线观看| 国产精品精品国产色婷婷| 久久精品亚洲精品国产欧美kt∨ | 国产午夜精品久久久久久免费视| 7777精品伊人久久久大香线蕉的| 色国产综合视频| 99久久99久久综合| 99久免费精品视频在线观看 | 欧美少妇xxx| 色老综合老女人久久久| 99精品视频一区|