亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产一区二区电影| 日韩小视频在线观看专区| 欧美一区二区视频在线观看2022 | 中文字幕亚洲欧美在线不卡| 爽爽淫人综合网网站| 91久久精品国产91性色tv | 欧美色电影在线| 中文一区在线播放| 国产乱子伦一区二区三区国色天香| 91啪亚洲精品| 中文字幕一区二| 波多野洁衣一区| 国产欧美一二三区| 精品一区二区三区免费| 91精品婷婷国产综合久久| 中文字幕一区二区三区乱码在线 | 91亚洲国产成人精品一区二三| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲国产中文字幕在线视频综合| 不卡视频免费播放| 国产午夜精品美女毛片视频| 裸体一区二区三区| 91精品婷婷国产综合久久性色| 亚洲午夜久久久久中文字幕久| 成人一区二区在线观看| 久久久国际精品| 国产一区二区三区免费看| 91精品国产欧美一区二区成人| 亚洲成人先锋电影| 欧美色综合网站| 天天综合日日夜夜精品| 欧美男人的天堂一二区| 五月激情丁香一区二区三区| 欧美乱妇一区二区三区不卡视频| 亚洲综合999| 欧美高清视频一二三区 | 成人av在线一区二区| 国产肉丝袜一区二区| 国产99久久久国产精品潘金| 欧美激情中文字幕一区二区| 暴力调教一区二区三区| 亚洲女女做受ⅹxx高潮| 欧日韩精品视频| 丝袜亚洲另类丝袜在线| 欧美v日韩v国产v| 91成人在线精品| 亚洲曰韩产成在线| 欧洲另类一二三四区| 日韩专区中文字幕一区二区| 精品免费国产一区二区三区四区| 国产精品一区专区| 亚洲乱码中文字幕| 欧美女孩性生活视频| 国内精品伊人久久久久影院对白| 久久久久99精品一区| 99精品视频在线免费观看| 亚洲宅男天堂在线观看无病毒| 欧美一区二区三区四区在线观看| 韩国三级在线一区| 亚洲黄色小说网站| 2021国产精品久久精品| 91麻豆精品一区二区三区| 三级亚洲高清视频| 欧美国产一区二区| 欧美日韩高清影院| 成人激情黄色小说| 日日嗨av一区二区三区四区| 国产午夜久久久久| 欧美人动与zoxxxx乱| 成人永久aaa| 日韩成人一级大片| 亚洲精品网站在线观看| 日韩精品一区二区三区在线| 99精品国产视频| 狠狠色综合色综合网络| 亚洲美女屁股眼交| 国产亚洲成年网址在线观看| 欧美三级资源在线| 成人免费的视频| 美女视频黄a大片欧美| 亚洲狠狠丁香婷婷综合久久久| www久久久久| 欧美另类z0zxhd电影| 成人黄色国产精品网站大全在线免费观看| 午夜一区二区三区视频| 国产精品三级视频| 亚洲精品一区二区三区影院| 色999日韩国产欧美一区二区| 激情五月播播久久久精品| 亚洲国产欧美一区二区三区丁香婷| 国产视频不卡一区| 精品国产3级a| 日韩一级免费观看| 欧美日韩色综合| 色94色欧美sute亚洲线路一久 | 久久99最新地址| 日本美女一区二区| 亚洲午夜视频在线观看| 亚洲欧美国产三级| 国产精品电影一区二区| 欧美经典一区二区| 久久精品人人做人人综合 | 国产乱人伦偷精品视频不卡| 日韩av成人高清| 亚洲不卡av一区二区三区| 一区二区国产盗摄色噜噜| 国产精品毛片久久久久久| 久久久久一区二区三区四区| 日韩三级在线免费观看| 欧美无砖砖区免费| 欧美色成人综合| 欧美精品一二三| 欧美美女网站色| 欧美日韩国产另类一区| 欧美日韩激情一区二区| 69av一区二区三区| 日韩欧美的一区| 国产无遮挡一区二区三区毛片日本| 精品久久久网站| 国产婷婷一区二区| 一区免费观看视频| 亚洲一二三区在线观看| 日韩激情一区二区| 黄页网站大全一区二区| 国产一区二区剧情av在线| 国产一区二区精品在线观看| 国产精品一区二区三区四区 | 国产精品久久三区| 亚洲黄色在线视频| 日韩激情一二三区| 激情六月婷婷久久| av在线不卡观看免费观看| 日本精品免费观看高清观看| 欧美日韩精品一二三区| 日韩欧美一区二区三区在线| 久久先锋影音av| 亚洲伦在线观看| 日本不卡一区二区三区高清视频| 免费三级欧美电影| 粉嫩嫩av羞羞动漫久久久| 色菇凉天天综合网| 欧美α欧美αv大片| 国产精品国产三级国产专播品爱网 | 在线不卡免费av| 精品99久久久久久| 亚洲另类春色国产| 精品一区二区三区免费| 99久免费精品视频在线观看| 欧美综合久久久| 亚洲精品一区二区三区影院| 亚洲乱码中文字幕| 精品一区二区在线免费观看| www.欧美色图| 日韩欧美视频一区| 亚洲精品一卡二卡| 国产精品一二三区在线| 欧美午夜宅男影院| 国产喷白浆一区二区三区| 亚洲国产精品久久艾草纯爱| 国产精品影音先锋| 欧美一区二区在线免费观看| 中文字幕免费观看一区| 免费成人在线视频观看| 99re成人在线| 国产情人综合久久777777| 视频一区免费在线观看| 色综合久久88色综合天天免费| 日韩免费观看高清完整版在线观看| 中文字幕日韩av资源站| 久久99精品国产.久久久久久| 在线视频欧美区| 国产蜜臀97一区二区三区| 首页国产欧美久久| 欧美网站大全在线观看| 中文字幕一区二区三区四区| 国产一区二区三区久久久 | 久久99精品久久久久久国产越南| 91在线观看美女| 国产午夜精品久久久久久免费视| 日韩精品成人一区二区三区| 色一区在线观看| 中文字幕视频一区二区三区久| 精品亚洲国内自在自线福利| 欧美日韩免费视频| 亚洲午夜久久久久久久久电影网| 99热在这里有精品免费| 国产清纯美女被跳蛋高潮一区二区久久w| 美女尤物国产一区| 欧美一区二区三区播放老司机| 亚洲成人自拍网| 欧美色图天堂网| 亚洲一区欧美一区| 欧美性视频一区二区三区| 亚洲乱码一区二区三区在线观看| 9i在线看片成人免费| 亚洲欧洲三级电影| 色婷婷综合在线| 亚洲一二三专区| 欧美日韩在线观看一区二区| 亚洲一区二区五区|