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

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

?? d3dutility.cpp

?? Introduction to directx9 3d game programming 一書的源代碼
?? CPP
字號:
//////////////////////////////////////////////////////////////////////////////////////////////////
// 
// File: d3dutility.cpp
// 
// Author: Frank Luna (C) All Rights Reserved
//
// System: AMD Athlon 1800+ XP, 512 DDR, Geforce 3, Windows XP, MSVC++ 7.0 
//
// Desc: Provides utility functions for simplifying common tasks.
//          
//////////////////////////////////////////////////////////////////////////////////////////////////

#include "d3dUtility.h"

// vertex formats
const DWORD d3d::Vertex::FVF = D3DFVF_XYZ | D3DFVF_NORMAL | D3DFVF_TEX1;


bool d3d::InitD3D(
	HINSTANCE hInstance,
	int width, int height,
	bool windowed,
	D3DDEVTYPE deviceType,
	IDirect3DDevice9** device)
{
	//
	// Create the main application window.
	//

	WNDCLASS wc;

	wc.style         = CS_HREDRAW | CS_VREDRAW;
	wc.lpfnWndProc   = (WNDPROC)d3d::WndProc; 
	wc.cbClsExtra    = 0;
	wc.cbWndExtra    = 0;
	wc.hInstance     = hInstance;
	wc.hIcon         = LoadIcon(0, IDI_APPLICATION);
	wc.hCursor       = LoadCursor(0, IDC_ARROW);
	wc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
	wc.lpszMenuName  = 0;
	wc.lpszClassName = "Direct3D9App";

	if( !RegisterClass(&wc) ) 
	{
		::MessageBox(0, "RegisterClass() - FAILED", 0, 0);
		return false;
	}
		
	HWND hwnd = 0;
	hwnd = ::CreateWindow("Direct3D9App", "Direct3D9App", 
		WS_EX_TOPMOST,
		0, 0, width, height,
		0 /*parent hwnd*/, 0 /* menu */, hInstance, 0 /*extra*/); 

	if( !hwnd )
	{
		::MessageBox(0, "CreateWindow() - FAILED", 0, 0);
		return false;
	}

	::ShowWindow(hwnd, SW_SHOW);
	::UpdateWindow(hwnd);

	//
	// Init D3D: 
	//

	HRESULT hr = 0;

	// Step 1: Create the IDirect3D9 object.

	IDirect3D9* d3d9 = 0;
    d3d9 = Direct3DCreate9(D3D_SDK_VERSION);

    if( !d3d9 )
	{
		::MessageBox(0, "Direct3DCreate9() - FAILED", 0, 0);
		return false;
	}

	// Step 2: Check for hardware vp.

	D3DCAPS9 caps;
	d3d9->GetDeviceCaps(D3DADAPTER_DEFAULT, deviceType, &caps);

	int vp = 0;
	if( caps.DevCaps & D3DDEVCAPS_HWTRANSFORMANDLIGHT )
		vp = D3DCREATE_HARDWARE_VERTEXPROCESSING;
	else
		vp = D3DCREATE_SOFTWARE_VERTEXPROCESSING;

	// Step 3: Fill out the D3DPRESENT_PARAMETERS structure.
 
	D3DPRESENT_PARAMETERS d3dpp;
	d3dpp.BackBufferWidth            = width;
	d3dpp.BackBufferHeight           = height;
	d3dpp.BackBufferFormat           = D3DFMT_A8R8G8B8;
	d3dpp.BackBufferCount            = 1;
	d3dpp.MultiSampleType            = D3DMULTISAMPLE_NONE;
	d3dpp.MultiSampleQuality         = 0;
	d3dpp.SwapEffect                 = D3DSWAPEFFECT_DISCARD; 
	d3dpp.hDeviceWindow              = hwnd;
	d3dpp.Windowed                   = windowed;
	d3dpp.EnableAutoDepthStencil     = true; 
	d3dpp.AutoDepthStencilFormat     = D3DFMT_D24S8;
	d3dpp.Flags                      = 0;
	d3dpp.FullScreen_RefreshRateInHz = D3DPRESENT_RATE_DEFAULT;
	d3dpp.PresentationInterval       = D3DPRESENT_INTERVAL_IMMEDIATE;

	// Step 4: Create the device.

	hr = d3d9->CreateDevice(
		D3DADAPTER_DEFAULT, // primary adapter
		deviceType,         // device type
		hwnd,               // window associated with device
		vp,                 // vertex processing
	    &d3dpp,             // present parameters
	    device);            // return created device

	if( FAILED(hr) )
	{
		// try again using a 16-bit depth buffer
		d3dpp.AutoDepthStencilFormat = D3DFMT_D16;
		
		hr = d3d9->CreateDevice(
			D3DADAPTER_DEFAULT,
			deviceType,
			hwnd,
			vp,
			&d3dpp,
			device);

		if( FAILED(hr) )
		{
			d3d9->Release(); // done with d3d9 object
			::MessageBox(0, "CreateDevice() - FAILED", 0, 0);
			return false;
		}
	}

	d3d9->Release(); // done with d3d9 object
	
	return true;
}

int d3d::EnterMsgLoop( bool (*ptr_display)(float timeDelta) )
{
	MSG msg;
	::ZeroMemory(&msg, sizeof(MSG));

	static float lastTime = (float)timeGetTime(); 

	while(msg.message != WM_QUIT)
	{
		if(::PeekMessage(&msg, 0, 0, 0, PM_REMOVE))
		{
			::TranslateMessage(&msg);
			::DispatchMessage(&msg);
		}
		else
        {	
			float currTime  = (float)timeGetTime();
			float timeDelta = (currTime - lastTime)*0.001f;

			ptr_display(timeDelta);

			lastTime = currTime;
        }
    }
    return msg.wParam;
}

D3DLIGHT9 d3d::InitDirectionalLight(D3DXVECTOR3* direction, D3DXCOLOR* color)
{
	D3DLIGHT9 light;
	::ZeroMemory(&light, sizeof(light));

	light.Type      = D3DLIGHT_DIRECTIONAL;
	light.Ambient   = *color * 0.4f;
	light.Diffuse   = *color;
	light.Specular  = *color * 0.6f;
	light.Direction = *direction;

	return light;
}

D3DLIGHT9 d3d::InitPointLight(D3DXVECTOR3* position, D3DXCOLOR* color)
{
	D3DLIGHT9 light;
	::ZeroMemory(&light, sizeof(light));

	light.Type      = D3DLIGHT_POINT;
	light.Ambient   = *color * 0.4f;
	light.Diffuse   = *color;
	light.Specular  = *color * 0.6f;
	light.Position  = *position;
	light.Range        = 1000.0f;
	light.Falloff      = 1.0f;
	light.Attenuation0 = 1.0f;
	light.Attenuation1 = 0.0f;
	light.Attenuation2 = 0.0f;

	return light;
}

D3DLIGHT9 d3d::InitSpotLight(D3DXVECTOR3* position, D3DXVECTOR3* direction, D3DXCOLOR* color)
{
	D3DLIGHT9 light;
	::ZeroMemory(&light, sizeof(light));

	light.Type      = D3DLIGHT_SPOT;
	light.Ambient   = *color * 0.4f;
	light.Diffuse   = *color;
	light.Specular  = *color * 0.6f;
	light.Position  = *position;
	light.Direction = *direction;
	light.Range        = 1000.0f;
	light.Falloff      = 1.0f;
	light.Attenuation0 = 1.0f;
	light.Attenuation1 = 0.0f;
	light.Attenuation2 = 0.0f;
	light.Theta        = 0.5f;
	light.Phi          = 0.7f;

	return light;
}

D3DMATERIAL9 d3d::InitMtrl(D3DXCOLOR a, D3DXCOLOR d, D3DXCOLOR s, D3DXCOLOR e, float p)
{
	D3DMATERIAL9 mtrl;
	mtrl.Ambient  = a;
	mtrl.Diffuse  = d;
	mtrl.Specular = s;
	mtrl.Emissive = e;
	mtrl.Power    = p;
	return mtrl;
}

d3d::BoundingBox::BoundingBox()
{
	// infinite small 
	_min.x = d3d::INFINITY;
	_min.y = d3d::INFINITY;
	_min.z = d3d::INFINITY;

	_max.x = -d3d::INFINITY;
	_max.y = -d3d::INFINITY;
	_max.z = -d3d::INFINITY;
}

bool d3d::BoundingBox::isPointInside(D3DXVECTOR3& p)
{
	if( p.x >= _min.x && p.y >= _min.y && p.z >= _min.z &&
		p.x <= _max.x && p.y <= _max.y && p.z <= _max.z )
	{
		return true;
	}
	else
	{
		return false;
	}
}

d3d::BoundingSphere::BoundingSphere()
{
	_radius = 0.0f;
}

bool d3d::DrawBasicScene(IDirect3DDevice9* device, float scale)
{
	static IDirect3DVertexBuffer9* floor  = 0;
	static IDirect3DTexture9*      tex    = 0;
	static ID3DXMesh*              pillar = 0;

	HRESULT hr = 0;

	if( device == 0 )
	{
		if( floor && tex && pillar )
		{
			// they already exist, destroy them
			d3d::Release<IDirect3DVertexBuffer9*>(floor);
			d3d::Release<IDirect3DTexture9*>(tex);
			d3d::Release<ID3DXMesh*>(pillar);
		}
	}
	else if( !floor && !tex && !pillar )
	{
		// they don't exist, create them
		device->CreateVertexBuffer(
			6 * sizeof(d3d::Vertex),
			0, 
			d3d::Vertex::FVF,
			D3DPOOL_MANAGED,
			&floor,
			0);

		Vertex* v = 0;
		floor->Lock(0, 0, (void**)&v, 0);

		v[0] = Vertex(-20.0f, -2.5f, -20.0f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f);
		v[1] = Vertex(-20.0f, -2.5f,  20.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f);
		v[2] = Vertex( 20.0f, -2.5f,  20.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f);

		v[3] = Vertex(-20.0f, -2.5f, -20.0f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f);
		v[4] = Vertex( 20.0f, -2.5f,  20.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f);
		v[5] = Vertex( 20.0f, -2.5f, -20.0f, 0.0f, 1.0f, 0.0f, 1.0f, 1.0f);

		floor->Unlock();

		D3DXCreateCylinder(device, 0.5f, 0.5f, 5.0f, 20, 20, &pillar, 0);

		D3DXCreateTextureFromFile(
			device,
			"desert.bmp",
			&tex);
	}
	else
	{
		//
		// Pre-Render Setup
		//
		device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
		device->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
		device->SetSamplerState(0, D3DSAMP_MIPFILTER, D3DTEXF_POINT);

		D3DXVECTOR3 dir(0.707f, -0.707f, 0.707f);
		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);

		//
		// Render
		//

		D3DXMATRIX T, R, P, S;

		D3DXMatrixScaling(&S, scale, scale, scale);

		// used to rotate cylinders to be parallel with world's y-axis
		D3DXMatrixRotationX(&R, -D3DX_PI * 0.5f);

		// draw floor
		D3DXMatrixIdentity(&T);
		T = T * S;
		device->SetTransform(D3DTS_WORLD, &T);
		device->SetMaterial(&d3d::WHITE_MTRL);
		device->SetTexture(0, tex);
		device->SetStreamSource(0, floor, 0, sizeof(Vertex));
		device->SetFVF(Vertex::FVF);
		device->DrawPrimitive(D3DPT_TRIANGLELIST, 0, 2);
		
		// draw pillars
		device->SetMaterial(&d3d::BLUE_MTRL);
		device->SetTexture(0, 0);
		for(int i = 0; i < 5; i++)
		{
			D3DXMatrixTranslation(&T, -5.0f, 0.0f, -15.0f + (i * 7.5f));
			P = R * T * S;
			device->SetTransform(D3DTS_WORLD, &P);
			pillar->DrawSubset(0);

			D3DXMatrixTranslation(&T, 5.0f, 0.0f, -15.0f + (i * 7.5f));
			P = R * T * S;
			device->SetTransform(D3DTS_WORLD, &P);
			pillar->DrawSubset(0);
		}
	}
	return true;
}

float d3d::GetRandomFloat(float lowBound, float highBound)
{
	if( lowBound >= highBound ) // bad input
		return lowBound;

	// get random float in [0, 1] interval
	float f = (rand() % 10000) * 0.0001f; 

	// return float in [lowBound, highBound] interval. 
	return (f * (highBound - lowBound)) + lowBound; 
}

void d3d::GetRandomVector(
	  D3DXVECTOR3* out,
	  D3DXVECTOR3* min,
	  D3DXVECTOR3* max)
{
	out->x = GetRandomFloat(min->x, max->x);
	out->y = GetRandomFloat(min->y, max->y);
	out->z = GetRandomFloat(min->z, max->z);
}

DWORD d3d::FtoDw(float f)
{
	return *((DWORD*)&f);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本色道久久综合亚洲aⅴ蜜桃 | 亚洲免费观看在线视频| 亚洲裸体xxx| 三级久久三级久久久| 激情丁香综合五月| 91同城在线观看| 欧美色网站导航| www久久久久| 亚洲三级在线免费观看| 日本亚洲三级在线| www.欧美精品一二区| 88在线观看91蜜桃国自产| 国产亚洲综合av| 香蕉成人伊视频在线观看| 国产一区二区电影| 欧美日韩在线综合| 国产拍揄自揄精品视频麻豆| 亚洲大片免费看| 国产精品99久久久久久有的能看 | 一区二区三区在线观看网站| 美女www一区二区| 99re成人在线| 亚洲精品一区二区精华| 亚洲国产精品久久久久婷婷884| 国产美女精品一区二区三区| 欧美性生交片4| 久久女同互慰一区二区三区| 亚洲成a人片在线观看中文| 国产91在线|亚洲| 欧美一区二区三区免费视频| 亚洲免费观看高清完整版在线观看| 美女在线一区二区| 色婷婷精品久久二区二区蜜臂av| 久久先锋影音av鲁色资源网| 亚洲影视在线观看| 从欧美一区二区三区| 91精品国产色综合久久ai换脸| 亚洲欧美日韩国产中文在线| 国产一区二区三区香蕉| 欧美精品在线观看一区二区| 亚洲美女屁股眼交3| 国产白丝精品91爽爽久久| 欧美一级一级性生活免费录像| 亚洲人成在线观看一区二区| 国产精品一区一区| 日韩视频中午一区| 午夜精品久久久久久| 91偷拍与自偷拍精品| 国产精品日产欧美久久久久| 久久99精品网久久| 91麻豆精品国产91久久久使用方法 | 亚洲一区在线观看视频| 99视频一区二区三区| 国产日韩欧美a| 国产精品主播直播| 精品久久国产老人久久综合| 日本中文一区二区三区| 欧美视频完全免费看| 亚洲激情五月婷婷| 91视视频在线观看入口直接观看www | 亚洲国产一区二区三区| 97se亚洲国产综合自在线不卡| 久久精品视频一区| 国产成人精品在线看| 国产网站一区二区| 国产成人8x视频一区二区| 久久精品日韩一区二区三区| 国产一区二区在线免费观看| 欧美一级理论片| 久久精品国产精品亚洲综合| 欧美一区二区精品在线| 麻豆国产精品777777在线| 日韩欧美一级在线播放| 欧美日韩高清一区二区三区| 一区二区三区高清不卡| 欧美三级日韩在线| 午夜久久久久久久久| 欧美人与z0zoxxxx视频| 日韩在线a电影| 欧美一级理论片| 国产在线播放一区| 国产精品人妖ts系列视频| 99国产欧美另类久久久精品| 日韩美女视频一区| 91国在线观看| 丝袜美腿一区二区三区| 日韩午夜激情av| 国产精品一区二区三区99| 欧美激情一区不卡| 91一区二区在线| 亚洲一本大道在线| 欧美日本一区二区三区| 老司机午夜精品| 中文字幕高清不卡| 色女孩综合影院| 亚洲福利视频三区| 日韩欧美国产一区二区三区| 国产成人8x视频一区二区| 亚洲女爱视频在线| 欧美一区二区视频在线观看2022| 国产永久精品大片wwwapp| 国产精品免费人成网站| 日本韩国欧美一区二区三区| 日韩精品国产欧美| 国产日产亚洲精品系列| 在线观看成人免费视频| 麻豆精品视频在线观看| 中文字幕在线不卡一区| 这里只有精品免费| 国产aⅴ综合色| 亚洲va韩国va欧美va| 久久噜噜亚洲综合| 色嗨嗨av一区二区三区| 美女mm1313爽爽久久久蜜臀| 国产精品久久久久久久久搜平片 | 午夜电影一区二区三区| 久久久国产精品午夜一区ai换脸| 色噜噜夜夜夜综合网| 久久精品理论片| 亚洲精品国久久99热| 久久一二三国产| 91国产成人在线| 国产精品一区在线观看你懂的| 亚洲精品一卡二卡| 亚洲精品在线免费观看视频| 91黄色激情网站| 国产福利91精品| 天堂在线一区二区| 国产精品污网站| 日韩欧美国产午夜精品| 在线免费av一区| 国产99精品视频| 麻豆视频观看网址久久| 亚洲精品少妇30p| 久久综合九色综合欧美亚洲| 欧美日韩一级视频| 成年人国产精品| 狠狠色狠狠色综合系列| 亚洲成人资源网| 国产精品美女久久久久久2018 | 欧美私模裸体表演在线观看| 国产激情精品久久久第一区二区 | 26uuu精品一区二区| 欧美日韩精品电影| 波多野结衣91| 国产一区美女在线| 视频一区二区三区中文字幕| 亚洲男同性恋视频| 欧美国产在线观看| 欧美电视剧在线看免费| 欧美中文字幕一区| 97久久超碰精品国产| 国产成人精品三级| 精品一区二区三区香蕉蜜桃| 午夜精品123| 亚洲一二三四在线| 亚洲日本中文字幕区| 欧美国产成人精品| 久久久久免费观看| 日韩免费高清av| 欧美一区二区三区免费在线看| 欧美日韩中文字幕精品| 色狠狠综合天天综合综合| 99久久久免费精品国产一区二区 | 18欧美亚洲精品| 国产精品视频在线看| 国产亚洲精品bt天堂精选| 欧美xingq一区二区| 欧美三级视频在线| 欧美日韩色一区| 欧美亚洲一区二区在线观看| 色综合一区二区| 91免费观看在线| 99re在线精品| 色婷婷精品大在线视频| 一本色道久久综合精品竹菊| 99天天综合性| 一本到三区不卡视频| 日本精品视频一区二区| 色999日韩国产欧美一区二区| 91免费视频大全| 一本久久精品一区二区| 欧美亚洲日本国产| 欧美中文字幕久久| 欧美影片第一页| 欧美日韩高清一区| 91精品国产一区二区| 欧美tickle裸体挠脚心vk| 精品国产伦理网| 久久九九影视网| 国产丝袜美腿一区二区三区| 日本一二三四高清不卡| 国产精品短视频| 亚洲免费高清视频在线| 亚洲在线免费播放| 琪琪久久久久日韩精品| 韩国女主播一区二区三区| 国产成人综合在线播放| 波多野结衣在线aⅴ中文字幕不卡| 9久草视频在线视频精品|