《Directx 9.0 3D 游戏开发编程基础》例程3.6 出现的问题

独酌逸醉 2011-11-19 01:23:57
大家好,小弟正在学习 directx 。在龙书例程 3.6 中绘制一个 cube。代码和源代码几乎相同,但是却绘制不出来 cube。下面是代码:
// file.vertex.h

#ifndef __VERTEX_H__
#define __VERTEX_H__

struct Vertex
{
public:
Vertex()
{ }
Vertex(float x, float y, float z)
: m_x(x), m_y(y), m_z(z)
{ }

void SetX(float x) { m_x = x ; }
void SetY(float y) { m_y = y ; }
void SetZ(float z) { m_z = z ; }
float GetX() const { return m_x ; }
float GetY() const { return m_y ; }
float GetZ() const { return m_z ; }

public:
static const DWORD FVF;

public:
float m_x;
float m_y;
float m_z;
};

const DWORD Vertex::FVF = D3DFVF_XYZ;


#endif /* __VERTEX_H__ */


// direct3dframe.h

#ifndef __DIRECT3DFRAME_H__
#define __DIRECT3DFRAME_H__

#include <d3d9.h>
#include <d3dx9.h>

#pragma comment(lib, "d3d9.lib")
#pragma comment(lib, "d3dx9.lib")
#pragma comment(lib, "winmm.lib")

// Direct3D 框架类,完成 Direct3D 的初始化等操作
class Direct3DFrame
{
public:
Direct3DFrame(
LPCWSTR wndName,
HINSTANCE hInstance,
int width, int height,
bool windowed,
D3DDEVTYPE deviceType);

~Direct3DFrame(void);

public:
bool InitD3D();
// Setup() 设置资源,Cleanup() 清除资源
bool Setup();
void Cleanup();
bool Display(float timeDelta);

public:
static LRESULT CALLBACK WndProc(HWND hWnd, UINT msg,
WPARAM wParam, LPARAM lParam);
int EnterMsgLoop();

private:
bool CreateWin32Window(HWND& hWnd);

private:
LPCWSTR m_wndName; // 窗口名称
HINSTANCE m_hInstance; // 应用程序实例句柄
int m_width; // 后台缓冲大小
int m_height;
bool m_windowed; // 窗口模式 (true) 或者全屏模式 (false)
D3DDEVTYPE m_deviceType; // HAL or REF
IDirect3DDevice9* m_device;

IDirect3DVertexBuffer9* m_vb; // 顶点缓存
IDirect3DIndexBuffer9* m_ib; // 索引缓存

float m_yRotAngle; // y 轴每次旋转增量
};

#endif /* __DIRECT3DFRAME_H__ */


...全文
213 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
独酌逸醉 2011-11-21
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 ccssddnnchaizhi 的回复:]

setup()里面
// define the triangle of the cube:
WORD* indices = NULL;
m_vb->Lock(0, 0, (void**)&indices, 0);

这写错了
最后应该是m_ib->Lock(0, 0, (void**)&indices, 0);
[/Quote]

嗯,对。
谢谢你的回复。
ccssddnnchaizhi 2011-11-21
  • 打赏
  • 举报
回复
setup()里面
// define the triangle of the cube:
WORD* indices = NULL;
m_vb->Lock(0, 0, (void**)&indices, 0);

这写错了
最后应该是m_ib->Lock(0, 0, (void**)&indices, 0);
独酌逸醉 2011-11-20
  • 打赏
  • 举报
回复
求人不如求己啊。
独酌逸醉 2011-11-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 baesky 的回复:]

先别设置renderstate,另外用PIX看看一帧你都做了什么。
[/Quote]

PIX 是什么?
独酌逸醉 2011-11-19
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 dizuo 的回复:]

这里下例子代码研究一下:www.codesampler.com
[/Quote]

您给的连接是 opengl 的,可是我用的是 directx 。
gianni_bella 2011-11-19
  • 打赏
  • 举报
回复
游戏上的爱情难道真的就仅仅只是游戏吗?
ryfdizuo 2011-11-19
  • 打赏
  • 举报
回复
这里下例子代码研究一下:www.codesampler.com
Baesky 2011-11-19
  • 打赏
  • 举报
回复
先别设置renderstate,另外用PIX看看一帧你都做了什么。
独酌逸醉 2011-11-19
  • 打赏
  • 举报
回复

//file. winmain.cpp
#include "Direct3DFrame.h"

int WINAPI WinMain(HINSTANCE hInstance,
HINSTANCE prevInstance,
PSTR cmdLine,
int showCmd)
{
Direct3DFrame d3dFrame(TEXT("Direct3DFrame"), hInstance,
640, 480, true, D3DDEVTYPE_HAL);

if (!d3dFrame.InitD3D()) {
::MessageBox(0, TEXT("InitD3D() - FAILED"), 0, 0);
return 0;
}

if (!d3dFrame.Setup()) {
::MessageBox(0, TEXT("Setup() - FAILED"), 0, 0);
return 0;
}

d3dFrame.EnterMsgLoop();
d3dFrame.Cleanup();

return 0;
}

独酌逸醉 2011-11-19
  • 打赏
  • 举报
回复

// file.direct3dframe.cpp
[code=C/C++]
#include "Direct3DFrame.h"
#include "Vertex.h"
Direct3DFrame::Direct3DFrame(
LPCWSTR wndName,
HINSTANCE hInstance,
int width, int height,
bool windowed,
D3DDEVTYPE deviceType)
{
m_wndName = wndName;
m_hInstance = hInstance;
m_width = width;
m_height = height;
m_windowed = windowed;
m_deviceType = deviceType;
this->m_device = NULL;

this->m_vb = NULL;
this->m_ib = NULL;

m_yRotAngle = 0.0f;
}

Direct3DFrame::~Direct3DFrame(void)
{
m_device->Release();
}
bool Direct3DFrame::InitD3D()
{
HWND hWnd;
if (!CreateWin32Window(hWnd)) {
return false;
}

// ---- Init D3D:

HRESULT hr = 0;

// Step 1: Create the IDirect3D9 object.
/* IDirect3D9 用途:
* (1) 设置枚举 ( device enumeration )
* ->指获取系统中可用的每块图形卡的性能、显示模式(display mode)、格式及其他信息
* (2) 创建 IDirect3DDevice9 类型
*/
IDirect3D9* d3d9 = NULL;
d3d9 = Direct3DCreate9(D3D_SDK_VERSION);

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

// Step 2: Check for hardare vp.
D3DCAPS9 caps;
d3d9->GetDeviceCaps(D3DADAPTER_DEFAULT, m_deviceType, &caps);

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

// Step3 : Fill out the D3DPRESENT_PARAMETERS structure.
D3DPRESENT_PARAMETERS d3dpp;
d3dpp.BackBufferWidth = m_width;
d3dpp.BackBufferHeight = m_height;
d3dpp.BackBufferFormat = D3DFMT_A8R8G8B8;
d3dpp.BackBufferCount = 1;
d3dpp.MultiSampleType = D3DMULTISAMPLE_NONE;
d3dpp.MultiSampleQuality = 0;
d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD;
d3dpp.hDeviceWindow = hWnd;
d3dpp.Windowed = m_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
m_deviceType, // device type
hWnd, // window assocated with device
vp, // vertex processing
&d3dpp, // present parameters
&m_device); // return created device

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

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

d3d9->Release(); // done with d3d9 object

return true;
}

LRESULT CALLBACK Direct3DFrame::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);
}
bool Direct3DFrame::CreateWin32Window(HWND& hWnd)
{
WNDCLASS wc;
wc.style = CS_HREDRAW | CS_VREDRAW;
wc.lpfnWndProc = (WNDPROC)WndProc;
wc.cbClsExtra = 0;
wc.cbWndExtra = 0;
wc.hInstance = m_hInstance;
wc.hIcon = LoadIcon(0, IDI_APPLICATION);
wc.hCursor = LoadCursor(0, IDC_ARROW);
wc.hbrBackground = (HBRUSH) GetStockObject(WHITE_BRUSH);
wc.lpszMenuName = NULL;
wc.lpszClassName = m_wndName;

if (!RegisterClass(&wc)) {
::MessageBox(0, TEXT("RegisterClass() - FAILED"), 0, 0);
return false;
}

hWnd = ::CreateWindow(m_wndName, m_wndName,
WS_OVERLAPPEDWINDOW^WS_MAXIMIZEBOX , 0, 0, m_width, m_height,
0, 0, m_hInstance, 0);
/*hWnd = ::CreateWindow(m_wndName, m_wndName,
WS_EX_TOPMOST, 0, 0, m_width, m_height,
0, 0, m_hInstance, 0);*/

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

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

return true;
}
bool Direct3DFrame::Display(float timeDelta)
{
if (m_device) {
// spin the cube:
D3DXMATRIX rx, ry;
// rotate 45 degrees on x-axis
D3DXMatrixRotationX(&rx, 3.14f / 4.0f);

// increment y-rotation angle each frame

D3DXMatrixRotationY(&ry, m_yRotAngle);
m_yRotAngle += timeDelta;

// reset angle to zero when angle reaches 2*PI
if (m_yRotAngle >= 6.28f) {
m_yRotAngle = 0.0f;
}

D3DXMATRIX p = rx * ry;

m_device->SetTransform(D3DTS_WORLD, &p);

// draw the scene:
m_device->Clear(0, 0, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, 0xffffffff, 1.0f, 0);
m_device->BeginScene();

m_device->SetStreamSource(0, m_vb, 0, sizeof(Vertex));
m_device->SetIndices(m_ib);
m_device->SetFVF(Vertex::FVF);

// Draw cube.
m_device->DrawIndexedPrimitive(D3DPT_TRIANGLELIST, 0, 0, 8, 0, 12);

m_device->EndScene();
m_device->Present(0, 0, 0, 0);
}

return true;
}
int Direct3DFrame::EnterMsgLoop()
{
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;

Display(timeDelta);

lastTime = currTime;
}
}

return msg.wParam;
}

bool Direct3DFrame::Setup()
{
// Create vertex and index buffers.
m_device->CreateVertexBuffer (
8 * sizeof(Vertex),
D3DUSAGE_WRITEONLY,
Vertex::FVF,
D3DPOOL_MANAGED,
&m_vb,
0);
m_device->CreateIndexBuffer(
36 * sizeof(WORD),
D3DUSAGE_WRITEONLY,
D3DFMT_INDEX16,
D3DPOOL_MANAGED,
&m_ib,
0);

// Fill the buffers with the cube data.
Vertex* vertices;
m_vb->Lock(0, 0, (void**)&vertices, 0);

// vertices of a unit cube
vertices[0] = Vertex(-1.0f, -1.0f, -1.0f);
vertices[1] = Vertex(-1.0f, 1.0f, -1.0f);
vertices[2] = Vertex( 1.0f, 1.0f, -1.0f);
vertices[3] = Vertex( 1.0f, -1.0f, -1.0f);
vertices[4] = Vertex(-1.0f, -1.0f, 1.0f);
vertices[5] = Vertex(-1.0f, 1.0f, 1.0f);
vertices[6] = Vertex( 1.0f, 1.0f, 1.0f);
vertices[7] = Vertex( 1.0f, -1.0f, 1.0f);

m_vb->Unlock();

// define the triangle of the cube:
WORD* indices = NULL;
m_vb->Lock(0, 0, (void**)&indices, 0);

// front side
indices[0] = 0; indices[1] = 1; indices[2] = 2;
indices[3] = 0; indices[4] = 2; indices[5] = 3;

// back side
indices[6] = 4; indices[7] = 6; indices[8] = 5;
indices[9] = 4; indices[10] = 7; indices[11] = 6;

// left side
indices[12] = 4; indices[13] = 5; indices[14] = 1;
indices[15] = 4; indices[16] = 1; indices[17] = 0;

// right side
indices[18] = 3; indices[19] = 2; indices[20] = 6;
indices[21] = 3; indices[22] = 6; indices[23] = 7;

// top
indices[24] = 1; indices[25] = 5; indices[26] = 6;
indices[27] = 1; indices[28] = 6; indices[29] = 2;

// bottom
indices[30] = 4; indices[31] = 0; indices[32] = 3;
indices[33] = 4; indices[34] = 3; indices[35] = 7;

m_ib->Unlock();

// Position and aim the camera.
D3DXVECTOR3 position(0.0f, 0.0f, -5.0f);
D3DXVECTOR3 target(0.0f, 0.0f, 0.0f);
D3DXVECTOR3 up(0.0f, 1.0f, 0.0f);
D3DXMATRIX v;
D3DXMatrixLookAtLH(&v, &position, &target, &up);

m_device->SetTransform(D3DTS_VIEW, &v);

// Set the projection matrix.
D3DXMATRIX proj;
D3DXMatrixPerspectiveFovLH(
&proj,
D3DX_PI * 0.5f,
(float)m_width / (float)m_height,
1.0f,
1000.0f);
m_device->SetTransform(D3DTS_PROJECTION, &proj);

// Switch to wireframe mode.
m_device->SetRenderState(D3DRS_FILLMODE, D3DFILL_WIREFRAME);

return true;
}

void Direct3DFrame::Cleanup()
{
m_vb->Release();
m_vb = NULL;

m_ib->Release();
m_ib = NULL;
}


目录: 第Ⅰ部分 基础知识 必备的数学知识 3D空间中的向量 向量相等 计算向量的长度 向量的规范化 向量加法 向量减法 数乘 点积 叉积 矩阵 矩阵相等、矩阵数乘和矩阵加法 矩阵乘法 单位矩阵 逆矩阵 矩阵的转置 D3DX矩阵 基本变换 平移矩阵 旋转矩阵 比例变换矩阵 几何变换的组合 向量变换的一些函数 平面(选读) D3DXPLANE 点和平面的空间关系 平面的创建 平面的规范化 平面的变换 平面中到某一点的最近点 射线(选读) 射线 射线与平面的相交 小结    第Ⅱ部分 Direct3D基础 第1章 初始化Direct3D 1.1 Direct3D概述 1.1.1 REF设备 1.1.2 D3DDEVTYPE 1.2 COM(组件对象模型) 1.3 预备知识 1.3.1 表面 1.3.2 多重采样 1.3.3 像素格式 1.3.4 内存池 1.3.5 交换链和页面置换 1.3.6 深度缓存 1.3.7 顶点运算 1.3.8 设备性能 1.4 Direct3D的初始化 1.4.1 获取接口IDirect3D9的指针 1.4.2 校验硬件顶点运算 1.4.3 填充D3DPRESENT_PARAMETER结构 1.4.4 创建IDirect3DDevice9 接口 1.5 例程:Direct3D的初始化 1.5.1 d3dUtility.h/cpp 1.5.2 例程框架 1.5.3 例程:D3D初始化 1.6 小结 第2章 绘制流水线 2.1 模型表示 2.1.1 顶点格式 2.1.2 三角形单元 2.1.3 索引 2.2 虚拟摄像机 2.3 绘制流水线 2.3.1 局部坐标系 2.3.2 世界坐标系 2.3.3 观察坐标系 2.3.4 背面消隐 2.3.5 光照 2.3.6 裁剪 2.3.7 投影 2.3.8 视口变换 2.3.9 光栅化 2.4 小结 第3章 Direct3D中的绘制 3.1 顶点缓存与索引缓存 3.1.1 创建顶点缓存和索引缓存 3.1.2 访问缓存内容 3.1.3 获取顶点缓存和索引缓存的信息 3.2 绘制状态 3.3 绘制的准备工作 3.4 使用顶点缓存和索引缓存进行绘制 3.4.1 IDirect3DDevice9::DrawPrimitive 3.4.2 IDirect3DDevice9::DrawIndexedPrimitive 3.4.3 Begin/End Scene 3.5 D3DX几何体 3.6 例程:三角形、立方体、茶壶、D3DXCreate* 3.7 小结 第4章 颜色 4.1 颜色表示 4.2 顶点颜色 4.3 着色 4.4 例程:具有颜色的三角形 4.5 小结 第5章 光照 5.1 光照的组成 5.2 材质 5.3 顶点法线 5.4 光源 5.5 例程:光照 5.6 一些附加例程 5.7 小结 第6章 纹理映射 6.1 纹理坐标 6.2 创建并启用纹理 6.3 纹理过滤器 6.4 多级渐进纹理 6.4.1 多级渐进纹理过滤器 6.4.2 使用多级渐进纹理 6.5 寻址模式 6.6 例程:纹理四边形 6.7 小结 第7章 融合技术 7.1 融合方程 7.2 融合因子 7.3 透明度 7.3.1 Alpha通道 7.3.2 指定Alpha来源 7.4 用DirectX Texture Tool 创建Alpha通道 7.5 例程:透明效果 7.6 小结 第8章 模板 8.1 模板缓存的使用 8.1.1 模板缓存格式的查询 8.1.2 模板测试 8.1.3 模板测试的控制 8.1.4 模板缓存的更新 8.1.5 模板写掩码 8.2 例程:镜面效果 8.2.1 成像中的数学问题 8.2.2 镜面效果实现概述 8.2.3 代码解析 8.3 例程:Planer Shadows 8.3.1 平行光阴影 8.3.2 点光源产生的阴影 8.3.3 阴影矩阵 8.3.4 使用模板缓存防止二次融合 8.3.5 代码解析 8.4 小结 第Ⅲ部分 Direct3D的应用 第9章 字体 9.1 ID3DXFont接口 9.1.1 创建一个ID3DXFont 接口对象 9.1.2 绘制文本 9.1.3 计算每秒绘制的帧数 9.2 CD3DFont 9.2.1 创建CD3DFont类的实例 9.2.2 绘制文本 9.2.3 清理 9.3 D3DXCreateText函数 9.4 小结 第10章 网格(一) 10.1 几何信息 10.2 子集和属性缓存 10.3 绘制 10.4 网格优化 10.5 属性表 10.6 邻接信息 10.7 克隆 10.8 创建网格(D3DXCreateMeshFVF) 10.9 例程:网格的创建与绘制 10.10 小结 第11章 网格(二) 11.1 ID3DXBuffer 11.2 XFile 11.2.1 加载XFile文件 11.2.2 XFile材质 11.2.3 例程:XFile 11.2.4 生成顶点法线 11.3 渐进网格 11.3.1 生成渐进网格 11.3.2 顶点属性权值 11.3.3 ID3DXPMesh接口方法 11.3.4 例程:Progressive Mesh 11.4 外接体 11.4.1 一些新的特殊常量 11.4.2 外接体的类型 11.4.3 例程:Bounding Volumes 11.5 小结 第12章 设计一个灵活的Camera类 12.1 Camera类的设计 12.2 实现细节 12.2.1 观察矩阵(取景变换矩阵, View Matrix)的计算 12.2.2 绕任意轴的旋转 12.2.3 俯仰、偏航和滚动 12.2.4 行走、扫视和升降 12.3 例程:Camera 12.4 小结 第13章 地形绘制基础 13.1 高度图 13.1.1 创建高度图 13.1.2 加载RAW文件 13.1.3 访问和修改高度图 13.2 创建地形几何信息 13.2.1 顶点的计算 13.2.2 索引的计算 13.3 纹理映射 13.4 光照 13.4.1 概述 13.4.2 坐标方格的明暗度计算 13.4.3 对地形进行着色 13.5 在地形中“行走” 13.6 例程:Terrain 13.7 一些改进 13.8 小结 第14章 粒子系统 14.1 粒子和点精灵 14.1.1 结构格式 14.1.2 点精灵的绘制状态 14.1.3 粒子及其属性 14.2 粒子系统的组成 14.2.1 绘制一个粒子系统 14.2.2 随机性 14.3 具体的粒子系统 14.3.1 例程:Snow System 14.3.2 例程:Firework 14.3.3 例程:Particle Gun 14.4 小结 第15章 拾取 15.1 屏幕到投影窗口的变换 15.2 拾取射线的计算 15.3 对射线进行变换 15.4 射线/物体相交判定 15.5 例程:Picking 15.6 小结
Introduction to 3D Game Programming with DirectX 9.0,中文书名为《DirectX 9.0 3D 游戏开发编程基础》,资源是这本书的英文原版,配有详细的书签目录 最后附上其中文目录 目录 第Ⅰ部分 基础知识 必备的数学知识 3 3D空间中的向量 3 向量相等 7 计算向量的长度 7 向量的规范化 8 向量加法 9 向量减法 9 数乘 10 点积 11 叉积 11 矩阵 12 矩阵相等、矩阵数乘和矩阵加法 13 矩阵乘法 14 单位矩阵 15 逆矩阵 15 矩阵的转置 16 D3DX矩阵 16 基本变换 19 平移矩阵 20 旋转矩阵 21 比例变换矩阵 23 几何变换的组合 24 向量变换的一些函数 25 平面(选读) 26 D3DXPLANE 27 点和平面的空间关系 27 平面的创建 28 平面的规范化 29 平面的变换 29 平面中到某一点的最近点 30 射线(选读) 31 射线 31 射线与平面的相交 32 小结 32 第Ⅱ部分 Direct3D基础 第1章 初始化Direct3D 37 1.1 Direct3D概述 37 1.1.1 REF设备 38 1.1.2 D3DDEVTYPE 38 1.2 COM(组件对象模型) 38 1.3 预备知识 39 1.3.1 表面 39 1.3.2 多重采样 41 1.3.3 像素格式 42 1.3.4 内存池 42 1.3.5 交换链和页面置换 43 1.3.6 深度缓存 44 1.3.7 顶点运算 45 1.3.8 设备性能 45 1.4 Direct3D的初始化 46 1.4.1 获取接口IDirect3D9的指针 47 1.4.2 校验硬件顶点运算 47 1.4.3 填充D3DPRESENT_PARAMETER结构 48 1.4.4 创建IDirect3DDevice9接口 50 1.5 例程:Direct3D的初始化 51 1.5.1 d3dUtility.h/cpp 52 1.5.2 例程框架 53 1.5.3 例程:D3D初始化 54 1.6 小结 56 第2章 绘制流水线 58 2.1 模型表示 59 2.1.1 顶点格式 60 2.1.2 三角形单元 60 2.1.3 索引 61 2.2 虚拟摄像机 62 2.3 绘制流水线 63 2.3.1 局部坐标系 64 2.3.2 世界坐标系 64 2.3.3 观察坐标系 65 2.3.4 背面消隐 67 2.3.5 光照 68 2.3.6 裁剪 68 2.3.7 投影 69 2.3.8 视口变换 70 2.3.9 光栅化 72 2.4 小结 72 第3章 Direct3D中的绘制 73 3.1 顶点缓存与索引缓存 73 3.1.1 创建顶点缓存和索引缓存 73 3.1.2 访问缓存内容 76 3.1.3 获取顶点缓存和索引缓存的信息 77 3.2 绘制状态 78 3.3 绘制的准备工作 78 3.4 使用顶点缓存和索引缓存进行绘制 79 3.4.1 IDirect3DDevice9::DrawPrimitive 79 3.4.2 IDirect3DDevice9::DrawIndexedPrimitive 80 3.4.3 Begin/End Scene 81 3.5 D3DX几何体 81 3.6 例程:三角形、立方体、茶壶、D3DXCreate* 83 3.7 小结 87 第4章 颜色 89 4.1 颜色表示 89 4.2 顶点颜色 92 4.3 着色 92 4.4 例程:具有颜色的三角形 93 4.5 小结 95 第5章 光照 97 5.1 光照的组成 97 5.2 材质 98 5.3 顶点法线 100 5.4 光源 102 5.5 例程:光照 105 5.6 一些附加例程 108 5.7 小结 108 第6章 纹理映射 109 6.1 纹理坐标 110 6.2 创建并启用纹理 111 6.3 纹理过滤器 112 6.4 多级渐进纹理 113 6.4.1 多级渐进纹理过滤器 114 6.4.2 使用多级渐进纹理 114 6.5 寻址模式 114 6.6 例程:纹理四边形 116 6.7 小结 118 第7章 融合技术 119 7.1 融合方程 119 7.2 融合因子 121 7.3 透明度 122 7.3.1 Alpha通道 122 7.3.2 指定Alpha来源 123 7.4 用DirectX Texture Tool创建Alpha通道 123 7.5 例程:透明效果 125 7.6 小结 127 第8章 模板 128 8.1 模板缓存的使用 129 8.1.1 模板缓存格式的查询 129 8.1.2 模板测试 130 8.1.3 模板测试的控制 130 8.1.4 模板缓存的更新 132 8.1.5 模板写掩码 132 8.2 例程:镜面效果 133 8.2.1 成像中的数学问题 133 8.2.2 镜面效果实现概述 134 8.2.3 代码解析 135 8.3 例程:Planer Shadows 139 8.3.1 平行光阴影 139 8.3.2 点光源产生的阴影 140 8.3.3 阴影矩阵 141 8.3.4 使用模板缓存防止二次融合 142 8.3.5 代码解析 143 8.4 小结 144 第Ⅲ部分 Direct3D的应用 第9章 字体 149 9.1 ID3DXFont接口 149 9.1.1 创建一个ID3DXFont接口对象 149 9.1.2 绘制文本 150 9.1.3 计算每秒绘制的帧数 151 9.2 CD3DFont 152 9.2.1 创建CD3DFont类的实例 152 9.2.2 绘制文本 152 9.2.3 清理 153 9.3 D3DXCreateText函数 153 9.4 小结 155 第10章 网格(一) 156 10.1 几何信息 156 10.2 子集和属性缓存 157 10.3 绘制 159 10.4 网格优化 159 10.5 属性表 161 10.6 邻接信息 163 10.7 克隆 164 10.8 创建网格(D3DXCreateMeshFVF) 165 10.9 例程:网格的创建与绘制 167 10.10 小结 172 第11章 网格(二) 174 11.1 ID3DXBuffer 174 11.2 XFile 175 11.2.1 加载XFile文件 175 11.2.2 XFile材质 176 11.2.3 例程:XFile 177 11.2.4 生成顶点法线 180 11.3 渐进网格 181 11.3.1 生成渐进网格 182 11.3.2 顶点属性权值 183 11.3.3 ID3DXPMesh接口方法 183 11.3.4 例程:Progressive Mesh 184 11.4 外接体 187 11.4.1 一些新的特殊常量 189 11.4.2 外接体的类型 189 11.4.3 例程:Bounding Volumes 190 11.5 小结 192 第12章 设计一个灵活的Camera类 193 12.1 Camera类的设计 193 12.2 实现细节 195 12.2.1 观察矩阵(取景变换矩阵,View Matrix)的计算 195 12.2.2 绕任意轴的旋转 198 12.2.3 俯仰、偏航和滚动 199 12.2.4 行走、扫视和升降 201 12.3 例程:Camera 202 12.4 小结 205 第13章 地形绘制基础 206 13.1 高度图 207 13.1.1 创建高度图 207 13.1.2 加载RAW文件 208 13.1.3 访问和修改高度图 209 13.2 创建地形几何信息 210 13.2.1 顶点的计算 212 13.2.2 索引的计算 214 13.3 纹理映射 216 13.4 光照 219 13.4.1 概述 219 13.4.2 坐标方格的明暗度计算 220 13.4.3 对地形进行着色 222 13.5 在地形中“行走” 222 13.6 例程:Terrain 226 13.7 一些改进 228 13.8 小结 229 第14章 粒子系统 230 14.1 粒子和点精灵 230 14.1.1 结构格式 230 14.1.2 点精灵的绘制状态 231 14.1.3 粒子及其属性 233 14.2 粒子系统的组成 234 14.2.1 绘制一个粒子系统 238 14.2.2 随机性 243 14.3 具体的粒子系统 243 14.3.1 例程:Snow System 244 14.3.2 例程:Firework 246 14.3.3 例程:Particle Gun 248 14.4 小结 250 第15章 拾取 251 15.1 屏幕到投影窗口的变换 253 15.2 拾取射线的计算 254 15.3 对射线进行变换 255 15.4 射线/物体相交判定 256 15.5 例程:Picking 258 15.6 小结 259 第Ⅳ部分 着色器和效果 第16章 高级着色语言(HLSL)入门 263 16.1 HLSL着色器程序的编制 264 16.1.1 全局变量 266 16.1.2 输入和输出结构 266 16.1.3 入口函数 267 16.2 HLSL着色器程序的编译 268 16.2.1 常量表 268 16.2.2 HLSL着色器程序的编译 272 16.3 变量类型 274 16.3.1 标量类型 274 16.3.2 向量类型 274 16.3.3 矩阵类型 275 16.3.4 数组 277 16.3.5 结构体 277 16.3.6 关键字typedef 277 16.3.7 变量的前缀 278 16.4 关键字、语句及类型转换 279 16.4.1 关键字 279 16.4.2 基本程序流程 279 16.4.3 类型转换 280 16.5 运算符 281 16.6 用户自定义函数 282 16.7 内置函数 284 16.8 小结 286 第17章 顶点着色器入门 287 17.1 顶点声明 288 17.1.1 顶点声明的描述 288 17.1.2 顶点声明的创建 291 17.1.3 顶点声明的启用 291 17.2 顶点数据的使用 291 17.3 使用顶点着色器的步骤 293 17.3.1 顶点着色器的编写与编译 294 17.3.2 顶点着色器的创建 294 17.3.3 顶点着色器的设置 294 17.3.4 顶点着色器的销毁 295 17.4 例程:Diffuse Lighting 295 17.5 例程:Cartoon Rendering 302 17.5.1 卡通着色 303 17.5.2 卡通着色的顶点着色器代码 304 17.5.3 轮廓的勾勒 307 17.5.4 实现轮廓勾勒的顶点着色器代码 310 17.6 小结 312 第18章 像素着色器入门 313 18.1 多重纹理概述 313 18.1.1 启用多重纹理 315 18.1.2 多重纹理坐标 316 18.2 像素着色器的输入和输出 317 18.3 使用像素着色器的步骤 318 18.3.1 像素着色器的编写和编译 318 18.3.2 像素着色器的创建 318 18.3.3 像素着色器的设置 319 18.3.4 像素着色器的销毁 319 18.4 HLSL采样器对象 319 18.5 例程:像素着色器中的多重纹理 321 18.6 小结 329 第19章 效果框架 331 19.1 手法与路径 331 19.2 更多HLSL的内置对象 333 19.2.1 纹理对象 333 19.2.2 采样器对象与采样器状态 333 19.2.3 顶点着色器对象和像素着色器对象 334 19.2.4 字符串 335 19.2.5 注释 335 19.3 效果文件中的设备状态 336 19.4 创建一种效果 337 19.5 常量的设置 338 19.6 使用一种效果 340 19.6.1 效果句柄的获取 341 19.6.2 效果的激活 341 19.6.3 效果的启用 341 19.6.4 当前绘制路径的设置 342 19.6.5 效果的终止 342 19.6.6 一个例子 342 19.7 例程:效果文件中的光照和纹理 343 19.8 例程:雾效 349 19.9 例程:卡通效果 352 19.10 EffectEdit 353 19.11 小结 354 附录 Windows编程入门 355 参考文献 372
传说中的龙书是也。。。 最好最新的DirectX游戏开发入门书籍 英文版+中文版+源代码 打包 非常适合初学者 内容提要 -------------------------------------------------------------------------------- 本书主要介绍如何使用DirectX 9.0开发交互式3D图形程序,重点是游戏开发。全书首先介绍了必要的数学工具,然后讲解了相关的3D概念。其他主题几乎涵盖了Direct3D中的所有基本运算,例如图元的绘制、光照、纹理、Alpha融合、模板,以及如何使用Direct3D实现游戏中所需的技术。介绍顶定点着色器和像素着色器的章节(包含了效果框架和新的高级着色语言的内容)对这些关键运算进行了较为集中的讨论。 本书内容深入浅出,内容广泛,可供从事3D游戏程序设计、可视化系统设计或其他图形应用程序开发开发人员和大中专院校学生参考,也极适合各种游戏开发培训机构作为Direct3D编程的培训教程。 目录 -------------------------------------------------------------------------------- 第Ⅰ部分 基础知识 必备的数学知识\t 3D空间中的向量\t 矩阵\t\t 基本变换\t 平面(选读)\t 射线(选读)\t 小结\t\t 第Ⅱ部分 Direct3D基础 第1章 初始化Direct3D 1.1 Direct3D概述\t 1.2 COM(组件对象模型)\t 1.3 预备知识\t 1.4 Direct3D的初始化\t 1.5 例程:Direct3D的初始化 1.6 小结\t 第2章 绘制流水线\t 2.1 模型表示\t 2.2 虚拟摄像机 2.3 绘制流水线 2.4 小结\t 第3章 Direct3D中的绘制\t 3.1 顶点缓存与索引缓存 3.2 绘制状态\t 3.3 绘制的准备工作\t 3.4 使用顶点缓存和索引缓存进行绘制\t 3.5 D3DX几何体 3.6 例程:三角形、立方体、茶壶、D3DXCreate* 3.7 小结\t 第4章 颜色\t 4.1 颜色表示 4.2 顶点颜色 4.3 着色\t 4.4 例程:具有颜色的三角形\t 4.5 小结\t 第5章 光照\t 5.1 光照的组成\t 5.2 材质\t 5.3 顶点法线\t 5.4 光源\t 5.5 例程:光照 5.6 一些附加例程\t 5.7 小结\t 第6章 纹理映射 6.1 纹理坐标\t 6.2 创建并启用纹理\t 6.3 纹理过滤器 6.4 多级渐进纹理 6.5 寻址模式 6.6 例程:纹理四边形 6.7 小结\t 第7章 融合技术\t 7.1 融合方程\t 7.2 融合因子 7.3 透明度 7.4 用DirectX Texture Tool创建Alpha通道\t 7.5 例程:透明效果\t 7.6 小结\t 第8章 模板\t 8.1 模板缓存的使用\t 8.2 例程:镜面效果\t 8.3 例程:Planer Shadows\t 8.4 小结\t 第Ⅲ部分 Direct3D的应用 第9章 字体\t 第10章 网格(一)\t 第11章 网格(二)\t 第12章 设计一个灵活的Camera类 第13章 地形绘制基础\t 第14章 粒子系统\t 第15章 拾取\t 第Ⅳ部分 着色器和效果 第16章 高级着色语言(HLSL)入门\t 第17章 顶点着色器入门\t 第18章 像素着色器入门\t 第19章 效果框架\t 附录 Windows编程入门\t 参考文献 作者介绍 -------------------------------------------------------------------------------- Prank Luna是Hero lnteractive的程序员,从事交互式3D图形编程已有八年多。他最早接触DirectX可以追溯到DirectX5发布之时,目前居住在加州的洛杉矶市。

8,305

社区成员

发帖
与我相关
我的任务
社区描述
游戏开发相关内容讨论专区
社区管理员
  • 游戏开发
  • 呆呆敲代码的小Y
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧