码迷,mamicode.com
首页 > 其他好文 > 详细

【Stage3D学习笔记续】真正的3D世界(三):纹理效果

时间:2014-11-28 15:45:45      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   io   ar   color   os   使用   sp   

混合模式:

代码

示例是《Stage3D指南》中的直接弄出来的,可以通过点击键盘上的Q、W、E这3个按键,更换混合模式、模型和纹理,可以直观的查看不同混合模式的效果,住:下方的地形使用"context3D.setBlendFactors(Context3DBlendFactor.ONE, Context3DBlendFactor.ZERO);"正常混合模式渲染,上方中心的模型使用特定的混合模式渲染。

 

深度测试(Z-Buffer):

使用Z-Buffer的话,GPU会把每个像素都设置到一个叫做深度缓冲的地方,最终会绘制到屏幕的像素是距离屏幕最近的像素,而不使用Z-Buffer的话,GPU会使用画家算法进行绘制,即后绘制的图像会覆盖先绘制的图像。

下面我们修改一下上面的例子来测试一下:

代码

首先我们之前的例子是先绘制地形再绘制上面的模型的,这样的话我们是否使用深度测试其实是看不出区别的,因为模型就是在地形的上方,所以我们需要将两个绘制顺序进行颠倒。

点击“R”键切换是否使用深度测试。如果不使用深度测试,那么模型是先绘制,地形是后绘制,所以模型位于地形的后方,使用深度测试则会判断像素距离屏幕的距离,最终呈现距离最近的像素,所以模型又回到上方了。

另外我们使用深度测试时,会发现混合模式好像出现了问题,全是黑色的方块!其实混合模式没有出现问题,而是我们的模型先绘制,所以混合颜色时缓冲中并没有颜色可以进行混合(如果先绘制地形,则会和地形的颜色混合),所以就出现了这个问题。

 

背面剔除:

用于提升渲染速度,开启后,看不见的一面不会进行绘制。

1 context3D.setCulling(Context3DTriangleFace.NNONE);


增加性能:

  • 不透明的纹理绘制得更快;
  • 尽量避免重复绘制;
  • 尽量避免状态改变;
  • 使用更加简单的着色器;
  • 绘制更少的网格;

【Stage3D学习笔记续】真正的3D世界(三):纹理效果

标签:style   blog   http   io   ar   color   os   使用   sp   

原文地址:http://www.cnblogs.com/hammerc/p/4128455.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!