CreatorPrimer|2.x的渲染初探

Shawn之前只是从感性的一面了Cocos Creator 2.0在性能更好,增加部分3D效果的支持,同时API有一些变化。随着对Cocos Creator 2.x的实践,以及引擎组大神们的指导,对Cocos Creator 1.x和2.x有了新的了解和认识,在此将这次学习内容与大家分享。

1. 1.x与2.x的渲染区别

Cocos Creator 1.x 是在cocos2d-js基础上增加了组件与可视化编辑器,但随着引擎不断迭代与进化,之前cocos2d-js的渲染设计制约了引擎的发展,新版本需要丢下原有的包袱,轻装上阵。

渲染树对比

通过下面的一些图我们对比一下1.x与2.x在渲染上的区别:

1.x的逻辑树与渲染树

从上图可以看到,引擎中维护了一颗场景逻辑树(左边),需要时刻与渲染树(右边)进行数据同步。sgNode仅仅是为了同步Node的所有transform信息和渲染组件的状态信息,这造成了巨大的浪费。

2.x中的节点树

在2.x使用了全新的设计,引擎内部只有一颗逻辑树,场景下包含节点,节点下挂载有渲染组件,简单清晰。因此在2.x中节点与组件对象中,不再有_sgNode这个变量了,使用时需要注意。

渲染流程

我们通过节点的transform为例对比1.x与2.x的渲染流程,请看下图:

1.x渲染流程
  1. 检查节点颜色是否dirty(变脏),如果是生成Color更指令
  2. 检查 Transform(几何属性变换)是否dirty,如果是生成更新Transform指令
  3. 通过dirty检查是否需要重新渲染,是则生成渲染指令压入渲染队列
  4. 检查是否存在子节点,如果存在,则对子节点进行相同渲染流程的检测
  5. Render渲染器按队列顺序执行渲染指令
2.x渲染流程

2.x在渲染流程上预先建立了所有情况的渲染通道,看上图中:transform、render、render&transform、render&transform&children。

通过节点的渲染标志直接进入某条渲染通道,有效减少动态判断带来的性能损耗。

按Shawn的理解是将在原来的条件判断,进化成了直接查表,据引擎组大神讲预先建立的各种情况的渲染组合有100多种之多。

渲染框架

我们再从整体上看一下2.0的渲染框架,请看下图:

2.0渲染框架
  1. Assembler(组装器)获取组件、节点数据生成RenderData(渲染数据),渲染数据会按有效批次提交形成Model
  2. Model渲染数据包含两部分:顶点数据(VertexBuffer、IndexBuffer)和表现(Effect),记得前面介绍过2.0材质系统,核心就是Effect了。
  3. 2.0增加了新的3D Render(3D渲染器),在外表现为Camera(摄像机)的使用,在2.0场景中如果移除Camera,运行时你将不会看到任何内容
  4. 最后Camera使用Model数据对游戏场景进行渲染,

使用2.0的Camera用极少的代码就能实现卷轴地图、缩略小地图、节点跟随、动态调整渲染顺序等复杂功能。

渲染数据

我们再看一下渲染数据这块,它分为两个部分:数据与表现,请看下图:

Renderer数据结构
  1. 数据部分:输入组装器,组装了VertexBuffer(顶点缓存)和IndexBuffer(索引缓存)
  2. 表现部分:主要是增加了Material(材质系统)相关API,可以方便地控制Shader的defines、Uniforms,同时可以在不同帧切换使用不同的Shader。

这部分的应用可以参考《ShaderHelper组件速递》《Material.js源码分析》。

3. 小结

本篇初步探索了Cocos Creator 2.x新的渲染流程和框架,其中对开发者特别有用的是性能提升、自定材质系统、3D摄像机让游戏表现会更加丰富。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,331评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,372评论 3 398
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,755评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,528评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,526评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,166评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,768评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,664评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,205评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,290评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,435评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,126评论 5 349
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,804评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,276评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,393评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,818评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,442评论 2 359

推荐阅读更多精彩内容