我是『云飞扬』
Cocos论坛昵称『大风起兮云飞扬』
Cocos引擎忠实用户
Cocos2d-x、Cocos Creator、Cocos Creator 3D系列
都在项目中使用过
有Cocos论坛强迫症,每天必逛!
喜欢研究一些有意思的东西,比如:帧同步
最近开始对图形渲染比较感兴趣
在看Cocos引擎源码,也在学习图形学当中
也在想尽办法—脱单、脱单、脱单!
不过...
今天给大家分享的主题还是

Cocos Creator 3D源码之GFX

GFX是什么

GFX是一个抽象层,它的目的是屏蔽底层的图形接口(OpenGL、Vulkan、Metal ……),暴露给上层一个统一的图形接口。

GFX中的抽象概念

GFX的目录结构如下:左侧是抽象概念的抽象类,webgl、webgl2两个文件夹则是对这些抽象概念的具体实现。右侧的GFXObjectType是这些抽象概念的枚举。整个抽象系统跟Vulkan接近。

define.ts

里面定义了各种枚举、常量。例如,GFXFormat里面定义了各种纹理格式:ETC、PVR、ASTC... GFXCullMode定义了面剔除, GFXFilter定义了纹理采样过滤方式...

device.ts

GFX 设备,整个GFX的大总管。

职责一:提供硬件设备支持的各项渲染参数的查询。如:最大顶点属性数量、最大纹理单元数量、最大uniform缓冲绑定数量... 接口如下:

职责二:负责整个抽象层所有对象的创建,接口如下所示:

queue.ts

GFXQueue GFX队列:命令缓冲会被提交到这里。GFXQueue是一个抽象类,可以看一下具体实现类WebGL2Queue。代码如下:

并没有看到任何跟命令执行有关的东东。也是为Vulkan和Metal准备的。

buffer.ts

定义了GFXBuffer 缓冲抽象类。常见缓冲有:顶点缓冲、顶点索引缓冲、uniform缓冲

input-assembler.ts

定义了GFXInputAssembler输入汇集器。收集顶点数据然后提供给GPU使用。里面主要是顶点数据信息,如:顶点缓冲、索引缓冲。

webgl2-commands.ts

  1. 对原始WebGL函数调用的封装 

  2. 提供了一套极简的命令系统 

  3. 命令集的执行

command-buffer.ts

定义了抽象类GFXCommandBuffer,代表命令缓冲。

webgl2-command-buffer.ts

WebGL2CommandBuffer 继承自 GFXCommandBuffer。每一个函数调用都对应的生成一个命令。

webgl2-primary-command-buffer.ts

WebGL2PrimaryCommandBuffer 继承自 WebGL2CommandBuffer这里对函数的调用都进行了重写,从WebGL2CommandBuffer生成命令的方式,改成了函数的直接调用。那到底使用的是哪一个commandBuffer呢?在前向渲染管线ForwardPipeline中我们可以看到然后再看一下createCommandBuffer的实现

到这里就可以确认使用的是WebGL2PrimaryCommandBuffer了。至于WebGL2CommandBuffer里以命令集执行的方式应该也是为Vulkan和Metal准备的。

descriptor-set.ts

描述符集可以理解为OpenGL中的UniformBuffer和纹理组成的集合。集合分了三类:

  1. GLOBAL

  2. MATERIAL

  3. LOCAL

GLOBAL里放的是一些全局通用信息,例如时间、屏幕尺寸、相机的位置、平行光的方向。

LOCAL里面放的主要是跟模型相关的一些信息,例如模型的世界矩阵ccmatWorld、光照烘焙信息cclightingMapUVParam。MATERIAL材质本身的。

pipeline-layout.ts descriptor-set-layout.ts

主要是描述了uniformBuffer以及纹理的绑定信息。我们来看一下WebGL2PipelineLayout运行时的数据,以便有一个直观的印象。

img

Uniform以及纹理的绑定 Uniform Buffer Object 绑定点的形象说明 图源自https://learnopengl-cn.github.io/04%20Advanced%20OpenGL/08%20Advanced%20GLSL/#uniform_1步骤a

调用堆栈

步骤b调用栈

顶点属性相关的处理

pipeline-state.ts

定义了GFXPipelineState抽象类,是对整个管线状态的抽象。材质正是对管线某一个状态的完整描述(包括uniform和纹理)。

fence.ts

处理同步相关的东东,为后续适配Vulkan和Metal做准备。但当前版本实际并没有使用到。

GFX全貌

首先我们来回忆一下引擎的渲染流程结合代码,看一下forwardStage的具体实现

可以看到所有的渲染队列都执行了recordCommandBuffer,继续看一下里面的实现。在这里我们看到了之前所讲的那些GFX概念:commandBuffer、 inputAssembler、shader、pipelineState、DescriptorSet... 画个图将前面讲的零碎概念串起来最后附送一张图


欢迎关注我的微信公众号:游戏编程之路

  • 2020社区最新教程精华700+页PDF!

  • 【腾讯课堂】Creator零基础修仙实战上线啦!

  • NativeAPI手机原生功能调用接口丰富

  • 能生成女朋友吗?Creator全自动代码生成器来袭!

  • 996试用期4个月,被公司劝退!开发者太糟心了!

  • 换皮被默许?微信后台竟然支持代码授权!!!

太干了!大俠『云飞杨』带你走进GFX!相关推荐

  1. 交大『云观CD-ROMIII』直接由CD-ROM执行之安装法(转)

    交大『云观CD-ROMIII』直接由CD-ROM执行之安装法(转) 笔者很高兴看到交大一群朋友们的努力, 出版了一份本土的 "Plug & Play" Linux CD-R ...

  2. 『 云原生·Docker』Docker镜像分层与Docker镜像操作(二)

    系列文章目录 本系列主要分为以下六大部分,正在更新中,尽请期待! 『 云原生·生之门』 『 云原生·前置知识』 『 云原生·Docker』 『 云原生·Kubernetes』 『 云原生·KubeSp ...

  3. 『 云原生·Docker』虚拟机与容器

    系列文章目录 本系列主要分为以下六大部分,正在更新中,尽请期待! 『 云原生·生之门』 『 云原生·前置知识』 『 云原生·Docker』 『 云原生·Kubernetes』 『 云原生·KubeSp ...

  4. 『 云原生·Docker』Docker网络

    系列文章目录 本系列主要分为以下六大部分,正在更新中,尽请期待! 『 云原生·生之门』 『 云原生·前置知识』 『 云原生·Docker』 『 云原生·Kubernetes』 『 云原生·KubeSp ...

  5. 『 云原生·Docker』Docker存储

    系列文章目录 本系列主要分为以下六大部分,正在更新中,尽请期待! 『 云原生·生之门』 『 云原生·前置知识』 『 云原生·Docker』 『 云原生·Kubernetes』 『 云原生·KubeSp ...

  6. 『 云原生·Docker』Docker容器数据卷

    系列文章目录 本系列主要分为以下六大部分,正在更新中,尽请期待! 『 云原生·生之门』 『 云原生·前置知识』 『 云原生·Docker』 『 云原生·Kubernetes』 『 云原生·KubeSp ...

  7. qtablewidget 数据量大效率很低_让大牛带你走进大数据分析:R基础及应用的潮流尖端,享受RHadoop...

    走进R,走进大数据时代数据分析的潮流尖端,掌握R语言,熟悉大数据的基础概念和R与Hadoop结合进行大数据的处理分析. 大数据时代, R以其强大的数据分析挖掘.可视化绘图等功能,越来越受到社会各个领域 ...

  8. 『飞秋』Windows7新功能体验(1):为Windows 7 Media Center安装网络电视(Internet TV)

    『飞秋』Windows7新功能体验(1):为Windows 7 Media Center安装网络电视(Internet TV) 在Windows 7许多的新功能里,娱乐功能也做了很大的改进: Dire ...

  9. 【推荐】两大APP与云账户红包SDK集成详情及Demon分享

    云账户红包SDK3.0已经发布一段时间了! 就在本月,两家老牌重量级APP完成了云账户红包SDK的集成,经过双方严格的联合测试,现在正式发版了!他们就是"工作圈"&&quo ...

最新文章

  1. insta经典滤镜下载
  2. 将源码包打包成RPM包
  3. Express使用http-proxy-middleware
  4. 一个炒鸡好用的pdf阅读器
  5. MAC 修改文件夹以及子文件夹和子文件权限 以及 修改文件夹owner
  6. java jdk包_Java开发工具包JDK的简介
  7. node.js 实现udp传输_nodejs实现UDP组播示例方法
  8. 集合竞价如何买入_教你几招!什么是集合竞价?散户如何参与集合竞价?
  9. 谷歌开发者版和beta版_Google工具栏Beta,工具栏API和ComputerZen Google工具栏按钮
  10. Python进化算法之多目标优化与代码实战
  11. JavaScript动态加载效果
  12. 已解决mybatis报错:Invalid bound statement (not found)
  13. 洛谷 P1010 [NOIP1998 普及组] 幂次方 Python题解
  14. 从底层到应用,那些数据人的必备技能
  15. Java web 项目技术文档目录结构
  16. 高防BGP服务器有什么用
  17. mapbox自定义地图
  18. wifi共享精灵轻松搞定wifi网络
  19. (只需两步)让ChatGPT免费帮你制作出漂亮的PPT
  20. 库卡机器人Officelite运行EthernetKRL进行通讯

热门文章

  1. linux 6 服务搭建,Linux CentOS6.8搭建sftp服务
  2. ArcEngine面转线
  3. python如何把ts视频拼接起来_Python实现FLV视频拼接功能
  4. 解决textarea在ie浏览器下宽度溢出的问题
  5. THRUST:一个开源的、面向异构系统的并行编程语言:编程模型主要包括:数据并行性、任务并行性、内存管理、内存访问控制、原子操作、同步机制、错误处理机制、混合编程模型、运行时系统等
  6. linux shell 编辑文件内容,Shell编辑与文本处理(Bash sed文本编辑)
  7. java 画爱心壮那首歌最,抖音简单爱心所爱是什么歌 简单爱心所爱是什么歌名歌词介绍...
  8. 蓝/紫/红色光油溶性钙钛矿/近红外发射光油溶性PbS/CdS量子点制备
  9. 如何找到Xcode中下载的Provisioning Profile文件
  10. 展讯Android 12 通过 ADB 获取当前背光值