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

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

?? planescene.pas

?? 為Delphi2005做了改動 DSPack 2.3.3 (Sep 2004). DSPack is a set of Components and class to write Multimedia
?? 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.

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产一区久久| 欧美一级片在线| 久久久久青草大香线综合精品| 婷婷开心激情综合| 日韩一区二区三区在线| 欧美日免费三级在线| 一区二区三区波多野结衣在线观看| 成人黄页毛片网站| 一区二区三区欧美| 欧美一区二区视频网站| 九九**精品视频免费播放| 久久久久久久综合色一本| 99热在这里有精品免费| 亚洲国产精品天堂| 精品欧美一区二区三区精品久久 | 91精品国产入口| 美女一区二区久久| 国产欧美日韩麻豆91| 91天堂素人约啪| 奇米色一区二区| 国产欧美日产一区| 欧美三级日韩三级| 国产精品综合在线视频| 日韩毛片视频在线看| 这里是久久伊人| 国产成人免费9x9x人网站视频| 亚洲美女淫视频| 91精品在线观看入口| 大桥未久av一区二区三区中文| 亚洲免费资源在线播放| 欧美一级在线视频| 91麻豆免费看| 极品少妇一区二区三区精品视频| 国产精品伦理在线| 91精品视频网| 91色porny在线视频| 激情五月婷婷综合网| 亚洲狼人国产精品| 久久久久久久网| 欧美日本在线一区| av日韩在线网站| 韩国v欧美v日本v亚洲v| 一区二区三区国产精华| 久久嫩草精品久久久精品| 欧美三级三级三级| 99久久婷婷国产综合精品电影| 免费黄网站欧美| 亚洲一区二区av电影| 国产性做久久久久久| 欧美网站一区二区| 国产99久久精品| 精品亚洲aⅴ乱码一区二区三区| 夜夜夜精品看看| 亚洲欧洲精品天堂一级| 久久久噜噜噜久久人人看| 欧美日韩电影一区| 欧美在线视频日韩| 91网站视频在线观看| 国产成a人无v码亚洲福利| 美女免费视频一区二区| 五月天久久比比资源色| 一区二区三区精品视频| 中文字幕在线观看一区| 国产人妖乱国产精品人妖| 欧美精品一区二区三区蜜臀| 91精品蜜臀在线一区尤物| 欧美日韩免费观看一区三区| 91免费观看视频| 99久久婷婷国产综合精品| 成人高清视频在线| 国产a视频精品免费观看| 黑人精品欧美一区二区蜜桃 | 日韩精品1区2区3区| 亚洲综合视频在线| 亚洲视频一二三区| 自拍偷拍亚洲激情| 亚洲欧美日韩久久精品| 亚洲欧洲韩国日本视频| 欧美日韩高清影院| 亚洲高清免费在线| 亚洲综合在线第一页| 综合久久久久久久| 亚洲免费av高清| 亚洲电影中文字幕在线观看| 亚洲一区精品在线| 亚洲一区二区欧美日韩| 午夜精品在线视频一区| 亚洲国产成人91porn| 天堂一区二区在线免费观看| 日本亚洲电影天堂| 免费在线看一区| 精品一区二区国语对白| 国产成人自拍在线| 99久久国产综合色|国产精品| 不卡一二三区首页| 欧美视频完全免费看| 777奇米成人网| 精品久久99ma| 中文一区一区三区高中清不卡| 国产精品电影院| 亚洲国产欧美一区二区三区丁香婷| 亚洲成人三级小说| 国产真实乱偷精品视频免| 国产成人精品一区二| 青青草视频一区| 亚洲国产精品精华液2区45| 国产精品入口麻豆九色| 亚洲人成网站在线| 午夜日韩在线观看| 久久99精品久久只有精品| 国产成人免费视| 在线观看av一区二区| 日韩久久精品一区| 国产精品久久影院| 天天综合网天天综合色| 国产一区二区三区综合| 色综合色狠狠天天综合色| 欧美一卡2卡三卡4卡5免费| 国产欧美一区二区三区网站 | 日本一区二区免费在线| 亚洲一区视频在线| 国产一区日韩二区欧美三区| 色又黄又爽网站www久久| 精品美女被调教视频大全网站| 欧美国产视频在线| 日韩电影在线一区| av一本久道久久综合久久鬼色| 黄网站免费久久| 亚洲色图20p| 久久国产精品色| 91国偷自产一区二区三区观看| 91精品国产全国免费观看| 欧美国产成人精品| 日韩电影一区二区三区| 成人不卡免费av| 日韩欧美国产不卡| 一区二区三区精品| 不卡一卡二卡三乱码免费网站| 欧美日本韩国一区二区三区视频 | 一二三区精品福利视频| 国产精品一区二区91| 777午夜精品视频在线播放| 国产精品久久久久影院亚瑟| 青青草国产精品亚洲专区无| 色综合久久88色综合天天免费| 欧美精品一区二| 日精品一区二区| 欧美在线一区二区| 亚洲三级小视频| 成人h动漫精品| 久久久久国产成人精品亚洲午夜 | 韩国v欧美v亚洲v日本v| 国产精品国模大尺度视频| 欧美丝袜自拍制服另类| 欧美国产日本韩| 精品在线免费观看| 欧美久久高跟鞋激| 午夜精品久久久久影视| 色婷婷综合久久久中文字幕| 欧美经典三级视频一区二区三区| 美国三级日本三级久久99 | 免费的成人av| 3d动漫精品啪啪一区二区竹菊| 一区二区免费视频| 91久久精品一区二区二区| 国产精品美女www爽爽爽| 风流少妇一区二区| 中文字幕久久午夜不卡| 成人中文字幕电影| 国产精品久久久久影院老司| 国产精品1024久久| 中文字幕乱码亚洲精品一区| 国产精品夜夜嗨| 欧美国产精品专区| zzijzzij亚洲日本少妇熟睡| 精品国精品自拍自在线| 麻豆成人在线观看| 欧美mv日韩mv国产网站| 久草中文综合在线| 久久这里只有精品6| 国产高清亚洲一区| 专区另类欧美日韩| 欧美色偷偷大香| 久久国产综合精品| 欧美激情一区三区| 99久久综合国产精品| 亚洲一区二区欧美激情| 91精品在线免费| 国产精品一区二区91| ...中文天堂在线一区| 欧美视频中文一区二区三区在线观看 | 亚瑟在线精品视频| 欧美一区二区三区免费在线看| 久久国内精品自在自线400部| 国产亚洲1区2区3区| 9人人澡人人爽人人精品| 夜夜亚洲天天久久| 久久综合狠狠综合久久综合88 | 日本大胆欧美人术艺术动态 | 国产一区亚洲一区|