1. EGL
OpenGL ES命令须要一个rendering context和一个drawing surface。
Rendering Context: 保存当前的OpenGL ES状态。
Drawing Surface: 是原语(primitive)绘图的Surface。
它指定了渲染的buffer类型,如:color buffer。depth buffer和stencil buffer;同一时候它也指定了每一个须要的buffer的位深度(bit depth)。
EGL是OpenGL ES API与Native Window System之间的接口。
在OpenGL ES运行render之前,须要EGL做下面工作:
• 查询设备上可得到的显示设备,并初始化它们。
• 创建一个Rendering Surface(渲染表面)。
EGL能够创建屏幕上的表面(on-srceen surface)或离线屏幕表面off-screen surface,屏幕上的表面连接到本地窗体系统;而离线屏幕表面不显示,但能够用于渲染表面(rendering surface)的像素缓冲区。
• 创建一个rendering context(渲染环境)。
在真正開始绘图之前,须要把渲染环境连接到渲染表面。
1.1 EGL 数据类型
Data Type | C-Language Type | EGL Type |
32-bit integer | int | EGLint |
32-bit unsigned integer | unsigned int | EGLBoolean, EGLenum |
32-bit pointer | void * | EGLConfig, EGLContext, EGLDisplay, EGLSurface, EGLClientBuffer |
2. OpengGL ES命令后缀和參数数据类型
Data Type Suffix | Data Type | C-Language Type | GL Type |
b | 8-bit signed integer | signed char | GLbyte |
ub | 8-bit unsigned integer | unsigned char | GLubyte, GLboolean |
s | 16-bit signed integer | short | GLshort |
us | 16-bit unsigned integer | unsigned short | GLushort |
i | 32-bit signed integer | int | GLint |
ui | 32-bit unsigned integer | unsigned int | GLuint, GLbitfield, GLenum |
x | 16.16 fixed point | int | GLfixed |
f | 32-bit floating point | float | GLfloat, GLclampf |
GLvoid是OpenGL ES命令可接受的指针。
2.1 OpenGL ES基本错误码
错误码可通过GLenum glGetError(void)函数获取。假设当前错误码的值不为GL_NO_ERROR。则新产生的错误码不能被保存。
Error Code | Description |
GL_NO_ERROR | No error has been generated since the last call to glGetError. |
GL_INVALID_ENUM | A GLenum argument is out of range. The command that generated the error is ignored. |
GL_INVALID_VALUE | A numeric argument is out of range. The command that generated the error is ignored. |
GL_INVALID_OPERATION | The specific command cannot be performed in the current OpenGL ES state. The command that generated the error is ignored. |
GL_OUT_OF_MEMORY | There is insufficient memory to execute this command. The state of the OpenGL ES pipeline is considered to be undefined if this error is encountered except for the current error code. |
3. Flush和Finish
OpenGL ES2.0 API继承了OpenGL的C-S(client-server)模式。应用程序(client)公布命令,则Server负责运行处理。且不是应用程序每发一个命令都被及时地发送给Server。在设备中CPU负责运行游戏的逻辑。并向GPU(硬件显卡或是软件模拟的显卡)发送绘图指令。在这样的架构下,CPU和GPU分别充当client与server端的角色。
glFlush命令把当前OpenGL ES环境中的命令进行刷新,然后发送给Server。glFlush仅仅是把命令发送给Server,但并不等待运行完毕。
假设须要等到Server运行完毕时才返回,则须要调用glFinish,但它严重影响性能。
eglSwapBuffers中调用了glFlush。
4. 主要的状态管理
管道的每一个阶段都有自己的一些状态,且每一个状态有相应的值,这些状态值能够通过下面两个函数进行改动:
void glEnable(GLenum cap)
void glDisable(GLenum cap)
在初始状态时,除GL_DITHER(初始值为GL_TRUE)之外,其他每一个状态的初始值都为GL_FALSE。这些状态值被保存在EGLcontext中。
其状态值可通过glIsEnabled(GLboolean glIsEnabled(GLenum cap))来进行查询。