一个关于DirectX 变换的问题(进者有分)

ChinaShrimp 2005-01-05 02:48:46
我下载了DirectX 9的SDK,安装完毕后在Microsoft DirectX 9.0 SDK (December 2004)\Samples\C++\Direct3D\Tutorials\Tut02_Vertices有一个如何绘制三角形的例子以及Tut03_Matrices如何设置变换矩阵。但是我看完第二个例子后,想直接在上面增加变换矩阵即
void SetMatrix()
{
HRESULT result;
D3DXMATRIXA16 matWorld;
D3DXMatrixTranslation(&matWorld, 50, 50, 0);

result = g_pd3dDevice->SetTransform(D3DTS_WORLD, &matWorld);
assert(result == D3D_OK);

D3DXMATRIXA16 matView;
D3DXVECTOR3 vEyePt(0, 0, 6);
D3DXVECTOR3 vLookatPt(0, 0, -5);
D3DXVECTOR3 vUpVec(0, 1, 0);
D3DXMatrixLookAtLH(&matView, &vEyePt, &vLookatPt, &vUpVec);

g_pd3dDevice->SetTransform(D3DTS_VIEW, &matView);

D3DXMATRIXA16 matProj;
D3DXMatrixPerspectiveFovLH( &matProj, D3DX_PI/4, 1.0f, 1.0f, 100.0f );
g_pd3dDevice->SetTransform( D3DTS_PROJECTION, &matProj );
}

在绘制函数里面加上了对SetMatrix的调用
VOID Render()
{
// Clear the backbuffer to a blue color
g_pd3dDevice->Clear( 0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(0,0,255), 1.0f, 0 );

// Begin the scene
if( SUCCEEDED( g_pd3dDevice->BeginScene() ) )
{
SetMatrix();

g_pd3dDevice->SetStreamSource( 0, g_pVB, 0, sizeof(CUSTOMVERTEX) );
g_pd3dDevice->SetFVF( D3DFVF_CUSTOMVERTEX );
g_pd3dDevice->DrawPrimitive( D3DPT_TRIANGLEFAN, 0, 2);

// End the scene
g_pd3dDevice->EndScene();
}

// Present the backbuffer contents to the display
g_pd3dDevice->Present( NULL, NULL, NULL, NULL );
}

困扰我的就是不管我怎么设置这些变换矩阵,最终的显示结果都一样好像就没有设置过这些变换一样,我想请问大虾我哪里做错了或者少添加了什么东西?
...全文
279 20 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
ChinaShrimp 2005-09-03
  • 打赏
  • 举报
回复
多谢大家
chijingde 2005-03-04
  • 打赏
  • 举报
回复
应该解决了吧?
IO_X 2005-03-04
  • 打赏
  • 举报
回复
关于RHW顶点格式的帖子见过N遍了...-.-b
bright_chn 2005-03-03
  • 打赏
  • 举报
回复
up~
mars_snailbaby 2005-03-03
  • 打赏
  • 举报
回复
看一下
tomwen 2005-03-03
  • 打赏
  • 举报
回复
偶 不是很懂
也来学学
Snow_1980 2005-01-12
  • 打赏
  • 举报
回复
惭愧,我还不知道呢……
IO_X 2005-01-11
  • 打赏
  • 举报
回复
晕,有rhw的顶点是不经过变换管道的
Leon8086 2005-01-11
  • 打赏
  • 举报
回复
仔细看看Vertex Format那章,D3DFVF_XYZRHW这种格式属于“Lit & Transformed”的顶点,就是说在他上面不会再做光照和坐标系变换了。这种定点格式直接对应于RenderTarget上面的像素点。
Kshape 2005-01-09
  • 打赏
  • 举报
回复
up
zhouxiaoxiao2015 2005-01-08
  • 打赏
  • 举报
回复
该成这个试一试:D3DFVF_XYZ|D3DFVF_NORMAL|D3DFVF_TEX1
xiaolizi 2005-01-08
  • 打赏
  • 举报
回复
#define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZ|D3DFVF_DIFFUSE)
这个格式比较合适
lucky420 2005-01-08
  • 打赏
  • 举报
回复
D3DFVF_XYZRHW:Vertex format includes the position of a transformed vertex.它把你设的位置值直接作为转换后的坐标,所以你的转换矩阵不起作用的。
寻开心 2005-01-07
  • 打赏
  • 举报
回复
支持,iwaiwai的说法, 这种格式根本就不受变换矩阵的影响
guccyme_ 2005-01-07
  • 打赏
  • 举报
回复
#define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZRHW|D3DFVF_DIFFUSE)

D3DFVF_XYZRHW这个参数的意义查一查
ChinaShrimp 2005-01-06
  • 打赏
  • 举报
回复
困扰我的就是不管我怎么设置这些变换矩阵,最终的显示结果都一样好像就没有设置过这些变换一样,我想请问大虾我哪里做错了或者少添加了什么东西?
潘李亮 2005-01-05
  • 打赏
  • 举报
回复
你想问什么啊
ChinaShrimp 2005-01-05
  • 打赏
  • 举报
回复
很着急,请大家多多帮忙!
ChinaShrimp 2005-01-05
  • 打赏
  • 举报
回复
//-----------------------------------------------------------------------------
// Name: Cleanup()
// Desc: Releases all previously initialized objects
//-----------------------------------------------------------------------------
VOID Cleanup()
{
if( g_pVB != NULL )
g_pVB->Release();

if( g_pd3dDevice != NULL )
g_pd3dDevice->Release();

if( g_pD3D != NULL )
g_pD3D->Release();
}


void SetMatrix()
{
HRESULT result;
D3DXMATRIXA16 matWorld;
D3DXMatrixTranslation(&matWorld, 50, 50, 0);

result = g_pd3dDevice->SetTransform(D3DTS_WORLD, &matWorld);
assert(result == D3D_OK);

D3DXMATRIXA16 matView;
D3DXVECTOR3 vEyePt(0, 0, 6);
D3DXVECTOR3 vLookatPt(0, 0, -5);
D3DXVECTOR3 vUpVec(0, 1, 0);
D3DXMatrixLookAtLH(&matView, &vEyePt, &vLookatPt, &vUpVec);

g_pd3dDevice->SetTransform(D3DTS_VIEW, &matView);

D3DXMATRIXA16 matProj;
D3DXMatrixPerspectiveFovLH( &matProj, D3DX_PI/4, 1.0f, 1.0f, 100.0f );
g_pd3dDevice->SetTransform( D3DTS_PROJECTION, &matProj );
}


//-----------------------------------------------------------------------------
// Name: Render()
// Desc: Draws the scene
//-----------------------------------------------------------------------------
VOID Render()
{
// Clear the backbuffer to a blue color
g_pd3dDevice->Clear( 0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(0,0,255), 1.0f, 0 );

// Begin the scene
if( SUCCEEDED( g_pd3dDevice->BeginScene() ) )
{
SetMatrix();
// Draw the triangles in the vertex buffer. This is broken into a few
// steps. We are passing the vertices down a "stream", so first we need
// to specify the source of that stream, which is our vertex buffer. Then
// we need to let D3D know what vertex shader to use. Full, custom vertex
// shaders are an advanced topic, but in most cases the vertex shader is
// just the FVF, so that D3D knows what type of vertices we are dealing
// with. Finally, we call DrawPrimitive() which does the actual rendering
// of our geometry (in this case, just one triangle).
g_pd3dDevice->SetStreamSource( 0, g_pVB, 0, sizeof(CUSTOMVERTEX) );
g_pd3dDevice->SetFVF( D3DFVF_CUSTOMVERTEX );
g_pd3dDevice->DrawPrimitive( D3DPT_TRIANGLEFAN, 0, 2);

// End the scene
g_pd3dDevice->EndScene();
}

// Present the backbuffer contents to the display
g_pd3dDevice->Present( NULL, NULL, NULL, NULL );
}




//-----------------------------------------------------------------------------
// Name: MsgProc()
// Desc: The window's message handler
//-----------------------------------------------------------------------------
LRESULT WINAPI MsgProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam )
{
switch( msg )
{
case WM_DESTROY:
Cleanup();
PostQuitMessage( 0 );
return 0;
}

return DefWindowProc( hWnd, msg, wParam, lParam );
}




//-----------------------------------------------------------------------------
// Name: WinMain()
// Desc: The application's entry point
//-----------------------------------------------------------------------------
INT WINAPI WinMain( HINSTANCE hInst, HINSTANCE, LPSTR, INT )
{
// Register the window class
WNDCLASSEX wc = { sizeof(WNDCLASSEX), CS_CLASSDC, MsgProc, 0L, 0L,
GetModuleHandle(NULL), NULL, NULL, NULL, NULL,
"test", NULL };
RegisterClassEx( &wc );

// Create the application's window
HWND hWnd = CreateWindow( "test", "transform",
WS_OVERLAPPEDWINDOW, 100, 100, 512, 512,
GetDesktopWindow(), NULL, wc.hInstance, NULL );

// Initialize Direct3D
if( SUCCEEDED( InitD3D( hWnd ) ) )
{
// Create the vertex buffer
if( SUCCEEDED( InitVB() ) )
{
// Show the window
ShowWindow( hWnd, SW_SHOWDEFAULT );
UpdateWindow( hWnd );

// Enter the message loop
MSG msg;
ZeroMemory( &msg, sizeof(msg) );
while( msg.message!=WM_QUIT )
{
if( PeekMessage( &msg, NULL, 0U, 0U, PM_REMOVE ) )
{
TranslateMessage( &msg );
DispatchMessage( &msg );
}
else
Render();
}
}
}

UnregisterClass( "test", wc.hInstance );
return 0;
}
ChinaShrimp 2005-01-05
  • 打赏
  • 举报
回复
多谢了!!!
全部代码:
#include <Windows.h>
#include <mmsystem.h>
#include <d3dx9.h>
#include <strsafe.h>
#include <assert.h>

//-----------------------------------------------------------------------------
// Global variables
//-----------------------------------------------------------------------------
LPDIRECT3D9 g_pD3D = NULL; // Used to create the D3DDevice
LPDIRECT3DDEVICE9 g_pd3dDevice = NULL; // Our rendering device
LPDIRECT3DVERTEXBUFFER9 g_pVB = NULL; // Buffer to hold vertices

// A structure for our custom vertex type
struct CUSTOMVERTEX
{
FLOAT x, y, z, rhw; // The transformed position for the vertex
DWORD color; // The vertex color
};

// Our custom FVF, which describes our custom vertex structure
#define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZRHW|D3DFVF_DIFFUSE)




//-----------------------------------------------------------------------------
// Name: InitD3D()
// Desc: Initializes Direct3D
//-----------------------------------------------------------------------------
HRESULT InitD3D( HWND hWnd )
{
// Create the D3D object.
if( NULL == ( g_pD3D = Direct3DCreate9( D3D_SDK_VERSION ) ) )
return E_FAIL;

// Set up the structure used to create the D3DDevice
D3DPRESENT_PARAMETERS d3dpp;
ZeroMemory( &d3dpp, sizeof(d3dpp) );
d3dpp.Windowed = TRUE;
d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD;
d3dpp.BackBufferFormat = D3DFMT_UNKNOWN;

// Create the D3DDevice
if( FAILED( g_pD3D->CreateDevice( D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd,
D3DCREATE_SOFTWARE_VERTEXPROCESSING,
&d3dpp, &g_pd3dDevice ) ) )
{
return E_FAIL;
}

// Device state would normally be set here

return S_OK;
}




//-----------------------------------------------------------------------------
// Name: InitVB()
// Desc: Creates a vertex buffer and fills it with our vertices. The vertex
// buffer is basically just a chuck of memory that holds vertices. After
// creating it, we must Lock()/Unlock() it to fill it. For indices, D3D
// also uses index buffers. The special thing about vertex and index
// buffers is that they can be created in device memory, allowing some
// cards to process them in hardware, resulting in a dramatic
// performance gain.
//-----------------------------------------------------------------------------
HRESULT InitVB()
{
float fWidth = 2*128.0f;
// Initialize three vertices for rendering a triangle
CUSTOMVERTEX vertices[] =
{
{ -fWidth, -fWidth, 0.5f, 1.0f, 0xffff0000, }, // x, y, z, rhw, color
{ fWidth, -fWidth, 0.5f, 1.0f, 0xff00ff00, },
{ fWidth, fWidth, 0.5f, 1.0f, 0xff00ffff, },
{ -fWidth, fWidth, 0.5f, 1.0f, 0xff00ffff, }
};

// Create the vertex buffer. Here we are allocating enough memory
// (from the default pool) to hold all our 3 custom vertices. We also
// specify the FVF, so the vertex buffer knows what data it contains.
if( FAILED( g_pd3dDevice->CreateVertexBuffer( 4*sizeof(CUSTOMVERTEX),
0, D3DFVF_CUSTOMVERTEX,
D3DPOOL_DEFAULT, &g_pVB, NULL ) ) )
{
return E_FAIL;
}

// Now we fill the vertex buffer. To do this, we need to Lock() the VB to
// gain access to the vertices. This mechanism is required becuase vertex
// buffers may be in device memory.
VOID* pVertices;
if( FAILED( g_pVB->Lock( 0, sizeof(vertices), (void**)&pVertices, 0 ) ) )
return E_FAIL;
memcpy( pVertices, vertices, sizeof(vertices) );
g_pVB->Unlock();

return S_OK;
}
中文名: 精通DirectX 3D图形与动画程序设计 原名: 精通DirectX 3D图形与动画程序设计 别名: 游戏编程, 游戏开发 作者: 王德才 资源格式: PDF 版本: 扫描版 出版社: 人民邮电出版社书号: 9787115159717发行时间: 2007年5月 地区: 大陆 语言: 简体中文 简介: 内容介绍:  本书系统全面地介绍了direct3d三维图形程序设计的相关内容。全书共分5个部分。第一部分介绍了direct3d程序设计基础,包括三维坐标变换、光照处理、纹理贴图、雾化效果、文件模型、文本和字体等内容。第二部分介绍了direct3d程序设计的相关高级技术,包括多层纹理映射、纹理坐标自动生成与变换、环境映射、凹凸纹理映射、立体纹理、纹理压缩、.x文件格式分析、网格模型优化、层次细节网格模型、增强网格模型、蒙皮骨骼动画网格模型以及粒子系统等。第三部分介绍了direct3d gpu编程(即可编程流水线),包括hlsl渲染语言、hlsl顶点渲染、hlsl像素渲染、effect及其高级应用、asm顶点渲染、asm像素渲染。第四部分介绍了三维图形程序设计领域目前流行的许多实用技术,包括广告板技术、纹理动画技术、自然现象模拟、三维地形模拟、海浪效果模拟、柔性物体模拟、凹凸纹理应用、短毛发模拟以及体积雾等。第五部分是附录,包括学习direct3d之前所必须掌握的基础知识和directx sdk提供的各种工具的简要说明。   本书配套光盘提供了书中所有示例程序的可执行文件、工程文件和完整源代码,以方便读者编译、调试示例程序。   本书主要面向对direct3d三维图形程序设计感兴趣的编程人员、游戏开发人员以及可视化仿真工程技术人员,也可作为高等院校相关专业和培训机构的direct3d程序设计用书。 目录: 第一部分 基础篇 第1章 directx与direct3d简介 1.1 什么是directx和direct3d 1.2 directx的发展历史  1.3 directx 9.0的安装与配置  1.3.1 directx 9.0的安装 1.3.2 选择调试或发布库 1.3.3 在visual studio.net ide中配置directx 1.3.4 浏览directx sdk示例程序   1.4 directx功能组件 1.5 directx的几种开发方式 1.6 小结 第2章 direct3d程序设计基础 2.1 相关基础知识 2.2 direct3d体系结构 2.3 direct3d对象 2.4 direct3d设备对象 2.4.1 direct3d设备类型 2.4.2 创建direct3d设备对象 2.5 direct3d程序基本结构 . 2.6 最简单的direct3d程序   2.6.1 工程项目和开发环境设置 2.6.2 创建窗口 2.6.3 初始化direct3d 2.6.4 消息循环 2.6.5 渲染图形 2.6.6 结束direct3d程序   2.7 direct3d设备对象深入探讨 2.8 direct3d表面 2.9 小结 第3章 坐标系与基本图元 3.1 direct3d坐标系 3.2 direct3d基本图元 3.3 使用顶点缓冲区绘制图形 3.3.1 创建顶点缓冲区 3.3.2 渲染顶点缓冲区图形 3.3.3 各种基本图元绘制 3.4 使用索引缓冲区绘制图形 3.5 图形渲染其他相关内容 3.5.1 灵活顶点格式 3.5.2 渲染状态 3.5.3 场景提交 3.5.4 图形反锯齿(antialiasing) 3.5.5 全屏幕显示 3.6 direct3d中的颜色表示 3.7 资源的概念 3.8 小结 第4章 顶点坐标变换 4.1 顶点坐标变换和光照流水线概述 4.2 矩阵类型及其操作 4.3 世界变换 4.4 取景变换 4.5 投影变换 4.6 视区变换 4.7 获取direct3d坐标变换矩阵 4.8 三维坐标变换示例程序   4.9 小结 第5章 光照与材质 5.1 光照计算模型 5.2 光源 5.2.1 光源类型 5.2.2 光源属性 5.2.3 设置灯光 5.2.4 对光源的几点说明 5.3 材质 5.3.1 设置材质 5.3.2 获取材质属性 5.4 光照和材质示例程序   5.4.1 简单光照示例程序   5.4.2 多光源光照示例程序   5.4.3 使用灯光的几点说明 5.5 深入理解光照计算模型 5.6 小结 第6章 纹理映射基础 6.1 基本概念 6.2 使用纹理 6.3 纹理过滤方式 6.3.1 最近点采样  6.3.2 线性纹理过滤 6.3.3 各项异性纹理过滤 6.3.4 多级渐进纹理过滤 6.3.5 纹理过滤方式示例程序   6.4 纹理寻址模式 6.4.1 重迭纹理寻址模式 6.4.2 镜像纹理寻址模式 6.4.3 夹取纹理寻址模式 6.4.4 边框颜色纹理寻址模式 6.4.5 纹理寻址模式示例程序   6.5 纹理阶段混合状态 6.5.1 纹理阶段混合状态设置 6.5.2 纹理阶段混合状态示例程序   6.6 纹理包装 6.7 小结 第7章 使用文件模型 7.1 三维模型基础 7.2 模型文件格式转换 7.2.1 ds max制作的模型转换为.x文件模型 7.2.2 maya制作的模型转换为.x文件模型 7.3 在direct3d程序中载入模型 7.3.1 网格模型接口id3dxmesh 7.3.2 载入.x文件并生成网格模型 7.4 渲染网格模型 7.5 三维模型旋转 7.5.1 通过矩阵实现模型旋转 7.5.2 通过四元数实现模型旋转 7.6 使用文件模型的几点提示 7.7 小结 第8章 深度测试与alpha混合 8.1 深度测试 8.1.1 深度缓冲区与深度测试 8.1.2 使用深度测试 8.2 半透明物体的绘制 8.2.1 alpha混合原理 8.2.2 利用alpha混合实现半透明效果 8.2.3 alpha混合系数 8.3 alpha测试 8.3.1 alpha测试原理 8.3.2 使用alpha测试 8.4 小结 第9章 雾化 9.1 雾化效果实现原理 9.2 雾化混合因子计算方法 9.3 顶点雾化与像素雾化 9.3.1 顶点雾化与基于范围的雾化 9.3.2 像素雾化和与眼相关深度雾化 9.4 为场景添加雾化效果 9.4.1 顶点雾化示例程序   9.4.2 像素雾化示例程序   9.4.3 基于范围的雾化示例程序   9.5 对雾化效果的几点说明 9.6 小结 第10章 字体与文本显示 10.1 二维文本绘制 10.2 三维文本绘制 10.3 小结 第二部分 高级技术篇 第11章 应用程序框架 11.1 生成一个direct3d程序框架 11.2 使用direct3d程序框架 11.3 direct3d程序框架剖析 11.3.1 dxut简介 11.3.2 初始化dxut 11.3.3 dxut框架与应用程序窗口 11.3.4 dxut框架与direct3d设备 11.3.5 dxut框架与消息循环 11.3.6 dxut框架与错误处理 11.3.7 通过dxut选择高级设备 11.3.8 其他dxut函数 11.4 添加文本 11.4.1 初始化id3dxsprite和id3dxfont对象 11.4.2 绘制文本 11.4.3 处理键盘消息 11.5 添加控件 11.5.1 初始化对话框 11.5.2 渲染控件 11.5.3 处理控件消息 11.5.4 释放对话框 11.6 小结 第12章 高级纹理技术 12.1 多层纹理映射 12.2 纹理阶段混合操作 12.2.1 黑暗映射 12.2.2 黑暗贴图动画 12.2.3 混合纹理与材质漫反射颜色 12.2.4 混合黑暗贴图与材质漫反射颜色 12.2.5 发光映射 12.2.6 细节映射 12.2.7 alpha混合操作 12.3 纹理坐标处理 12.3.1 纹理坐标自动生成 12.3.2 纹理坐标变换 12.4 环境纹理映射 12.4.1 立方体环境映射 12.4.2 球形环境映射 12.5 凹凸纹理映射 12.6 立体纹理 12.7 纹理压缩 12.7.1 dxt纹理压缩格式 12.7.2 使用dxt压缩纹理 12.8 纹理管理 12.9 小结 第13章 网格模型高级技术 13.1 .x文件格式分析 13.1.1 首部 13.1.2 网格 13.1.3 网格材质列表 13.1.4 法向量   13.1.5 纹理 13.1.6 框架和变换矩阵 13.1.7 动画 13.1.8 蒙皮信息 13.2 网格模型优化 13.2.1 网格模型优化函数 13.2.2 网格模型优化方式 13.2.3 示例程序optimizedmesh具体实现 13.3 层次细节网格模型 13.3.1 生成层次细节网格模型前的准备工作 13.3.2 生成层次细节模型 13.3.3 示例程序progressmesh的具体实现 13.4 增强网格模型 13.4.1 增强网格模型的生成 13.4.2 示例程序enhancedmesh的具体实现 13.5 渐变网格模型 13.5.1 实现渐变网格模型的准备工作 13.5.2 生成渐变网格模型 13.5.3 渲染渐变网格模型 13.6 dxut网格模型类 13.6.1 cdxutmesh类 13.6.2 cdxutmeshframe类和cdxutmeshfile类 13.6.3 使用类cdxutmesh和cdxutmeshfile渲染网格模型 13.7 骨骼动画网格模型 13.7.1 骨骼动画基本原理 13.7.2 骨骼动画类的设计与实现  13.7.3 骨骼动画类的使用 13.8 蒙皮骨骼动画网格模型 13.8.1 图形混合 13.8.2 索引顶点混合 13.8.3 顶点混合示例 13.8.4 蒙皮骨骼动画网格模型类的设计与实现 13.8.5 蒙皮骨骼动画网格模型类的使用 13.9 多骨骼动画网格模型 13.10 其他文件格式模型 13.11 小结 第14章 模板测试与模板缓冲区 14.1 模板测试 14.2 模板缓冲区 14.3 模板测试设置 14.4 使用模板测试实现特殊效果 14.5 实时阴影效果 14.6 小结 第15章 粒子系统 15.1 粒子系统技术简介 15.2 粒子系统基本原理 15.3 点精灵(point sprites) 15.4 粒子系统具体实现 15.5 综合开发实例 15.6 小结 第三部分 gpu编程篇 第16章 direct3d gpu编程概述 16.1 可编程流水线 16.2 顶点渲染 16.3 像素渲染 16.4 渲染语言 16.5 小结 第17章 高级渲染语言基础 17.1 数据类型 17.1.1 标准数据类型 17.1.2 向量   17.1.3 矩阵 17.1.4 复杂数据类型 17.2 表达式与运算符 17.3 语句 17.3.1 语句块 17.3.2 返回语句 17.3.3 流程控制语句 17.4 函数 17.5 段落 17.5.1 渲染器段落基本概念 17.5.2 渲染器段落语法 17.6 编写hlsl渲染器 17.6.1 添加文件 17.6.2 编写渲染器代码 17.7 小结 第18章 hlsl顶点渲染 18.1 hlsl顶点渲染基本步骤 18.2 使用hlsl顶点渲染实现基本光照模型 18.2.1 环境光光照模型 18.2.2 漫反射光照模型 18.2.3 镜面反射光照模型 18.3 小结 第19章 hlsl像素渲染 19.1 hlsl像素渲染基本步骤 19.2 使用hlsl实现基本纹理映射 19.3 渲染器的编译与调试 19.3.1 渲染器的编译 19.3.2 渲染器的调试 19.4 小结 第20章 效果(effect) 20.1 效果、技术与通道 20.1.1 效果和direct3d流水线 20.1.2 保存和恢复状态 20.1.3 共享参数 20.2 编写效果 20.3 使用效果 20.4 效果示例程序   20.4.1 光照计算 20.4.2 纹理映射 20.4.3 多技术效果 20.4.4 参数块与共享参数 20.5 建立并渲染段落 20.5.1 从效果中建立并渲染段落 20.5.2 不通过效果建立并渲染段落 20.5.3 段落使用示例程序   20.6 小结 第21章 hlsl高级应用 21.1 自身遮蔽阴影 21.2 凹凸纹理映射 21.3 立方体环境映射 21.3.1 立方体贴图  21.3.2 反射环境映射 21.3.3 折射/反射环境映射 21.3.4 动态折射/反射环境映射 21.4 渐变动画  21.5 蒙皮骨骼动画 21.6 小结 第22章 asm顶点渲染 22.1 asm顶点渲染基本步骤 22.2 顶点声明对象 22.3 asm顶点渲染简介 22.3.1 顶点渲染版本声明 22.3.2 顶点渲染寄存器 22.3.3 顶点渲染指令 22.4 asm顶点渲染示例 22.4.1 光照计算 22.4.2 渐变动画 22.4.3 蒙皮骨骼动画 22.5 小结 第23章 asm像素渲染 23.1 asm像素渲染基本步骤 23.2 asm像素渲染简介 23.2.1 版本声明 23.2.2 像素渲染寄存器 23.2.3 像素渲染指令 23.3 asm像素渲染示例 23.4 使用效果 23.4.1 asm效果 23.4.2 利用效果实现hlsl和asm混合编程 23.5 小结 第四部分 实用技术篇 第24章 dxut控件 24.1 dxut控件介绍 24.2 dxut控件使用示例程序   24.3 小结 第25章 广告板技术与十字交叉纹理 25.1 广告板技术 25.1.1 广告板技术介绍 25.1.2 广告板技术示例程序   25.2 十字交叉纹理 25.2.1 十字交叉纹理介绍 25.2.2 十字交叉纹理示例程序   25.3 小结 第26章 纹理动画 26.1 纹理动画原理 26.2 纹理动画示例程序   26.3 小结 第27章 自然现象模拟 27.1 动态云彩效果模拟 27.2 雨景效果模拟 27.3 雪景效果模拟 27.4 小结 第28章 三维地形模拟 28.1 三维地形模拟概述 28.2 三维地形模拟示例程序   28.3 小结 第29章 海浪效果模拟 29.1 使用纹理贴图实现海浪效果 29.2 实时生成海浪效果 29.3 小结 第30章 柔性物体模拟 30.1 柔性物体模拟介绍 30.2 粒子系统和弹簧结构 30.3 定义并实现cflutterflag类 30.4 示例程序的具体实现 30.5 小结 第31章 三维场景交互 31.1 使用鼠标选择三维场景中的物体 31.2 使用鼠标控制三维场景中角色的运动 31.3 小结 第32章 运动模糊效果 32.1 运动模糊效果的基本原理 32.2 示例程序motionblur 32.3 小结 第33章 凹凸纹理映射应用 33.1 水下效果模拟 33.2 水波效果模拟 33.3 小结 第34章 短毛发实时绘制 第35章 体积雾 第五部分 附录 附录a c++基础知识 a.1 类及其成员和封装 a.2 继承 a.3 this指针 a.4 虚函数、动态绑定和多态 a.5 双指针 a.6 内联函数 a.7 默认函数参数 a.8 声明变量的位置 a.9 const常量表达式   a.10 函数重载 a.11 运算符重载 附录b win32 api程序设计基础 b.1 api和sdk b.2 win32程序框架 b.3 win32 api程序框架分析 附录c com使用基础 c.1 什么是com对象 c.2 创建一个com对象 c.3 使用com接口 c.4 管理com对象的生命期 c.5 使用c访问com对象 c.6 用宏调用directx com方法 附录d 计算机图形学数学基础 d.1 坐标参照系 d.2 点与向量   d.3 矩阵 d.4 四元数 附录e 计算机图形学基础 e.1 概述 e.1.1 计算机图形学的概念 e.1.2 计算机图形学的研究内容 e.2 图形系统与图形设备 e.2.1 图形系统 e.2.2 图形设备 e.3 图形变换 e.3.1 图形的几何变换 e.3.2 形体的投影变换 e.3.3 裁剪 e.3.4 窗口到视口的变换 附录f directx sdk提供的各种工具使用说明 f.1 directx浏览器 f.2 纹理转换工具 f.3 directx纹理工具 f.4 directx性能浏览工具 f.5 directx错误查询工具 f.6 directx诊断工具 f.7 directx ops(dxops.exe)
零资源分下载,分享精神至上~ 3.0版新加入三维天空模拟系统。 其中的3D人物模型使用的是真三国无双6中的一个女角色。 背景音乐为仙剑奇侠传3主题曲。 一个综合型的Direct3D示例程序的3.0版。 用键盘上W,A,S,D,I,J,K,L,↑,↓,←,→12个键加上鼠标在美丽的三维空间中翱翔。包括了Direct3D初始化,DirectInput输入处理,顶点缓存,光照与材质,文字输出,颜色,纹理贴图,四大变换,网格模型,X文件载入等等知识(当然还有默认被开启的深度缓存),地形系统模拟,三维天空模拟。 源码的配套博文是 《【Visual C++】游戏开发四十九 浅墨DirectX教程十七 三维天空的实现》 ,文章地址为http://blog.csdn.net/zhmxy555/article/details/8715196, 点击Release文件夹下的exe文件可以直接看到运行效果,运行需要DirectX运行库的支持。报缺少D3D的DLL系列错误的童鞋们请google/百度一下 “DirectX 9.0c runtime”,下载并装个最新版的。 报缺少MVCR100D.Dll错误的朋友们去下一个安装就可以了,或者直接点击sln打开工程再次编译一次。 如果是想调试并运行源代码,但是报错了,请去下载最新版DirectX SDK并进行DirectX开发环境的配置。 编写环境:VS2010 我的博客地址是http://blog.csdn.net/zhmxy555,源码结合配套文章一起看效果更佳。 希望能和大家一起交流,共同学习,共同进步。
零资源分下载,分享精神至上~ 一个综合型的Direct3D示例程序,用键盘上W,A,S,D,I,J,K,L,↑,↓,←,→12个键加上鼠标在美丽的三维空间中翱翔。包括了Direct3D初始化,DirectInput输入处理,顶点缓存,光照与材质,文字输出,颜色,纹理贴图,四大变换,网格模型,X文件载入等等知识(当然还有默认被开启的深度缓存)。 其中的3D人物模型使用的是PS3版《真三国无双6》中的王元姬 ,一袭蓝衣,很美。 背景音乐为雅尼的《兰花》。 源码的配套博文是 《【Visual C++】游戏开发笔记四十七 浅墨DirectX教程十五 翱翔于三维世界:摄像机的实现》 ,文章地址为http://blog.csdn.net/zhmxy555/article/details/8657656, 点击Debug下的exe文件可以直接看到运行效果,运行需要DirectX运行库的支持。报缺少D3D的DLL系列错误的童鞋们请google/百度一下 “DirectX 9.0c runtime”,下载并装个最新版的。 报缺少MVCR100D.Dll错误的朋友们去下一个安装就可以了,或者直接点击sln打开工程再次编译一次。 如果是想调试并运行源代码,但是报错了,请去下载最新版DirectX SDK并进行DirectX开发环境的配置。 编写环境:VS2010 我的博客地址是http://blog.csdn.net/zhmxy555,源码结合配套文章一起看效果更佳。 希望能和大家一起交流,共同学习,共同进步。 by浅墨

8,325

社区成员

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

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