这样的博客数不胜数了,我也是这样学习过来的,记录一下自己的学习经历
第一步: 在Xcode创建项目并创建一个简单的类为OpenGLView导入opengels/es2/gl.h , 接下来创建CAEAGLLayer的对象。
data:image/s3,"s3://crabby-images/41f83/41f83d36ad802bb7260174263e9ea7ccb4d2ff78" alt=""
image.png
data:image/s3,"s3://crabby-images/f1aa8/f1aa83c0667e5804fed6e25c5f0e7f3b79e2f0e0" alt=""
image2.png
第二步:EAGLContext的对象,是opengles渲染必不可少的。EAGLContext管理所有通过OpenGL进行draw的信息。
data:image/s3,"s3://crabby-images/f47f2/f47f2ad02e6591f8f4c1227aef157d441b49a4d0" alt=""
image3.png
第三步:设置帧缓冲区和渲染缓冲区,FrameBuffer and RenderBuffer。apple不允许OpenGL直接渲染在屏幕上,我们需要把它放进输出的颜色缓冲,然后询问EAGL 去把缓冲对象展现到屏幕上。
data:image/s3,"s3://crabby-images/e88a6/e88a6a09cc1afb5e418f856200c437f691fe2d85" alt=""
image4.png
data:image/s3,"s3://crabby-images/bcfd4/bcfd4285669acfa6f1084b023432212c4c1bb15d" alt=""
image5.png
第四步:创建program,这里就用到了之前提到的GLSL语言,后续会更新关于它的语法等。这里会写到顶点着色器和片元着色器,就是glsl语言,代码见下图。
data:image/s3,"s3://crabby-images/78de1/78de129d3b138477f473c7a936e39addb5ca23ac" alt=""
shader文本
关于program,第一步就是加载着色器,编译,然后通过shader去创建program,固定着色器,链接着色器并检查program状态,接下来就是使用program啦,获取着色器程序中,指定为attribute类型变量的id。
data:image/s3,"s3://crabby-images/646f1/646f1484c2212ea3ad808d33bb908131c6867311" alt=""
image6.png
data:image/s3,"s3://crabby-images/745d1/745d1a529a95d45e09247df6ee2f282004e4e937" alt=""
image7.png
data:image/s3,"s3://crabby-images/fceb1/fceb1a7d19544ec9b11622242e8df4e806ed6f1f" alt=""
image8.png
加载编译shader代码:
data:image/s3,"s3://crabby-images/50a73/50a73139d53b828e729e476a01781d48b441d54b" alt=""
loadShader.png
第五步:Render
在render里设置清屏颜色,然后清屏。设置视口viewport,然后调用glVertexAttribPointer传入顶点数据,因为默认情况下所有顶点着色器的属性(Attribute)变量都是关闭的,所以这里调用glEnableVertexAttribArray启用指定属性。然后通过 glDrawArrays渲染三角形。最后调用EAGLContext的presentRenderbuffer将渲染结果提交给上下文中。
data:image/s3,"s3://crabby-images/47874/47874e49e4e2d7596a871cacdc48cc0a4f86d4ea" alt=""
render.png
记住opengl的流程,记住opengl的状态!
本人正在自学,本文相当于记录,如有错误,请指出,谢谢!