iOS OpenGL开发(三) - OpenGL渲染架构解析

OpenGL

前言

前两篇文章中给大家解析过了什么是OpenGL的一些常用名词,掌握一些常用的名词,可以更加方便我们后面的学习和理解,也方便我们后面在遇到之后更加容易去查找。然后讲了着色器的渲染流程,我们基本上把大致是怎么玩儿的也弄清楚了。那么这一片文章就从OpenGL的渲染架构开始,带大家聊了解一下OpenGL的渲染架构到底是怎么组成的。

OpenGL渲染架构

首先我们来看一张架构图:


着色器渲染架构图

解释一下什么叫做客户端,什么叫做服务端

  • 客户端:我们编写的代码,或者是说调用的OpenGL的API,客户端是存储在CPU存储器中的,并且在应用程序中执行,或者再主系统内存的驱动程序中执行。
  • 服务端:就是计算机图形硬件厂商所提供的OpenGL的实现。我们编写的GLSL代码也是在服务端去运行的,简单来说就是操作的GPU。

服务端和客户端在功能上是异步的,也就是说他们是各自独立的软件块或者硬件块,或者软硬件都有,为了获得最佳的性能,我们希望两方面都尽可能不停地工作。客户端不断地将数据块和命令块组合到一起送到缓冲区,然后这些缓冲区会发送到服务端执行。服务端将执行这些缓冲区的内容,与此同时客户端又做好了发送下一个用于渲染的数据或者信息的准备,如果服务端停止工作等待客户端,或者客户端停止了工作来等待服务端做好接受更多命令和数据的准备,我们就把这情况称为管线停滞

从上面的图,我们也能看出。客户端只会向服务端传递三种数据,分别是:

1、属性值(Attributes)

  • 就是一个对每个顶点都要做改变的数据元素。实际上,顶点位置本身就是一个属性。属性值可以使浮点数、整数或布尔数据。
  • 属性总是以四维向量的形式进行内部存储的,即使我们不会使用到所有4个分量。例如,一个顶点位置可能存储为一个x值,一个y值和一个z值,将占用4个分量中的3个。OpenGL会将第4个(w分量)设为1。实际上,如果我们在二维平面上面绘图的话,那么第3个分量就会自动设为0,第4个分量依旧设为1。
  • 属性会从本地客户端内存中复制存储在图形硬件中的一个缓冲区上。这些属性只供顶点着色器使用,对于片元着色器来说没有意义。
  • 这些属性对每个顶点都要做改变,并不意味着他们的值不能重复,而只是说明每个顶点都有一个实际存储值。当然,通常情况下他们都是不同的,但是也有可能会与整个数组都是同一个值得情况。但是这种情况很浪费。

2、Uniform值

  • Uniforms值本质上跟属性一样,但是跟属性值不同的是,顶点着色器和片元着色器中都可以有Uniform变量。
  • 所谓属性就是一个对每个顶点都要做改变的数据元素。实际上,顶点位置本身就是一个属性。属性是不变的。
  • 我们通常设置完Uniform变量就紧接着发出渲染一个图元批次的命令。Uniform实际上可以无次数限制的使用,我们可以设置一个应用于整个表面的单个颜色值,还可以设置一个时间值,在每次渲染某种类型的顶点动画时修改它。
  • Uniform变量一个常见的应用是在顶点渲染中设置变换矩阵。

3、纹理数据(Texture Data)

  • 从顶点着色器和片元着色器中都可以对纹理值进行采样和筛选。典型情况下,片元着色器对一个纹理进行采样,并在一个三角形的表面上应用图形数据,但是,纹理数据的作用并不仅仅是表现图形。很多图形文件格式都是以无符号字节形式对颜色分量进行存储的,但是我们仍然可以设置浮点纹理。
  • 任何大型浮点数据块(例如消耗资源很大的函数的大型查询表)都可以通过这种方式传递给着色器。

步骤:
1、三个值都可以通过三个通道分别传到顶点着色器中,顶点着色器处理从客户机输入的数据、应用变换、进行其他的类型的数学运算来计算关照效果、位移、颜色值等等。(为了渲染共有3个顶点的三角形,顶点着色器将执行3次,也就是为了每个顶点执行一次)在目前的硬件上有多个执行单元同时运行,就意味着所有的3个顶点可以同时进行处理;
2、顶点着色器处理完成之后,就会经过图元合成,将顶点组合在一起变成图元,然后裁剪、转换窗口坐标、进行光栅化;
3、接着将数据输入到片元着色器,计算片元最终颜色以及深度,然后传递到片元测试模块以及混合模块,由片元着色器输出我们将屏幕上看到的最终颜色值。

注意:

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

推荐阅读更多精彩内容

  • 本文首发于个人博客:Lam's Blog - 【OpenGL ES】入门及绘制一个三角形,文章由MarkDown语...
    格子林ll阅读 7,265评论 2 18
  • 想要学习OpenGL的渲染思想,就需要了解OpenGL中,图片是怎么渲染到我们所看到的屏幕上的,这个流程是需要知道...
    Daniel_Harvey阅读 4,677评论 0 3
  • 渲染管线 苹果提供了两种OpenGL ES的可视化模型,一种是客户端—服务端的架构模型,另一种就是管线的模型。 客...
    sellse阅读 12,135评论 1 10
  • 我们在工作中经常听到有人说“能者多劳”。对于那些“无能者”来说,这可能是他们调侃他人的一句话。因为他们没有能力,所...
    景琛阅读 242评论 0 0
  • 羡慕记性好的人,感觉干什么脑力活都不会费劲,临时抱抱佛脚就能分分钟成仙。 我经常梦到别人在修仙,然后我躲在旁边看,...
    酸奶小番茄阅读 229评论 0 0