Opengl4.5 中文手册—B

索引

A      B    C      D     E     F     G

H      I     J      K     L     M     N

O      P    Q      R     S     T

U      V    W      X     Y     Z

B

glBeginConditionalRender 3.0

开始条件渲染

GLuint queryid

GLenu mode: GL_QUERY_WAIT|GL_QUERY_NOWAIT|

GL_QUERY_BY_REGION_WAIT|GL_QUERY_REGION_NOWAIT

根据遮挡查询结果进行绘制,_WAIT会等待查询执行完毕,再根据结果判断;_NOWAIT版本在Query未执行完时会直接绘制

glBeginQuery 2.0

开启遮挡查询

GLenum target:

GL_SAMPLES_PASSED,  通过的采样个数

GL_ANY_SAMPLES_PASSED,  是否存在通过的采样 3.3+

GL_ANY_SAMPLES_PASSED_CONSERVATIVE,  非精确的结果(保守),速度可能快 4.3+

GL_PRIMITIVES_GENERATED, vertex shader或者geometry shader emit顶点数

GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN, 查询生成到反馈查询缓冲区中的顶点数

GL_TIME_ELAPSED

GLuint queryid

glEndQuery(GLenum target ):与begin相同

结束查询

可以使用glGetQuery、glGetQueryObject获取查询结果

glBeginQueryIndexed 4.0

4启用索引查询,用于geometryshader

GLenum target

GLuint index 和BeginQuery区别在于使用geometryshader并在在target为GL_PRIMITIVES_GENERATED\ GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN时,可指定对应的stream索引

GLuint queryid

glEndQueryIndexed结束查询

glBeginTransformFeedback

3.0+ 开启反馈查询

GLenum mode: GL_POINTS\GL_LINES\GL_TRIANGLES

用于将vertex或者geometry shader结果输出到通过glBindBufferBase、glBindBufferRange绑定的GL_TRANSFORM_FEEDBACK_BUFFER缓冲区,不是通过glBindBuffer绑定(无索引参数,只能绑定到非数组类型的目标缓冲区:GL_ATOMIC_COUNTER_BUFFER, GL_TRANSFORM_FEEDBACK_BUFFER, GL_UNIFORM_BUFFER or GL_SHADER_STORAGE_BUFFER). P458

记录的顶点程序输出可在程序链接前通过glTransformFeedbackVaryings设置

glBindAttribLocation 2.0

设置顶点属性索引,一般在shader中用layout(location=index) 设置,设置的索引在linkprogram之后生效。

可以将多个名称绑定到同一索引,实现别名

GLuint program,

GLuint index,

const GLchar *name

绑定片段程序输出使用glBindFragDataLocation

glBindBuffer 2.0

关联buffer

GLenum target:

GL_ARRAY_BUFFER   顶点属性,用于glVertexAttribPointer

GL_ELEMENT_ARRAY_BUFFER         顶点索引,用于glDrawElements等索引绘制方法

GL_COPY_READ_BUFFER          Buffer copy source

GL_COPY_WRITE_BUFFER        Buffer copy destination

GL_PIXEL_PACK_BUFFER           用于从纹理或帧缓冲区对象中读取像素数据  glGetCompressedTexImage, glGetTexImage, and glReadPixels.

GL_PIXEL_UNPACK_BUFFER     作为生成纹理数据源,用于glTexImage2D, glTexImage3D, glTexSubImage1D, glTexSubImage2D等

GL_TEXTURE_BUFFER       Texture data buffer

GL_QUERY_BUFFER   用于存储查询结果glGetQuery

GL_DISPATCH_INDIRECT_BUFFER   用于glDispatchComputeIndirect

GL_DRAW_INDIRECT_BUFFER  用于glDrawArraysIndirect and glDrawElementsIndirect

以下四个类型含多个绑定点,需要使用glBindBufferBase 或glBindBufferRange绑定

GL_ATOMIC_COUNTER_BUFFER     Atomic counter storage

GL_SHADER_STORAGE_BUFFER       Read-write storage for shaders

GL_TRANSFORM_FEEDBACK_BUFFER     Transform feedback buffer

GL_UNIFORM_BUFFER

GLuint bufferID

glBindBufferBase

3.0+ 绑定索引的数组类型的缓冲区,也可绑定非索引类型缓冲区

索引缓冲区包括:GL_ATOMIC_COUNTER_BUFFER, GL_TRANSFORM_FEEDBACK_BUFFER

, GL_UNIFORM_BUFFER or GL_SHADER_STORAGE_BUFFER

GLenum target,

GLuint index, 相比glBindBuffer增加了此参数,指定对应绑定点索引,

GLuint buffer

glBindBufferRange

3.0+绑定索引的缓冲区中可用数据范围,也可用于绑定非索引类型缓冲区

索引缓冲区包括:GL_ATOMIC_COUNTER_BUFFER, GL_TRANSFORM_FEEDBACK_BUFFER

, GL_UNIFORM_BUFFER or GL_SHADER_STORAGE_BUFFER

相比glBindBufferBase增加了offset和size

GLenum   target,

GLuint      index,

GLuint      buffer,

GLintptr   offset,

GLsizeiptr                 size

glBindFramebuffer

关联帧缓冲区

3.0+

GLenum target, :GL_DRAW_FRAMEBUFFER 渲染、GL_READ_FRAMEBUFFER读取、GL_FRAMEBUFFER 渲染和读取

GLuint framebuffer

关联到GL_DRAW_FRAMEBUFFER的Framebuffer的可通过glFramebufferRenderbuffer挂接渲染缓冲区、以及通过glFramebufferTexture2D渲染到纹理。

glBindFragDataLocation 3.0

设置片段程序输出对应的颜色缓冲区索引

GLuint program,

GLuint colorNumber, [0, GL_MAX_DRAW_BUFFERS)

const char * name 变量名称

如果片段程序使用layout (location = colorNumber)指定了索引,则此方法调用无效

不可以将多个变量输出到同一索引

主要用于多渲染目标绘制,参考glDrawBuffers

glBindFragDataLocationIndexed 3.2

同glBindFragDataLocation, 增加了index,分别为0/1表示对应颜色混合等式的第一个或第二个输入项

GLuint program,

GLuint colorNumber,

GLuint index,

const char *name

glBindImageTexture

4.2+ 绑定纹理到image unit用于后续的shader读写

GLuint unit,              绑定到的image unit索引

GLuint texture,

GLint level,               使用的纹理level

GLboolean layered,使用纹理数组或者立方体纹理时,是否按层堆放。true 使用所有, false 仅使用layer指定的层

GLint layer, layerder=false时指定使用的层

GLenum access, GL_READ_ONLY, GL_WRITE_ONLY, or GL_READ_WRITE 指定读写权限

GLenum format 数据输出格式,应与纹理的innerformat同大小并属于同一类。

glBindImageTextures

4.4+ 批量绑定纹理到image unit

GLuint first,     起始iamge unit索引

GLsizei count,

const GLuint *textures

采用layered方式绑定level 0,格式与纹理格式相同

glBindProgramPipeline

4.1+ 绑定管线对象到当前上下文

GLuint pipeline

如果glUseProgram 设置了当前程序,则使用glUseProgram的设置,glUseProgram优先级较高。

glBindRenderbuffer

3.0+ 绑定渲染缓冲区

GLenum target, GL_RENDERBUFFER 仅此一个绑定点,设计多余

GLuint renderbuffer

绑定后可通过glRenderbufferStorage初始化格式和大小,并关联到Framebuffer用于后续渲染

glBindSampler

3.3+ 将采样器关联到纹理单元

GLuint unit

GLuint sampler

采样器设置优先于纹理的单元的纹理状态设置,未设置采样器才会采用纹理状态设置

一个采样器可用于多个纹理单元

glBindSamplers

4.4+ 批量设置多个采样器

GLuint first,     起始纹理单元索引

GLsizei count,

const GLuint *samplers

glBindTexture

2.0+ 绑定纹理

GLenum target: GL_TEXTURE_1D, GL_TEXTURE_2D, GL_TEXTURE_3D, GL_TEXTURE_1D_ARRAY, GL_TEXTURE_2D_ARRAY, GL_TEXTURE_RECTANGLE, GL_TEXTURE_CUBE_MAP, GL_TEXTURE_CUBE_MAP_ARRAY, GL_TEXTURE_BUFFER, GL_TEXTURE_2D_MULTISAMPLE or GL_TEXTURE_2D_MULTISAMPLE_ARRAY

GLuint     texture

纹理默认仅当前渲染上下文可见。

glBindTextures

4.4+ 批量绑定纹理

GLuint first,     起始纹理单元

GLsizei count,

const GLuint *textures

glBindTextureUnit

4.5+ 蒋纹理直接绑定到纹理单元

GLuint unit,

GLuint texture

相当于glActiveTexture +glBindTexture, 可配合glBindSampler

glBindTransformFeedback

4.0+ 绑定变换反馈对象

GLenum target,  GL_TRANSFORM_FEEDBACK

GLuint id

glBindVertexArray

3.0+ 绑定顶点数组对象VAO

GLuint arrayID

glBindVertexBuffer

4.3+ 绑定顶点buffer ,相当于glBindBuffer+glVertexAttribPointer,但简单多了,以前设计太累赘

GLuint bindingindex, 绑定索引

GLuint buffer,

GLintptr offset,

GLintptr stride

4.5+ glVertexArrayVertexBuffer 直接绑定到VAO

glBindVertexBuffers

4.4+ 批量绑定多个顶点buffer

GLuint firstIndex,

GLsizei count,

const GLuint *buffers,

const GLuintptr *offsets,

const GLsizei *strides

glBlendColor

2.0+ 设置混合颜色,用于glBlendFunc:: GL_CONSTANT_COLOR

GLfloat red,

GLfloat green,

GLfloat blue,

GLfloat alpha

glBlendEquation

2.0+ 设置源、目标混合方程式

GLenum mode GL_FUNC_ADD, GL_FUNC_SUBTRACT, GL_FUNC_REVERSE_SUBTRACT, GL_MIN, GL_MAX 加、减、目标-源,最小、最大

glBlendEquationi (          GLuint buf, GLenum mode) 4.0+ 依据索引设置指定drawbuffer

glBlendEquationSeparate

2.0+ 对rgb和alpha设置不同的方程式

GLenum modeRGB,

GLenum modeAlpha

glBlendFunc

2.0+ 设置源和目标混合因子

GLenum src, dst :

GL_ZERO, GL_ONE, GL_SRC_COLOR, GL_ONE_MINUS_SRC_COLOR, GL_DST_COLOR, GL_ONE_MINUS_DST_COLOR, GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA, GL_DST_ALPHA, GL_ONE_MINUS_DST_ALPHA. GL_CONSTANT_COLOR, GL_ONE_MINUS_CONSTANT_COLOR, GL_CONSTANT_ALPHA, and GL_ONE_MINUS_CONSTANT_ALPHA

GL_CONSTANT_COLOR : 采用glBlendColor设定的值

GL_SRC_ALPHA_SATURATE :采用srcAlpha和1-dstAlpha中较小的一个

默认源为GL_ONE, 目标为 GL_ZERO。混合默认无效,启用需要使用glEnable(GL_BLEND)

常用的透明为:(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA)

glBlendFunc设置所有drawbuffer,设置单个drawbuffer使用glBlendFunci

glBlendFuncSeparate

与glBlendFunc类似,为rgb和alpha设置不同的混合因子

glBlitFramebuffer 3.0

3.0+ 帧缓冲区之间拷贝数据,比如帧缓冲区输出结果拷贝的窗口缓冲区显示

GLint srcX0,

GLint srcY0,

GLint srcX1,

GLint srcY1,

GLint dstX0,

GLint dstY0,

GLint dstX1,

GLint dstY1,

GLbitfield mask 颜色、深度、模板标记

GL_COLOR_BUFFER_BIT, GL_DEPTH_BUFFER_BIT GL_STENCIL_BUFFER_BIT

GLenum filter  过滤方式GL_NEAREST or GL_LINEAR, 深度或模板只能使用GL_NEAREST

将绑定到GL_READ_FRAMEBUFFER的FrameBuffer数据复制到GL_DRAW_FRAMEBUFFER绑定的帧缓冲区。可以为0,即窗口系统缓冲区。

拷贝范围为[srcx0, srcy0]-(srcx1,srcy1),即左下包含,右上不包含

glBlitNamedFramebuffer 4.5+ 根据framebufferID直接复制数据

glBufferData 2.0

初始化Buffer数据

GLenum           target,

GLsizeiptr                 size,   大小

const GLvoid * data, 数据地址,可为NULL,后续可通过glBufferSubData, glMapBuffer

glReadPixels等方式生成数据

GLenum                   usage:    GL_STREAM/STATIC/DYNAMIC_DRAW/READ/COPY

STATIC    一次创建,经常使用

DYMAMIC 多次创建,多次使用

STREAM  一次创建,几次使用

DRAW 写数据到GPU

READ  从GPU中读取数据

COPY  GPU读写数据

glNamedBufferData 4.5+ 直接初始化buffer数据

GLuint buffer,

GLsizei size,

const void *data,

GLenum usage

glBufferStorage 4.4

初始化buffer数据存储,参数与glBufferData仅最后标记不同,相比glBufferData, 标志位多了COHERENT和PERSISTENT以便协调cpu gpu并发

GLenum target,

GLsizeiptr size,

const GLvoid * data,

GLbitfield flags:

GL_DYNAMIC_STORAGE_BIT 数据可通过glBufferSubData动态更新,否则cpu在初始化后不能再更改数据。对于gpu, 不论设不设置都可以通过glCopyBufferSubData and glClearBufferSubData修改其数据

GL_MAP_READ_BIT cpu可以通过map读取其数据

GL_MAP_WRITE_BIT cpu可以通过map更新数据

GL_MAP_PERSISTENT_BIT map期间gpu可以读写buffer(不需要等待)

GL_MAP_COHERENT_BIT 使用glMapBufferRange期间,保持cpu与gpu数据一致。即cpu写对gpu立即可见。Gpu写在调用glFinish或者glFenceSync(GL_SYNC_GPU_ COMMANDS_COMPLETE,0)后对cpu可见。如果不指定此标记,需要先调用glMemoryBarrier,  数据修改才对gpu可见;对于cpu需要调用glMemoryBarrier之后再调用glFenceSync或者glFinish,gpu对数据的修改才可见

GL_CLIENT_STORAGE_BIT 使用客户端内存存储(具体存储位置依据实现)

指定GL_MAP_COHERENT_BIT需要同时指定GL_MAP_PERSISTENT_BIT

glNamedBufferStorage 4.5+ 直接设置buffer数据存储

glBufferSubData

2.0+ 替换部分数据

GLenum target,

GLintptr offset,

GLsizeiptr size,

const GLvoid * data

替换全部数据使用glBufferSubData优于glBufferData,可避免重新分配内存。

可以考虑使用多个buffer,避免在更新时堵塞渲染管线

glNamedBufferSubData 4.5+ 直接更新buffer

时间: 2024-08-02 15:51:00

Opengl4.5 中文手册—B的相关文章

Opengl4.5 中文手册—A

因为opengl API 比较庞大,网络上还没有完整的.较新的opengl中文手册 这对很多人很不方便,所以整理了这一系列,用于帮助大家"快速浏览最新的opengl api" 为了保障这一目的(同时也减少工作量),本系列对原文做了很大的简化 不过所做的的简化都尽量保证不影响原文的知识面,必要时还做了些扩展以帮助理解 如果阅读时觉的那个条目错误或者不方便理解,欢迎留言,我看到后会修改和补充 版本基于opengl 4.5,原本4.5是最终版本号,不过现在刚又推出了些新的4.6扩展,这对ap

Opengl4.5 中文手册—V

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W V glValidateProgram 2.0 验证程序是否可以正确执行,主要用于开发时调试 GLuint program glGetProgramiv(program , GL_VALIDATE_STATUS, &ok) 可获取是否通过验证 glValidateP

Opengl4.5 中文手册—U

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W U glUniform 2.0 设置uniform变量 存在多个版本,数组类型可使用count指定数组个数,矩阵版本可指定是否需要转置 glUniformBlockBinding 3.1 绑定uniform块 GLuint program, GLuint unifo

Opengl4.5 中文手册—C

索引 A      B    C      D     E     F     G H      I    J      K     L     M     N O      P    Q      R     S     T U      V    W      X     Y     Z C glCheckFramebufferStatus 3.0+ 查询Framebuffer状态 GLenum target glCheckNamedFramebufferStatus GLuint fram

Opengl4.5 中文手册—D

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W D glDebugMessageCallback 4.3+ 设置opengl调试信息回调 DEBUGPROC callback, void * userParam 用户自定义参数 DEBUGPROC定义: typedef void (APIENTRY *DEBUGP

Opengl4.5 中文手册—E

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W E glEnable 除了GL_DITHER and GL_MULTISAMPLE默认为GL_TRUE,其它默认均为GL_FALSE GL_BLEND 颜色混合,通过glBlendFunc控制混合参数 GL_CLIP_DISTANCE i 3.0+ 启用距离裁剪,顶

Opengl4.5 中文手册—F

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W F glFenceSync? 3.2+ 当前gl 命令流中创建同步对象 GLenum condition, : GL_SYNC_GPU_COMMANDS_COMPLETE GLbitfield flags : 0 服务端和客户端可通过glWaitSync\glCli

Opengl4.5 中文手册—G

索引 A      B    C      D     E     F     G H      I      L     M     N O      P    Q      R     S     T U      V    W G 本部分含很多get函数,大部分用于获取当前设置的状态值,基本上不会用到 glGenBuffers 2.0 GLsizei n, GLuint * buffers 生成n个未使用的缓冲区对象名称,之后可通过glBindBuffer与缓冲区对象关联. glGener

《开源分享1》:前端开发必备《Html-CSS中文手册》

一直想做一些优秀的资源分享内容,今天尝试整理了一下,以后会每天抽点时间发一些自认为不错的资料出来.帮助大家提高学习效率. 今天分享的内容:前端开发:<Html-CSS中文手册>! 本手册针对的是已有一定网页设计制作经验的读者.其目的是提供完整清晰的样式表内容的快速索引及进阶帮助.所以对于网页制作和样式表的基础知识,仅简单介绍,恕不赘述. 手册提供了完整的 CSS2.0 的属性(Properties).规则(At-Rules).伪类(Pseudo-Classes).伪元素(Pseudo-Elem