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

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

?? boundingvolumes.cpp

?? Introduction to directx9 3d game programming 一書的源代碼
?? CPP
字號:
//////////////////////////////////////////////////////////////////////////////////////////////////
// 
// File: boundingvolumes.cpp
// 
// Author: Frank Luna (C) All Rights Reserved
//
// System: AMD Athlon 1800+ XP, 512 DDR, Geforce 3, Windows XP, MSVC++ 7.0 
//
// Desc: Demonstrates how to use D3DXComputeBoundingSphere and D3DXComputeBoundingBox.
//
//      -The spacebar key switches between rendering the mesh's bounding sphere and box.
//          
//////////////////////////////////////////////////////////////////////////////////////////////////

#include "d3dUtility.h"
#include <vector>

//
// Globals
//

IDirect3DDevice9* Device = 0; 

const int Width  = 640;
const int Height = 480;

ID3DXMesh*                      Mesh = 0;
std::vector<D3DMATERIAL9>       Mtrls(0);
std::vector<IDirect3DTexture9*> Textures(0);

ID3DXMesh* SphereMesh = 0;
ID3DXMesh* BoxMesh    = 0;

bool RenderBoundingSphere = true;

//
// Prototypes
//

bool ComputeBoundingSphere(ID3DXMesh* mesh, d3d::BoundingSphere* sphere);
bool    ComputeBoundingBox(ID3DXMesh* mesh, d3d::BoundingBox*    box);

//
// Framework functions
//
bool Setup()
{
	HRESULT hr = 0;

	//
	// Load the XFile data.
	//
	ID3DXBuffer* adjBuffer  = 0;
	ID3DXBuffer* mtrlBuffer = 0;
	DWORD        numMtrls   = 0;

	hr = D3DXLoadMeshFromX(  
		"bigship1.x",
		D3DXMESH_MANAGED,
		Device,
		&adjBuffer,
		&mtrlBuffer,
		0,
		&numMtrls,
		&Mesh);

	if(FAILED(hr))
	{
		::MessageBox(0, "D3DXLoadMeshFromX() - FAILED", 0, 0);
		return false;
	}

	//
	// Extract the materials, load textures.
	//

	if( mtrlBuffer != 0 && numMtrls != 0 )
	{
		D3DXMATERIAL* mtrls = (D3DXMATERIAL*)mtrlBuffer->GetBufferPointer();

		for(int i = 0; i < numMtrls; i++)
		{
			// the MatD3D property doesn't have an ambient value set
			// when its loaded, so set it now:
			mtrls[i].MatD3D.Ambient = mtrls[i].MatD3D.Diffuse;

			// save the ith material
			Mtrls.push_back( mtrls[i].MatD3D );

			// check if the ith material has an associative texture
			if( mtrls[i].pTextureFilename != 0 )
			{
				// yes, load the texture for the ith subset
				IDirect3DTexture9* tex = 0;
				D3DXCreateTextureFromFile(
					Device,
					mtrls[i].pTextureFilename,
					&tex);

				// save the loaded texture
				Textures.push_back( tex );
			}
			else
			{
				// no texture for the ith subset
				Textures.push_back( 0 );
			}
		}
	}
	d3d::Release<ID3DXBuffer*>(mtrlBuffer); // done w/ buffer

	//
	// Optimize the mesh.
	//

	hr = Mesh->OptimizeInplace(		
		D3DXMESHOPT_ATTRSORT |
		D3DXMESHOPT_COMPACT  |
		D3DXMESHOPT_VERTEXCACHE,
		(DWORD*)adjBuffer->GetBufferPointer(),
		0, 0, 0);

	d3d::Release<ID3DXBuffer*>(adjBuffer); // done w/ buffer

	if(FAILED(hr))
	{
		::MessageBox(0, "OptimizeInplace() - FAILED", 0, 0);
		return false;
	}

	//
	// Compute Bounding Sphere and Bounding Box.
	//
    
	d3d::BoundingSphere boundingSphere;
	d3d::BoundingBox    boundingBox;

	ComputeBoundingSphere(Mesh, &boundingSphere);
	ComputeBoundingBox(Mesh, &boundingBox);

	D3DXCreateSphere(
		Device,
		boundingSphere._radius,
		20,
		20,
		&SphereMesh,
		0);

	D3DXCreateBox(
		Device,
		boundingBox._max.x - boundingBox._min.x,
		boundingBox._max.y - boundingBox._min.y,
		boundingBox._max.z - boundingBox._min.z,
		&BoxMesh,
		0);

	//
	// Set texture filters.
	//

	Device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
	Device->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
	Device->SetSamplerState(0, D3DSAMP_MIPFILTER, D3DTEXF_POINT);

	// 
	// Set Lights.
	//

	D3DXVECTOR3 dir(1.0f, -1.0f, 1.0f);
	D3DXCOLOR col(1.0f, 1.0f, 1.0f, 1.0f);
	D3DLIGHT9 light = d3d::InitDirectionalLight(&dir, &col);

	Device->SetLight(0, &light);
	Device->LightEnable(0, true);
	Device->SetRenderState(D3DRS_NORMALIZENORMALS, true);
	Device->SetRenderState(D3DRS_SPECULARENABLE, true);

	//
	// Set camera.
	//

	D3DXVECTOR3 pos(4.0f, 12.0f, -20.0f);
	D3DXVECTOR3 target(0.0f, 0.0f, 0.0f);
	D3DXVECTOR3 up(0.0f, 1.0f, 0.0f);

	D3DXMATRIX V;
	D3DXMatrixLookAtLH(
		&V,
		&pos,
		&target,
		&up);

	Device->SetTransform(D3DTS_VIEW, &V);

	//
	// Set projection matrix.
	//

	D3DXMATRIX proj;
	D3DXMatrixPerspectiveFovLH(
			&proj,
			D3DX_PI * 0.5f, // 90 - degree
			(float)Width / (float)Height,
			1.0f,
			1000.0f);
	Device->SetTransform(D3DTS_PROJECTION, &proj);

	return true;
}

void Cleanup()
{
	d3d::Release<ID3DXMesh*>(Mesh);

	for(int i = 0; i < Textures.size(); i++)
		d3d::Release<IDirect3DTexture9*>( Textures[i] );

	d3d::Release<ID3DXMesh*>(SphereMesh);
	d3d::Release<ID3DXMesh*>(BoxMesh);
}

bool Display(float timeDelta)
{
	if( Device )
	{
		//
		// Update: Rotate the mesh.
		//

		static float y = 0.0f;
		D3DXMATRIX yRot;
		D3DXMatrixRotationY(&yRot, y);
		y += timeDelta;

		if( y >= 6.28f )
			y = 0.0f;

		D3DXMATRIX World = yRot;

		Device->SetTransform(D3DTS_WORLD, &World);

		//
		// Render
		//

		Device->Clear(0, 0, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, 0xffffffff, 1.0f, 0);
		Device->BeginScene();

		// draw the mesh
		for(int i = 0; i < Mtrls.size(); i++)
		{
			Device->SetMaterial( &Mtrls[i] );
			Device->SetTexture(0, Textures[i]);
			Mesh->DrawSubset(i);
		}	

		//
		// Draw bounding volume in blue and at 10% opacity
		D3DMATERIAL9 blue = d3d::BLUE_MTRL;
		blue.Diffuse.a = 0.10f; // 10% opacity

		Device->SetMaterial(&blue);
		Device->SetTexture(0, 0); // disable texture

		Device->SetRenderState(D3DRS_ALPHABLENDENABLE, true);
		Device->SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);
		Device->SetRenderState(D3DRS_DESTBLEND, D3DBLEND_INVSRCALPHA);

		if( RenderBoundingSphere )
			SphereMesh->DrawSubset(0);
		else
			BoxMesh->DrawSubset(0);

		Device->SetRenderState(D3DRS_ALPHABLENDENABLE, false);

		Device->EndScene();
		Device->Present(0, 0, 0, 0);
	}
	return true;
}

//
// WndProc
//
LRESULT CALLBACK d3d::WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
	switch( msg )
	{
	case WM_DESTROY:
		::PostQuitMessage(0);
		break;
		
	case WM_KEYDOWN:
		if( wParam == VK_ESCAPE )
			::DestroyWindow(hwnd);

		if( wParam == VK_SPACE )
			RenderBoundingSphere = !RenderBoundingSphere;

		break;
	}
	return ::DefWindowProc(hwnd, msg, wParam, lParam);
}

//
// WinMain
//
int WINAPI WinMain(HINSTANCE hinstance,
				   HINSTANCE prevInstance, 
				   PSTR cmdLine,
				   int showCmd)
{
	if(!d3d::InitD3D(hinstance,
		Width, Height, true, D3DDEVTYPE_HAL, &Device))
	{
		::MessageBox(0, "InitD3D() - FAILED", 0, 0);
		return 0;
	}
		
	if(!Setup())
	{
		::MessageBox(0, "Setup() - FAILED", 0, 0);
		return 0;
	}

	d3d::EnterMsgLoop( Display );

	Cleanup();

	Device->Release();

	return 0;
}

bool ComputeBoundingSphere(ID3DXMesh* mesh, d3d::BoundingSphere* sphere)
{
	HRESULT hr = 0;

	BYTE* v = 0;
	mesh->LockVertexBuffer(0, (void**)&v);

	hr = D3DXComputeBoundingSphere(
			(D3DXVECTOR3*)v,
			mesh->GetNumVertices(),
			D3DXGetFVFVertexSize(mesh->GetFVF()),
			&sphere->_center,
			&sphere->_radius);

	mesh->UnlockVertexBuffer();

	if( FAILED(hr) )
		return false;

	return true;
}

bool ComputeBoundingBox(ID3DXMesh* mesh, d3d::BoundingBox* box)
{
	HRESULT hr = 0;

	BYTE* v = 0;
	mesh->LockVertexBuffer(0, (void**)&v);

	hr = D3DXComputeBoundingBox(
			(D3DXVECTOR3*)v,
			mesh->GetNumVertices(),
			D3DXGetFVFVertexSize(mesh->GetFVF()),
			&box->_min,
			&box->_max);

	mesh->UnlockVertexBuffer();

	if( FAILED(hr) )
		return false;

	return true;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线播放日韩导航| 欧美日韩国产三级| 另类综合日韩欧美亚洲| 亚洲成人在线观看视频| 一区二区三区国产| 亚洲乱码国产乱码精品精的特点| 国产欧美一区二区精品性| 欧美激情一区二区在线| 国产精品欧美一区二区三区| 欧美激情一区二区三区四区| 中文字幕亚洲视频| 亚洲免费av观看| 亚洲亚洲人成综合网络| 午夜电影网一区| 日韩av二区在线播放| 精品影视av免费| 福利一区二区在线| 日本韩国欧美在线| 日韩一区二区三区在线视频| 日韩精品中文字幕一区| 日本一区二区成人在线| 亚洲欧美经典视频| 日产国产欧美视频一区精品| 激情六月婷婷综合| 成人av动漫在线| 欧美人牲a欧美精品| 精品日韩在线一区| 日韩一区中文字幕| 丝袜美腿一区二区三区| 精品无码三级在线观看视频| av午夜一区麻豆| 7799精品视频| 国产女人aaa级久久久级| 一区二区视频在线| 久久国产人妖系列| 91香蕉视频mp4| 日韩欧美激情在线| 一区二区在线观看免费| 国内久久精品视频| 欧美做爰猛烈大尺度电影无法无天| 欧美日韩国产不卡| 中文字幕一区免费在线观看| 日韩经典一区二区| jizzjizzjizz欧美| 日韩欧美一区二区三区在线| 亚洲同性gay激情无套| 日韩一区精品视频| 色婷婷久久久亚洲一区二区三区| 日韩欧美高清dvd碟片| 亚洲综合一区在线| 成人免费黄色大片| 亚洲精品在线电影| 日韩精品五月天| 91啪九色porn原创视频在线观看| 精品日韩欧美在线| 亚洲一区欧美一区| 91性感美女视频| 国产精品成人免费在线| 另类的小说在线视频另类成人小视频在线| 成人av电影在线| 久久嫩草精品久久久精品一| 秋霞电影一区二区| 欧美日韩国产综合久久| 亚洲激情中文1区| 成人性生交大合| 久久久久国产成人精品亚洲午夜| 午夜电影久久久| 欧美日韩在线观看一区二区| 亚洲欧美日韩久久精品| 成人小视频免费在线观看| 久久久精品免费免费| 国产一区二区三区久久久 | 国产女人18毛片水真多成人如厕| 另类小说一区二区三区| 91精品国产综合久久精品麻豆| 亚洲人成在线观看一区二区| www.亚洲激情.com| 国产精品美女久久久久久2018 | 亚洲国产精品成人综合| 狠狠v欧美v日韩v亚洲ⅴ| 精品国产一区二区精华| 国产一区在线精品| 久久精品一区八戒影视| 国产伦精品一区二区三区免费迷| 久久亚洲综合av| 国产麻豆视频精品| 国产精品三级av| 99在线视频精品| 亚洲一区二区三区四区在线观看 | 国产精品毛片高清在线完整版| 国内成+人亚洲+欧美+综合在线| 精品电影一区二区三区| 国产精品99久久久久久宅男| 中文字幕一区视频| 欧美伊人久久大香线蕉综合69| 日本午夜精品一区二区三区电影 | 99精品久久久久久| 一区二区三区高清不卡| 欧美日韩在线播| 久久国产夜色精品鲁鲁99| 中文字幕精品综合| 欧美午夜片在线观看| 久久99精品久久久| 亚洲人成伊人成综合网小说| 欧美日韩和欧美的一区二区| 毛片一区二区三区| 中文字幕在线视频一区| 欧美日韩另类国产亚洲欧美一级| 麻豆精品久久久| 一区免费观看视频| 91精品国产综合久久久蜜臀图片| 国产黄色精品视频| 亚洲国产综合91精品麻豆| xvideos.蜜桃一区二区| 91社区在线播放| 韩国欧美一区二区| 夜夜精品视频一区二区| 2023国产精华国产精品| 色欧美日韩亚洲| 福利视频网站一区二区三区| 日韩va欧美va亚洲va久久| 国产精品视频一区二区三区不卡| 欧美高清hd18日本| 在线免费观看成人短视频| 国产一区二区美女诱惑| 午夜av电影一区| 亚洲欧美日韩一区二区三区在线观看| 日韩欧美高清一区| 欧美日韩一区小说| 91免费视频网址| 国产成人av电影在线| 日本成人在线电影网| 一区二区三区色| 国产精品高潮久久久久无| 欧美电影免费观看完整版| 欧美日韩亚洲综合在线| 日本高清不卡视频| bt欧美亚洲午夜电影天堂| 国产一区福利在线| 国产一区二区三区电影在线观看| 日韩影院精彩在线| 亚洲高清不卡在线观看| 亚洲精品videosex极品| 国产精品理论在线观看| 国产亚洲一区二区三区四区| 日韩亚洲欧美在线观看| 欧美一区午夜精品| 欧美日本在线播放| 欧美日韩在线三级| 欧美调教femdomvk| 欧美色大人视频| 欧美人妇做爰xxxⅹ性高电影 | 麻豆91免费看| 日本欧美一区二区三区| 日韩和欧美一区二区三区| 丝袜亚洲精品中文字幕一区| 日日夜夜免费精品视频| 天堂精品中文字幕在线| 日本成人中文字幕在线视频| 青青草原综合久久大伊人精品| 爽好多水快深点欧美视频| 日韩激情视频在线观看| 蜜臀久久久久久久| 久久爱www久久做| 国产精品99久久久久久似苏梦涵| 国产综合成人久久大片91| 国产一区二区三区免费| 福利一区在线观看| 99久久免费国产| 欧美色男人天堂| 日韩一级精品视频在线观看| 久久久亚洲欧洲日产国码αv| 久久久亚洲精品一区二区三区 | 偷偷要91色婷婷| 日本不卡一二三区黄网| 国产精品18久久久| 色哟哟一区二区在线观看| 欧美丰满少妇xxxxx高潮对白 | 亚洲电影激情视频网站| 日韩和欧美的一区| 国产不卡在线视频| 日本二三区不卡| 精品少妇一区二区三区在线视频| 久久蜜桃一区二区| 一区二区在线免费| 黄色日韩网站视频| 色综合久久中文综合久久97| 欧美高清精品3d| 国产精品传媒入口麻豆| 国产综合久久久久久鬼色| 91女神在线视频| 精品动漫一区二区三区在线观看| 自拍偷自拍亚洲精品播放| 日韩成人一级大片| 91在线无精精品入口| 久久久久久夜精品精品免费| 亚洲蜜桃精久久久久久久| 国产精品1024| 51精品视频一区二区三区| 中文字幕中文字幕一区|