cocos2d-x实现透明背景

cocos2d-x使用一个专门的OpenGL View进行渲染, 它的渲染和UIKit是分开进行的, 因此我们使用时一般是把cocos2d-x全屏显示, 比如 Ray的这篇教程(http://www.raywenderlich.com/4817/how-to-integrate-cocos2d-and-uikit) (cocos2d-x和cocos2d在本篇文章中没有本质区别)

如果我们把cocos2d作为一个子view插进来时, cocos2d的scene如果不加任何东西, 就会是黑色的一个矩形, 无法做成透明效果. 即使把OpenGL View的background color 设成 clearColor 也没用. cocos2d到底能不能变得透明?

通过bing艰难的找到这篇自问自答, http://stackoverflow.com/questions/12846744/cocos2d-opengl-es-becoming-transparent-over-uiview, 虽然只有一个赞, 但确实是网上唯一一个能够解决该问题的回答. 必须记录下来以飨后人.

解决方案

1. opengl view初始化时一定要选择 kEAGLColorFormatRGBA8 像素模式, 这样才能够支持透明.

[CCEAGLView viewWithFrame: CGRectMake(0, 0, winHeight, winWidth)

          pixelFormat: kEAGLColorFormatRGBA8

          depthFormat: GL_DEPTH24_STENCIL8_OES

   preserveBackbuffer: NO

           sharegroup: nil

        multiSampling: NO

      numberOfSamples: 0];

2. opengl view要启用透明模式, 有一个 opaque 属性, 默认为YES, 表示会自动把覆盖区域的内容遮挡住, 这是为了优化渲染快速裁切, 我们要把它设成 NO.

glClearColor(0, 0, 0, 0);

_cocosView.backgroundColor = [UIColor clearColor];

_cocosView.opaque = NO;

3. cocos2d-x的clear color要设置为(0, 0, 0, 0). 这个值是opengl在开始渲染每一帧时, 给每个像素设置的默认值. 因为cocos2d-x和UIKit的渲染是在不同opengl管线里实现的, 因为cocos2d-x会把UIKit渲染的内容替换到, 表现出来就是黑屏.

这个需要修改cocos2d-x的源代码, 在 CCDirector.cppvoid Director::setGLDefaultValues() 中, 把clear color值改一下就可以了.

使用以上三步操作, 我们就可以现在透明的cocos2d-x界面, 遮罩在UIKit上方.

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前言 我选择开发一个游戏有很多原因。我觉得自己是“核心”玩家,过去的大部分时间我都花在玩游戏,自己制作、阅读和游戏...
    月影檀香阅读 14,199评论 1 27
  • 游戏开发技术 游戏原理与机制 游戏开发技术 认识Cocos2D-X 游戏原理与机制 渲染驱动 事件驱动 渲染驱动游...
    JunChow520阅读 5,189评论 0 0
  • 游戏开发中,有了坐标系才有了整个世界,坐标系是游戏世界的标尺,让游戏元素正确有序得显示在屏幕上而不会分崩离析。 标...
    JunChow520阅读 5,933评论 0 3
  • 精灵就是将图形资源加载到内存中,并根据游戏需要将其显示到屏幕中的工具,继承自CCNode,CCSprite除了节点...
    白小白152阅读 4,734评论 0 1
  • Cocos2d-x是一个开源的移动2D游戏框架,MIT许可证下发布的。这是一个C++ Cocos2d-iPhone...
    黄花菜已凉阅读 4,814评论 1 3

友情链接更多精彩内容