游戏引擎—伪阴影在Cocos2d-x中的实现.docVIP

游戏引擎—伪阴影在Cocos2d-x中的实现.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
cocos引擎—伪阴影在Cocos2d-x中的实现 本文检索关键词:游戏引擎,游戏开发引擎,cocos引擎html5游戏开发 概要: 这篇教程里,我们会简单的介绍一下两种基本的伪阴影的概念,以及在Cocos2d-x中的实现方法。 何谓伪阴影: 在游戏过程中,我们通常会是用阴影来增强视觉效果的真实度,在这里,我们讨论伪阴影的计算方法,所谓的伪阴影,是指根据指定的空间位置的模型生成一个简单的阴影,这个阴影的形状——或者说轮廓与被生成阴影的模型的真实样子并无映射关系。这种影子虽然看起来简单,但是在某些场合也会非常的有用,比方说在一个光源在比较远和比较高的角度,光线比较充足的场景里。比方说,在艳阳高照的足球场上,球员脚底的阴影就是一团模糊不清的圆环状,伪阴影与模型无关,有实现简单,计算效率高等,所以在一些开阔明亮的场景里通常会使用。 通过距离计算的方式: 我们先说一种非常简单的方式。首先,我们获取到玩家角色的位置,然后将制定的地面的每一像素点的位置与玩家角色位置的距离作比较,当小于一个制定的范围的阈值的时候,就将该点涂黑。 实现 现在我们来描述一下如何具体的实现这个方式,首先我们读入一个地面,并自定义自己的shader,并将这个地面的所有顶点的属性属性,存入这个shader的state中: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 auto?plane?=?Sprite3D::create(plane.c3b); plane-setRotation3D(Vec3(90,0,0)); auto?shader?=GLProgram::createWithFilenames(simple_shadow.vert,simple_shadow.frag); auto?state?=?GLProgramState::create(shader); plane-setGLProgramState(state); //pass?meshs?attribute?to?shader long?offset?=?0;? auto?attributeCount?=?plane-getMesh()-getMeshVertexAttribCount(); for?(auto?i?=?0;?i??attributeCount;?i++)?{ ????????auto?meshattribute?=?plane-getMesh()-getMeshVertexAttribute(i); ????????state-setVertexAttribPointer(s_attributeNames[meshattribute.vertexAttrib], ????????????meshattribute.size,? ????????????meshattribute.type, ????????????GL_FALSE, ????????????plane-getMesh()-getVertexSizeInBytes(), ????????????(GLvoid*)offset); ????????offset?+=?meshattribute.attribSizeBytes; } 接着我们要将角色的坐标传入这个shader: 1 plane-getGLProgramState()-setUniformVec3(u_target_pos,orc-getPosition3D()); 目前我们无法获得平面在世界坐标系下的位置,我们将地面的模型变换的矩阵传入shader内 1 state-setUniformMat4(u_model_matrix,plane-getNodeToWorldTransform()); 这样前期的准备工作就已经做好了,接下来,我们来看一下shader内部是如何处理的,首先我们看一看顶点着色器部分: 1 2 3 4 5 6 7 8 9 10 11 12 attribute?vec4?a_position; attribute?vec2?a_texCoord; uniform?mat4?u_model_matrix; varying?vec2?TextureCoordOut; varying?vec4?v_position; void?main(void) { ????gl_Position?=??CC_PMatrix??*?CC_MVMatrix?*?a_position; ????TextureCoordOut?=?a_texCoord; ????TextureCoordOut.y?=?(1.0?-?TextureCoordOut.y); v_position?=?u_model_matr

您可能关注的文档

文档评论(0)

xjdo758 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档