随着短视频、美颜相机等APP愈来愈火,对于一个移动端开发工程师来讲,跟上时代的潮流即是咱们必备的意识。ios
固然还有一点,接触移动开发,咱们不只仅是要了解若是使用API去将控件摆在屏幕上,咱们还应该去了解,图片是如何去渲染到屏幕上面的,这里面到底有哪些过程,经过了解这些过程以后,在后面的开发这种咱们能怎么去优化项目呢?这里面的门道,每每是一些初中级程序员忽略的部分。程序员
那么这一系列的文章,就是从OpenGL开始,手把手的带你们感觉图形渲染的魅力。在我本身的学习过程当中,也将本身的学习过程,以及学习成果分享给你们。但愿能帮助到你们,若是有不认同的地方,欢迎能在留言中指出来,固然也能够将问题发送到个人邮箱:coderspr1nghall@gmail.com
。咱们一块儿讨论,一块儿飞。 这篇文章主要是将一些经常使用的专业术语进行总结,方便本身往后的查阅。算法
[TOC]编程
OpenGL (Open Graphics library) 是⼀一个跨编程语⾔、跨平台的编程图形程序接⼝,它将计算机的资源抽象称为一个个OpenGL的对象,对这些资源的操做抽象为一个个的OpenGL指令。数组
OpenGL ES (OpenGL for Embedded Systems) 是 OpenGL 三维图形 API 的子集,针对⼿机、 PDA和游戏主机等嵌入式设备而设计,去除了许多没必要要和性能较低的API接口。缓存
DirectX 是由不少API组成的,DirectX并非一个单纯的图形API. 最重要的是DirectX是属于 Windows上一个多媒体处理API.并不支持Windows之外的平台,因此不是跨平台框架. 按照性 质分类,能够分为四大部分,显示部分、声音部分、输⼊部分和网络部分。网络
Metal 是Apple为游戏开发者推出了新的平台技术 Metal,该技术可以为 3D 图 像提升 10 倍的渲染性能。Metal 是Apple为了解决3D渲染⽽而推出的框架。架构
其实苹果自14年推出Metal以后,就已经很明确的告诉你们,在极限性能方面,Metal的表现是要更加的出色的。由于他们对Metal作了不少针对性的优化,让他在iOS的设备上能有一个更完美的发挥。 这里也能够看出,Metal是能够取代OpenGL ES的。可是如今市场上面,依然仍是OpenGL ES的使用率更高。因此OpenGL ES和Metal的关系就有点像是Objective-C和Swift的关系同样。框架
状态机理论上是一种机器,其实咱们能够这样去理解,状态机描述了一个对象在其生命周期中所经历的各类状态,状态之间的转变,发生转变的动因,条件以及转变中所执行的活动。这一点上来讲,跟JSContext也能够类比一下。咱们的任何行为都是依赖着状态机的,状态机会记录全部的行为,那么咱们在须要使用某一个行为的时候,也是能够经过状态机去拿出来某一个行为。因此状态机也是一种行为,说明对象在其生命周期中相应事件所经历的状态序列以及对那些状态事件的相应。函数
所以具备如下特色:
这个好理解,就是将图形/图像数据转换成3D空间图像操做叫作渲染。例如,在图片或者视频进行解码以后,造成了一大堆的二进制文件,而后咱们将这一堆的二进制文件显示到屏幕上面的过程就能够理解为渲染。
那么什么是顶点呢?顶点就是指咱们再绘制一个图形的时候,他的顶点的位置数据,这个数据是能够直接存储在数组中或者将其缓存在GPU内存中的。若是存储在数组中就构成了顶点数组。其实顶点数据就是咱们在画画的时候,最开始画的一个大体的骨架。在OpenGL中的图像都是由图元组成。在OpenGL ES中,有三种图元:点、线、三角形。咱们经过设定函数的指针,将顶点数据存储在内存中,而后须要绘制的时候,直接从内存中取出来使用。这一部分的数据其实就是顶点数组。
咱们上面说了,咱们在调用绘制方法的时候,直接就由内存传入顶点数据。还有一种更加高性能的方法,就是提早分配一快内存,将顶点数据预先传入到显存当中,这部分的显存,就叫作顶点缓冲区。值得注意的是,这一块空间再也不内存中,而是在显存的一块空间中。
由于咱们的GPU在处理数据的时候,是经过一个固定的顺序来的,这个顺序不能被打破。相似一个流水线的形式,因此被称之为管线。
纹理能够理解为一个图片,也就是位图。⼤家在渲染图形时须要在其编码填充图⽚,为了使得场景更加逼真.⽽这里使⽤的图片,就是常说的纹理.可是在OpenGL,咱们更加习惯叫纹理,⽽不是图片。
在测试阶段以后,若是像素依然没有被剔除,那么像素的颜色将会和帧缓冲区中颜色附着上的颜色进行混合,混合的算法能够经过OpenGL的函数进行指定。可是OpenGL提供的混合算法是有限的,若是须要更加复杂的混合 算法,⼀般能够经过像素着⾊器进行实现,固然性能会比原生的混合算法差一些。
例如图形想发平生移,缩放,旋转变换。就须要使用变换矩阵。
⽤于将3D坐标转换为二维屏幕坐标,实际线条也将在二维坐标下进行绘制。
当咱们想把一个图像渲染到窗口的时候,GPU会开辟一个渲染缓冲区。可是每个窗口又只有一个缓冲区,那么若是在绘制的过程当中屏幕进行了刷新,窗口显示的画面就有可能不完整。为了解决这个问题,常规的OpenGL程序至少都会有两个缓冲区。显示在屏幕上的称为屏幕缓冲区,没有显示的称为离屏缓冲区,在一个缓冲区渲染完成以后,经过将屏幕缓冲区和离屏缓冲区交换,实现图像在屏幕上的显示。在iOS中常常遇到的离屏渲染,其实就是双缓冲区的机制引发的。若是这方面有疑问的,能够移步iOS 保持界面流畅的技巧去了解。 使用了双缓冲区和垂直同步技术以后,因为老是要等待缓冲区交换以后再进行下一帧的渲染,使得帧率没法彻底达到硬件容许的最高水平。为了解决这个问题,引入了三缓冲区技术,在等待垂直同步时,来回交替渲染两个离屏的缓冲区,而垂直同步发生时,屏幕缓冲区和最近渲染完成的离屏缓冲区交换,实现充分利用硬件性能的目的。