【转载】D3D中的Texture应用示例
本文列举了Direct3D中各种纹理应用实现:黑暗贴图,发光贴图,漫反射映射贴图,细节纹理,纹理混合,有较详尽的注解。其中黑暗贴图,发光贴图,细节纹理都是采用多重纹理的方法实现(也可以采用多次渲染混合实现)。
示例代码使用Beginning direct3D game programming中的框架,省去不少事情,可以专注纹理话题。代码:点此下载
下面来看代码与效果:
正常的纹理贴图效果:
正常的纹理贴图代码:
//基本纹理2
void drawNormalTexture()3
{4
// 设置box纹理贴图5
Device->SetTexture(0, texBox);6
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0); //使用纹理坐标7
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质8
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出9

10
// 描绘box11
Box->draw(0, 0, 0);12
}黑暗纹理贴图效果:
黑暗纹理贴图代码:
//黑暗映射纹理2
void drawDarkMapTexture()3
{4
// Multi texture:多重纹理,此处为两重纹理5
// finalColor = destPixelColor * sourcePixelColor6
// 设置box纹理贴图7
Device->SetTexture(0, texBox);8
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);9
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质10
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出11

12
// 设置黑暗纹理贴图13
Device->SetTexture(1, texAlpha);14
Device->SetTextureStageState(1, D3DTSS_TEXCOORDINDEX, 0);15
Device->SetTextureStageState(1, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质16
Device->SetTextureStageState(1, D3DTSS_COLORARG2, D3DTA_CURRENT); // 颜色来源-前一个texture stage17
Device->SetTextureStageState(1, D3DTSS_COLOROP, D3DTOP_MODULATE); // 颜色混合:相乘18

19
// 描绘box20
Box->draw(0, 0, 0);21
}漫反射映射贴图效果:夜光镜效果
漫反射映射贴图代码:
//漫射光映射纹理2
void drawDiffuseTexture()3
{4
// 设置box纹理贴图5
Device->SetTexture(0, texBox);6
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);7
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质8
Device->SetTextureStageState(0, D3DTSS_COLORARG2, D3DTA_DIFFUSE); // 颜色来源-漫反射9
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_MODULATE); // 颜色混合10

11
// 设置材质:绿色材质实现类似夜光镜的效果12
Device->SetMaterial(&d3d::GREEN_MTRL);13

14
// 描绘box15
Box->draw(0, 0, 0);16
}发光映射纹理贴图效果:
发光映射纹理贴图代码:
//发光映射纹理2
void drawGlowMapTexture()3
{4
// Multi texture:多重纹理,此处为两重纹理5
// finalColor = sourcePixelColor * 1.0 + destPixelColor * 1.06
// 设置box纹理贴图7
Device->SetTexture(0, texBox);8
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);9
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质10
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出11

12
// 设置黑暗纹理贴图13
Device->SetTexture(1, texAlpha);14
Device->SetTextureStageState(1, D3DTSS_TEXCOORDINDEX, 0);15
Device->SetTextureStageState(1, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质16
Device->SetTextureStageState(1, D3DTSS_COLORARG2, D3DTA_CURRENT); // 颜色来源-前一个texture stage17
Device->SetTextureStageState(1, D3DTSS_COLOROP, D3DTOP_ADD); // 颜色混合:相加18

19
// 描绘box20
Box->draw(0, 0, 0);21
}细节映射纹理贴图:实现粗糙的凹凸效果
细节映射纹理贴图代码:
//细节映射纹理:实现凹凸效果2
void drawDetailMapTexture()3
{4
// Multi texture:多重纹理,此处为两重纹理5
// finalColor = sourcePixelColor * destPixelColor + destPixelColor * sourcePixelColor6
// 设置box纹理贴图7
Device->SetTexture(0, texBox);8
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);9
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质10
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出11

12
// 设置细节纹理贴图13
Device->SetTexture(1, texDetail);14
Device->SetTextureStageState(1, D3DTSS_TEXCOORDINDEX, 0);15
Device->SetTextureStageState(1, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质16
Device->SetTextureStageState(1, D3DTSS_COLORARG2, D3DTA_CURRENT); // 颜色来源-前一个渲染通道17
Device->SetTextureStageState(1, D3DTSS_COLOROP, D3DTOP_ADDSIGNED); // 颜色混合18

19
// 描绘box20
Box->draw(0, 0, 0);21
}alpha纹理混合效果:多次渲染实现
alph纹理混合代码:
//alpha混合纹理2
void drawAlphaBlendTexture()3
{4
// 多次渲染实现纹理混合5
// finalColor = sourcePixelColor * sourceBlendFactor + destPixelColor * destBlendFactor6
// 设置纹理混合参数7
Device->SetTextureStageState(0, D3DTSS_ALPHAARG1, D3DTA_TEXTURE); // alpha值来自纹理8
Device->SetTextureStageState(0, D3DTSS_ALPHAOP, D3DTOP_SELECTARG1);9

10
// 设置混合因子实现透明效果11
Device->SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);12
Device->SetRenderState(D3DRS_DESTBLEND, D3DBLEND_INVSRCALPHA);13

14
//使用box纹理贴图实现第一次渲染,无alpha混合15
Device->SetTexture(0, texBox);16
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);17
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质18
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出19

20
// 第一次描绘box21
Box->draw(&boxWorldMatrix, 0, 0);22

23
//使用带alpha值得flower纹理贴图实现第二次渲染,有alpha混合24
Device->SetTexture(0, texAlphaFlower);25
Device->SetTextureStageState(0, D3DTSS_TEXCOORDINDEX, 0);26
Device->SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_TEXTURE); // 颜色来源-材质27
Device->SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1); // 使用当前颜色作为第一个texture stage的输出28

29
// 打开纹理混合30
Device->SetRenderState(D3DRS_ALPHABLENDENABLE, true);31

32
// 第一次描绘box33
Box->draw(&boxWorldMatrix, 0, 0);34

35
// 关闭纹理混合36
Device->SetRenderState(D3DRS_ALPHABLENDENABLE, false);37
}【转载】D3D中的Texture应用示例的更多相关文章
- [ZZ] D3D中的模板缓存(3)
http://www.cppblog.com/lovedday/archive/2008/03/25/45334.html http://www.cppblog.com/lovedday/ D3D中的 ...
- XCode和Cocoa在开发中使用第三方dylib示例
XCode和Cocoa在开发中使用第三方dylib示例 www.educity.cn 发布者:yukowang 来源:网络转载 发布日期:2014年06月13日 XCode和Co ...
- jQuery中$.fn的用法示例介绍
$.fn是指jquery的命名空间,加上fn上的方法及属性,会对jquery实例每一个有效,下面有个不错的示例,喜欢的朋友可以参考下 如扩展$.fn.abc(),即$.fn.abc()是对jquery ...
- demo工程的清单文件及activity中api代码简单示例
第一步注册一个账户,并创建一个应用.获取app ID与 app Key. 第二步下载sdk 第三步新建工程,修改清单文件,导入相关的sdk文件及调用相应的api搞定. 3.1 修改清单文件,主要是加入 ...
- [转]Linux中find常见用法示例
Linux中find常见用法示例[转]·find path -option [ -print ] [ -exec -ok command ] {} \;find命令的参 ...
- wpf将表中数据显示到datagrid示例(转)
原文:http://www.jb51.net/article/47120.htm 这篇文章主要介绍了wpf将表中数据显示到datagrid示例,需要的朋友可以参考下 a.在.xaml文件中拖入一个da ...
- oracle中to_date详细用法示例(oracle日期格式转换)
这篇文章主要介绍了oracle中to_date详细用法示例,包括期和字符转换函数用法.字符串和时间互转.求某天是星期几.两个日期间的天数.月份差等用法 TO_DATE格式(以时间:2007-11-02 ...
- vue不通过路由直接获取url中参数的方法示例
vue不通过路由直接获取url中参数的方法示例 vuejs取得URL中参数的值地址:http://localhost:3333/#/index?id=128console.log(this.$rout ...
- Python的collections模块中namedtuple结构使用示例
namedtuple顾名思义,就是名字+元组的数据结构,下面就来看一下Python的collections模块中namedtuple结构使用示例 namedtuple 就是命名的 tuple,比较 ...
随机推荐
- Oracle EBS 应收API只创建收款没有核销行以及消息堆栈
只创建了收款但没有创建核销行 排除其他原因 有可能是缓存溢出导致的这个要改成true 且使用消息堆栈处理
- 判断js对象类型
javascript中检测对象的类型的运算符有:typeof.constructor.instanceof.prototype. 1.typeof typeof是一个一元运算符,返回结果是一个说明运算 ...
- 使用jqGrid过程中出现的问题
在使用jqGrid过程中,需要后台查询数据添加到表格中,在js中循环调用addRowData方法时出现浏览器崩溃现象. 原因:jqGrid的addRowData方法中做了一系列的处理,在后台返回数据量 ...
- 使用UISearchDisplayController
使用UISearchDisplayController 虽然UISearchDisplayController名字中带有controller,可他不是一个UIView相关的controller,因为, ...
- Linux通过docker安装运行酷Q--用QQ骰子君进行跑团
Linux通过docker安装运行酷Q 文:铁乐与猫 需求:和小伙伴周末进行愉快的TRPG跑团,需要在QQ讨论组上加了qq小号后,将qq小号用酷Q配合投骰的应用变成骰子君. 限制:我个人的云计算服务器 ...
- 获取 docker 容器(container)的 ip 地址
获取单个IP docker inspect --format '{{ .NetworkSettings.IPAddress }}' <container-ID> 获取所有容器IP doc ...
- 11g数据库查看dataguard是否同步
一.环境 主库: ip地址:192.168.122.203 oracle根目录:/data/db/oracle SID:qyq 数据文件路径/ ...
- [EffectiveC++]item46:需要类型转换时请为模板定义非成员函数
- ZT 计算一个无符整数中1Bit的个数(1) 2010-04-20 10:52:48
计算一个无符整数中1Bit的个数(1) 2010-04-20 10:52:48 分类: C/C++ [转]计算一个无符整数中1Bit的个数(1) Count the number of bits ...
- HTML5的新标签-整体布局
过去:<div class="header"> <div class="hgroup"> <h1>....</h1&g ...