OpenGL缓冲对象:API列表

  1. OpenGL缓冲对象概念
  2. 缓冲区对象 Buffer Objects API列表

  1. 缓冲区对象 Buffer Objects
  2. 创建和绑定缓冲区对象 Creating and Binding Buffer Objects
  3. 创建缓冲对象数据存储 Creating Buffer Object Data Stores
  4. 修改缓冲对象数据存储 Modifying Buffer Object Data Stores
  5. Clear缓冲对象数据存储 Clear Buffer Object Data Stores
  6. 映射映射缓冲数据 Mapping Buffer Data
  7. 刷新映射缓冲数据 Flush Buffer Data
  8. 取消映射缓冲数据 Unmapping Buffer Data
  9. 使缓冲区数据无效 Invalidating Buffer Data
  10. 缓冲区间复制 Copying Between Buffers
  11. 缓冲对象查询 Buffer Object Queries

缓冲区对象 Buffer Objects

void glGenBuffers( sizei n, uint *buffers );

void glCreateBuffers( sizei n, uint *buffers );

void glDeleteBuffers( sizei n, const uint *buffers );

boolean glIsBuffer( uint buffer );
  • 创建和绑定缓冲区对象 Creating and Binding Buffer Objects
void glBindBuffer( enum target, uint buffer );
void glBindBufferRange( enum target, uint index,uint buffer, intptr offset, sizeiptr size );

void glBindBufferBase( enum target, uint index, uint buffer );

void glBindBuffersBase( enum target, uint first, sizei count, const uint *buffers );
// 等价于
// for (i = 0; i < count; i++) {
//     if (buffers == NULL) {
//         glBindBufferBase(target, first + i, 0);
//     } else {
//         glBindBufferBase(target, first + i, buffers[i]);
//     }
// }

void glBindBuffersRange( enum target, uint first,sizei count, const uint *buffers, const intptr *offsets, const sizeiptr *sizes );
// 等价于
// for (i = 0; i < count; i++) {
//     if (buffers == NULL) {
//         glBindBufferRange(target, first + i, 0, 0, 0);
//     } else {
//         glBindBufferRange(target, first + i, buffers[i],offsets[i], sizes[i]);
//     }
// }
  • 创建和修改缓冲对象数据存储 Creating and Modifying Buffer Object Data Stores
void glBufferStorage( enum target, sizeiptr size, constvoid *data, bitfield flags );

void glNamedBufferStorage( uint buffer, sizeiptr size,const void *data, bitfield flags );

void glBufferData( enum target, sizeiptr size, constvoid *data, enum usage );

void glNamedBufferData( uint buffer, sizeiptr size, constvoid *data, enum usage );

void glBufferSubData( enum target, intptr offset,sizeiptr size, const void *data );

void glNamedBufferSubData( uint buffer, intptr offset,sizeiptr size, const void *data );
void glClearBufferSubData( enum target, enum internalformat, intptr offset, sizeiptr size, enum format, enum type, const void *data );

void glClearNamedBufferSubData( uint buffer,enum internalformat, intptr offset, sizeiptr size, enum format, enum type, const void *data );

void glClearBufferData( enum target, enum internalformat,enum format, enum type, const void *data );
// 等价于
// glClearBufferSubData(target, internalformat, 0, size, format, type, data);

void glClearNamedBufferData( uint buffer,enum internalformat, enum format, enum type, constvoid *data );
// 等价于
// glClearNamedBufferSubData(buffer, internalformat, 0, size, format, type, data);
  • 映射和取消映射缓冲数据 Mapping and Unmapping Buffer Data
void *glMapBufferRange( enum target, intptr offset,sizeiptr length, bitfield acesss );

void *glMapNamedBufferRange( uint buffer, intptr offset,sizeiptr length, bitfield access );

void *glMapBuffer( enum target, enum access );
// 等价于
// glMapBufferRange(target, 0, length, flags);

void *glMapNamedBuffer( uint buffer, enum access );
// 等价于
// glMapNamedBufferRange(buffer, 0, length, flags);

void glFlushMappedBufferRange( enum target, intptr offset,sizeiptr length );

void glFlushMappedNamedBufferRange( uint buffer,intptr offset, sizeiptr length );

boolean glUnmapBuffer( enum target );

boolean glUnmapNamedBuffer( uint buffer );
  • 使缓冲区数据无效 Invalidating Buffer Data
void glInvalidateBufferSubData( uint buffer, intptr offset,sizeiptr length );

void glInvalidateBufferData( uint buffer );
// 等价于
// glInvalidateBufferSubData( buffer, 0, BUFFER_SIZE );
  • 缓冲区间复制 Copying Between Buffers
void glCopyBufferSubData( enum readTarget, enum writeTarget,intptr readOffset, intptr writeOffset, sizeiptr size );

void glCopyNamedBufferSubData( uint readBuffer,uint writeBuffer, intptr readOffset, intptr writeOffset,sizeiptr size );
  • 缓冲对象查询 Buffer Object Queries
void glGetBufferParameteriv( enum target, enum pname,int *data );

void glGetBufferParameteri64v( enum target, enum pname,int64 *data );

void glGetNamedBufferParameteriv( uint buffer,enum pname, int *data );

void glGetNamedBufferParameteri64v( uint buffer,enum pname, int64 *data );

void glGetBufferSubData( enum target, intptr offset,sizeiptr size, void *data );

void glGetNamedBufferSubData( uint buffer, intptr offset,sizeiptr size, void *data );

void glGetBufferPointerv( enum target, enum pname, const void **params );

void glGetNamedBufferPointerv( uint buffer, enum pname,const void **params );
  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
OpenGL ES 3.0 英文版 第1章——OpenGL ES 3.0简介   第1章简单介绍OpenGL ES,概述了OpenGL ES 3.0图形管线,讨论了OpenGL ES 3.0的设计理念和限制,最后介绍了OpenGL ES 3.0中使用的一些约定和类型。   第2章——你好,三角形:一个OpenGL ES 3.0示例   第2章介绍绘制三角形的一个简单OpenGL ES 3.0示例。我们的目的是说明OpenGL ES 3.0程序的样子,向读者介绍一些API概念,并说明如何构建和运行OpenGL ES 3.0示例程序。   第3章——EGL简介   第3章介绍EGL——为OpenGL ES 3.0创建表面和渲染上下文的API。我们说明与原生窗口系统通信、选择配置和创建EGL渲染上下文及表面的方法,传授足够多的EGL知识,你可以了解到启动OpenGL ES 3.0进行渲染所需的所有知识。   第4章——着色器和程序   着色器对象和程序对象OpenGL ES 3.0中最基本的对象。第4章介绍创建着色器对象、编译着色器和检查编译错误的方法。这一章还说明如何创建程序对象、将着色器对象连接到程序对象以及链接最终程序对象的方法。我们讨论如何查询程序对象的信息以及加载统一变量(uniform)的方法。此外,你将学习有关源着色器和程序二进制代码之间的差别以及它们的使用方法。   第5章——OpenGL ES着色语言   第5章介绍编写着色器所需的着色语言的基础知识。这些着色语言基础知识包括变量和类型、构造器、结构、数组、统一变量、统一变量块(uniform block)和输入/输出变量。该章还描述着色语言的某些更细微的部分,例如精度限定符和不变性。   第6章——顶点属性、顶点数组和缓冲对象   从第6章开始(到第11章为止),我们将详细介绍管线,教授设置和编程图形管线各个部分的方法。这一旅程从介绍几何形状输入图形管线的方法开始,包含了对顶点属性、顶点数组和缓冲对象的讨论。   第7章——图元装配和光栅化   在前一章讨论几何形状输入图形管线的方法之后,第7章将讨论几何形状如何装配成图元,介绍OpenGL ES 3.0中所有可用的图元类型,包括点精灵、直线、三角形、三角形条带和三角扇形。此外,我们还说明了在顶点上进行坐标变换的方法,并简单介绍了OpenGL ES 3.0管线的光栅化阶段。   第8章——顶点着色器   我们所介绍的管线的下一部分是顶点着色器。第8章概述了顶点着色器如何融入管线以及OpenGL ES 着色语言中可用于顶点着色器的特殊变量,介绍了多个顶点着色器的示例,包括逐像素照明和蒙皮(skinning)。我们还给出了用顶点着色器实现OpenGL ES 1.0(和1.1)固定功能管线的示例。   第9章——纹理   第9章开始介绍片段着色器,描述OpenGL ES 3.0中所有可用的纹理功能。该章提供了创建纹理、加载纹理数据以及纹理渲染的细节,描述了纹理包装模式、纹理过滤、纹理格式、压缩纹理、采样器对象、不可变纹理、像素解包缓冲对象和Mip贴图。该章介绍了OpenGL ES 3.0支持的所有纹理类型:2D纹理、立方图、2D纹理数组和3D纹理。   第10章——片段着色器   第9章的重点是如何在片段着色器中使用纹理,第10章介绍编写片段着色器所需知道的其他知识。该章概述了片段着色器和所有可用的特殊内建变量,还演示了用片段着色器实现OpenGL ES 1.1中所有固定功能技术的方法。多重纹理、雾化、Alpha测试和用户裁剪平面的例子都使用片段着色器实现。   第11章——片段操作   第11章讨论可以适用于整个帧缓冲区或者在OpenGL ES 3.0片段管线中执行片段着色器后适用于单个片段的操作。这些操作包括剪裁测试、模板测试、深度测试、多重采样、混合和抖动。本章介绍OpenGL ES 3.0图形管线的最后阶段。   第12章——帧缓冲对象   第12章讨论使用帧缓冲对象渲染屏幕外表面。帧缓冲对象有多种用法,最常见的是渲染到一个纹理。本章提供API缓冲对象部分的完整概述。理解帧缓冲对象对于实现许多高级特效(如反射、阴影贴图和后处理)至关重要。   第13章——同步对象和栅栏   第13章概述同步对象和栅栏,它们是在OpenGL ES 3.0主机应用和GPU执行中同步的有效图元。我们讨论同步对象和栅栏的使用方法,并以一个示例作为结束。   第14章——OpenGL ES 3.0高级编程   第14章是核心章节,将本书介绍的许多主题串联在一起。我们已经选择了高级渲染技术的一个样本,并展示了实现这些功能的示例。该章包含使用法线贴图的逐像素照明、环境贴图、粒子系统、图像后处理、程序纹理、阴影贴图、地形渲染

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值