火炬之光中人物被遮挡效果在Ogre中的实现方法

《火炬之光》貌似是最近挺惹人注目的游戏了。我所高兴的是这个游戏是Ogre做的,那么按老外的习惯,里面的模型材质纹理等都是暴露的了。下了一个果不其然。不过真正让我注目的是,这款游戏确实挺不错,一个非商业图形引擎能做成这样是很不错的了,其中我关注到了这样一个效果:

火炬之光 

即人物被遮挡后的透视效果。

想了很久不知道如何下手,天一给我发了个博客,立马茅塞顿开。

http://blog.csdn.net/xoyojank/archive/2009/11/09/4791555.aspx

引用这篇文章的步骤:

1. 先画场景

2. 画被遮挡的部分, ZWrite=False; ZFunc=Greater; 开启Alpha混合, 光照亮度做为alpha值输出, 颜色由参数传入.

3. 还原正常的渲染状态, 绘制原模型(为了显示未被遮挡的部分)

 

在Ogre中实现也是不难的。

在材质的通道里加上两行设置就可以实现透视效果,再用正常材质绘制一次模型即可。

我改了下1.6SDK Sample里的DemoTransparency项目,代码如下

 

      

[cpp]   view plain copy
  1. //创建要遮挡的"墙",在这里就用一个平面代替  
  2.         Entity *planeEnt = mSceneMgr->createEntity("Plane", SceneManager::PT_PLANE);  
  3.        //设置平面的材质  
  4.         planeEnt->setMaterialName("Examples/RustySteel");  
  5.    
  6.   //创建透视模型  
  7.         Entity* entityMask = mSceneMgr->createEntity("entityMask""OgreHead.mesh");  
  8.         entityMask->setMaterialName("Examples/TransparentTest");  
  9.   //创建正常模型  
  10.   Entity* entity = mSceneMgr->createEntity("normalEntity""OgreHead.mesh");  
  11.     
  12.   //将这3个物体附着到场景节点上  
  13.         SceneNode* rootNode = mSceneMgr->getRootSceneNode();  
  14.         rootNode->attachObject(planeEnt);  
  15.         rootNode->attachObject(entityMask);  
  16.    SceneNode* node = rootNode->createChildSceneNode();  
  17.    node->attachObject(entity);   

 

这些都是基本代码,主要是"Examples/TransparentTest"这个材质

我修改了Ogre自带的这个材质,代码如下

material Examples/TransparentTest
{
  technique
  {
    pass
    {
      ambient 0.2 0.2 0.2
      scene_blend add

 

      //重点是这两行
      depth_write off       //使像素不更新深度缓冲
      depth_func greater       //检测深度值的函数,greater参数即将要写入

                         //的像素的深度大于现在缓冲区内容的深度,则写入

                           //通俗来说就是只显示被遮盖的部分

                         //使用这条设置的前提是深度检测是打开的,即depth_check on
                         //不过它默认就是这样的,所以再次就不用再写一次了

 

      //下面的两个纹理单元起的效果是旋转的材质效果,不是本文重点

      //需要研究可参看Ogre手册

      texture_unit
      {
        texture Water01.jpg
        scroll_anim 0.25 0  

      }

      texture_unit
      {
        texture Water01.jpg
        wave_xform scroll_y sine 0 0.1 0 0.5
      }
    }

  }
}

 

最终效果如下

最终效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值