【转载】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,比较 ...
随机推荐
- mongodb存储引擎
存储引擎(Storage Engine)是MongoDB的核心组件,负责管理数据如何存储在硬盘(Disk)和内存(Memory)上.从MongoDB 3.2 版本开始,MongoDB 支持多数据存储引 ...
- 铁乐学python_Day43_协程
铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...
- Asp.Net网站的的编译与发布原理
如下所示创建一个简单的asp.Net Web应用程序 在VS中生成解决方案之后,可以在项目的目录下看到以下的文件: ...
- java+redis+lua生成自动增长的ID序列号
1.编写lua脚本用于生成主键ID序列号,内容如下 local key = tostring(KEYS[1]); local count = tonumber(KEYS[2]); local date ...
- codeforces 348D Turtles
codeforces 348D Turtles 题意 题解 代码 #include<bits/stdc++.h> using namespace std; #define fi first ...
- 张高兴的 Windows 10 IoT 开发笔记:无线收发芯片 nRF24L01
This is a Windows 10 IoT Core project on the Raspberry Pi 2/3, coded by C#. GitHub:https://github.co ...
- Geeks : Kruskal’s Minimum Spanning Tree Algorithm 最小生成树
版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/.未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...
- 2016-3-19日小结:scrollTop
<div id="div1" style="padding: 0; position:absolute;width: 200px;height: 200px;< ...
- 2743: [HEOI2012]采花
Description 萧芸斓是Z国的公主,平时的一大爱好是采花.今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花 .花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一 ...
- redis key全量导出与导出指定前缀的key
redis命令列表中有两种方法可以全量导出所有的key: (1)keys 由于redis是单线程的,使用keys会导致redis服务阻塞,不建议线上服务采用这种方式. (2)scan 命令,下面是使用 ...