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

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

?? pmesh.cpp

?? Introduction to directx9 3d game programming 一書的源代碼
?? CPP
字號:
//////////////////////////////////////////////////////////////////////////////////////////////////
// 
// File: pmesh.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 the progressive mesh interface (ID3DXPMesh).  Use
//       the 'A' key to add triangles, use the 'S' key to remove triangles.  Note
//       that we outline the triangles in yellow so that you can see them get 
//       removed and added.
//          
//////////////////////////////////////////////////////////////////////////////////////////////////

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

//
// Globals
//

IDirect3DDevice9* Device = 0; 

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

ID3DXMesh*                      SourceMesh = 0;
ID3DXPMesh*                     PMesh      = 0; // progressive mesh
std::vector<D3DMATERIAL9>       Mtrls(0);
std::vector<IDirect3DTexture9*> Textures(0);

//
// 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,
		&SourceMesh);

	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 = SourceMesh->OptimizeInplace(		
		D3DXMESHOPT_ATTRSORT |
		D3DXMESHOPT_COMPACT  |
		D3DXMESHOPT_VERTEXCACHE,
		(DWORD*)adjBuffer->GetBufferPointer(),
		(DWORD*)adjBuffer->GetBufferPointer(), // new adjacency info
		0, 0);

	if(FAILED(hr))
	{
		::MessageBox(0, "OptimizeInplace() - FAILED", 0, 0);
		d3d::Release<ID3DXBuffer*>(adjBuffer); // free
		return false;
	}

	//
	// Generate the progressive mesh. 
	//

	hr = D3DXGeneratePMesh(
		SourceMesh,
		(DWORD*)adjBuffer->GetBufferPointer(), // adjacency
		0,                  // default vertex attribute weights
		0,                  // default vertex weights
		1,                  // simplify as low as possible
		D3DXMESHSIMP_FACE,  // simplify by face count
		&PMesh);

	d3d::Release<ID3DXMesh*>(SourceMesh);  // done w/ source mesh
	d3d::Release<ID3DXBuffer*>(adjBuffer); // done w/ buffer

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

	// set to original detail
	DWORD maxFaces = PMesh->GetMaxFaces();
	PMesh->SetNumFaces(maxFaces);

	//
	// 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(-8.0f, 4.0f, -12.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<ID3DXPMesh*>(PMesh);

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

bool Display(float timeDelta)
{
	if( Device )
	{
		//
		// Update: Mesh resolution.
		//

		// Get the current number of faces the pmesh has.
		int numFaces = PMesh->GetNumFaces();

		// Add a face, note the SetNumFaces() will  automatically
		// clamp the specified value if it goes out of bounds.
		if( ::GetAsyncKeyState('A') & 0x8000f )
		{
			// Sometimes we must add more than one face to invert
			// an edge collapse transformation
			PMesh->SetNumFaces( numFaces + 1 );
			if( PMesh->GetNumFaces() == numFaces )
				PMesh->SetNumFaces( numFaces + 2 );
		}

		// Remove a face, note the SetNumFaces() will  automatically
		// clamp the specified value if it goes out of bounds.
		if( ::GetAsyncKeyState('S') & 0x8000f )
			PMesh->SetNumFaces( numFaces - 1 );
		
		//
		// Render
		//

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

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

			// draw wireframe outline
			Device->SetMaterial(&d3d::YELLOW_MTRL);
			Device->SetRenderState(D3DRS_FILLMODE, D3DFILL_WIREFRAME);
			PMesh->DrawSubset(i);
			Device->SetRenderState(D3DRS_FILLMODE, D3DFILL_SOLID);
		}	

		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);
		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;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产毛片aaaaa无费看| 蜜臀av一区二区三区| 日韩综合在线视频| 成人免费视频播放| 91麻豆精品国产91久久久久| 久久午夜羞羞影院免费观看| 一区二区三区中文在线观看| 国产伦精品一区二区三区在线观看| 在线观看视频一区| 国产网站一区二区三区| 日本美女视频一区二区| 日本中文在线一区| 波多野结衣在线aⅴ中文字幕不卡| 99麻豆久久久国产精品免费| 欧美一级一区二区| 精品成人一区二区三区四区| 亚洲国产三级在线| 成人av综合在线| 久久噜噜亚洲综合| 国内精品视频一区二区三区八戒| 欧美猛男gaygay网站| 亚洲另类色综合网站| 高清av一区二区| 久久九九全国免费| 全部av―极品视觉盛宴亚洲| 欧美日韩国产综合草草| 亚洲影院在线观看| 色系网站成人免费| 亚洲色图在线播放| av不卡免费在线观看| 欧美韩国日本一区| 成人小视频免费观看| 欧美国产日韩亚洲一区| 国产91精品入口| 国产精品你懂的| 国产91精品欧美| 国产精品不卡一区| 91免费视频网址| 国产精品国产自产拍在线| 成人黄色在线看| 成人免费小视频| 在线欧美小视频| 天天综合天天综合色| 91精品国模一区二区三区| 奇米一区二区三区| 2024国产精品| 成人白浆超碰人人人人| 亚洲精品v日韩精品| 欧美日韩视频在线第一区| 天堂成人免费av电影一区| 精品噜噜噜噜久久久久久久久试看 | 欧美成人一区二区三区在线观看| 日本色综合中文字幕| 日韩限制级电影在线观看| 国产最新精品免费| 成人免费在线视频观看| 欧美少妇一区二区| 久久丁香综合五月国产三级网站 | 欧美日韩精品一区二区| 蜜桃视频在线一区| 久久久精品免费网站| 成人激情动漫在线观看| 亚洲国产裸拍裸体视频在线观看乱了| 日韩网站在线看片你懂的| 国产一区啦啦啦在线观看| 亚洲欧美韩国综合色| 91精品国产色综合久久不卡蜜臀| 国产一区在线视频| 亚洲激情一二三区| 捆绑调教一区二区三区| 久久精品亚洲一区二区三区浴池| 99视频热这里只有精品免费| 午夜激情一区二区三区| 久久久电影一区二区三区| 91成人免费在线| 国产精品一区二区久久精品爱涩| 亚洲老妇xxxxxx| 久久精品欧美一区二区三区不卡 | 午夜电影网亚洲视频| 久久精品亚洲精品国产欧美kt∨| 在线观看一区日韩| 成人精品小蝌蚪| 国产精品自在欧美一区| 三级不卡在线观看| 中文字幕在线不卡视频| 欧美va在线播放| 欧美怡红院视频| av在线不卡网| 国产成人精品亚洲777人妖| 亚洲线精品一区二区三区| 中文字幕亚洲不卡| 久久综合av免费| 欧美一区日韩一区| 色综合色综合色综合色综合色综合| 国产伦精品一区二区三区视频青涩| 亚洲bt欧美bt精品777| 亚洲欧洲精品一区二区精品久久久| 日韩一二在线观看| 3atv在线一区二区三区| 欧美在线免费观看视频| 成人av在线一区二区三区| 国产一区美女在线| 久久99精品一区二区三区| 三级久久三级久久久| 一区二区三区在线免费播放| 国产精品三级av| 国产精品久线观看视频| 日本一区二区三区免费乱视频| 欧美精品一区二区三| 日韩欧美的一区二区| 日韩欧美激情四射| 欧美一区二区三区在线看| 8x福利精品第一导航| 精品1区2区3区| 欧美日韩国产区一| 欧美一区二区三区免费大片| 777色狠狠一区二区三区| 日韩亚洲欧美综合| 欧美大胆人体bbbb| www国产精品av| 国产精品人人做人人爽人人添| 欧美国产日韩一二三区| 国产精品九色蝌蚪自拍| 亚洲乱码国产乱码精品精小说 | 日韩**一区毛片| 国产一区二区三区在线观看精品 | 国产精品久久久久久久久免费樱桃| 国产日产欧美精品一区二区三区| 久久精品视频免费| 亚洲视频一二三| 亚洲va欧美va天堂v国产综合| 毛片基地黄久久久久久天堂| 久久精品国产一区二区| 国产盗摄精品一区二区三区在线| www.成人网.com| 欧美日韩和欧美的一区二区| 日韩欧美久久久| 国产精品美女久久久久aⅴ | 精品一区二区免费在线观看| 国产精品99久久久| 色女孩综合影院| 精品国产免费视频| 亚洲天堂网中文字| 视频一区二区中文字幕| 久久99热99| 91啪在线观看| 欧美mv和日韩mv的网站| 国产精品久久久久久久久动漫 | 亚洲国产另类av| 国产一区欧美日韩| 在线观看av不卡| 久久久久国色av免费看影院| 一区二区三区四区视频精品免费 | 亚洲精品一区二区三区四区高清| 日本一区二区免费在线| 一区二区三区在线免费观看| 久久99精品一区二区三区三区| aaa欧美大片| 日韩一级二级三级精品视频| 亚洲欧美另类久久久精品2019 | 性做久久久久久久免费看| 国产综合色精品一区二区三区| 色av综合在线| 日本一区二区三区在线不卡| 日韩av在线免费观看不卡| 一本在线高清不卡dvd| 精品国产露脸精彩对白| 亚洲国产日韩一区二区| av电影天堂一区二区在线观看| 精品免费国产二区三区| 亚洲一区成人在线| 99久久99久久免费精品蜜臀| 久久日一线二线三线suv| 日日夜夜精品视频天天综合网| heyzo一本久久综合| 久久综合国产精品| 奇米色777欧美一区二区| 欧美性一级生活| 亚洲欧美一区二区三区极速播放| 国产一区二区福利| 欧美一二三四在线| 亚洲va欧美va人人爽午夜| 一本久久a久久精品亚洲| 国产人成亚洲第一网站在线播放| 日本不卡123| 51精品秘密在线观看| 亚洲最新视频在线播放| 在线亚洲一区二区| 一区二区三区四区激情| 99久久国产免费看| 亚洲欧洲精品一区二区三区 | 韩国三级在线一区| 欧美一区二区三区成人| 日韩中文欧美在线| 91麻豆精品91久久久久久清纯| 亚洲成a人片在线不卡一二三区 | 91丨国产丨九色丨pron| 国产精品久久久久久久裸模| av午夜精品一区二区三区| 国产欧美中文在线|