1、OpenGL对共享的边有严格的规定:1)共享边上的像素因为同事被两者所覆盖,因此不可能不受到光照计算的影响;

2)共享边上的像素值,不可能受到多于一个三角形的光照计算的影响。

2、多边形存在正面与反面,为了能够明显地观察多边形的顶点,可以使用void glPolygonMode(GLenum face,GLenum mode)设置绘制方式

face必须是GL_FRONT_AND_BACK,mode可以是GL_POINT、GL_LINE、GL_FILL,默认使用的是GL_FILL 填充模式。

3、OpenGL缓存类型

4、向缓存写入数据

1)void glBufferData(GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage);是在分配缓存内存用的时候写入数据,如果data为nullptr,那么就是仅仅分配了内存。

2)void glBufferSubData(GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data);相对于上面整个缓冲地写入数据,这个方法只是从offset开始写入size大小的数据。

3)如果只是希望将缓存对象的数据清除为一个一直的值,可以使用如下方法

void glClearBufferData(GLenum target, GLenum internalformat, GLenum format, GLenum type, const GLvoid* data)

void glClearBufferSubData(GLenum target, GLenum internalformat, GLintptr offset, GLsizeiptr size, GLenum format, GLenum type, const GLvoid* data)

4)缓存中的数据可以互相拷贝

void glCopyBufferSubData(GLenum readtarget, GLenum writetarget, GLintptr readoffset, GLintptr writeoffset, GLsizeiptr size)

5、void glGetBufferSubData(GLenum target, GLintptr offset, GLsizeiptr size, GLvoid* data)这个方法能够将绑定的缓存目标中的数据读取到data指定的内存中。

6、上面介绍的众多方法都有一个问题,都会对指定的数据进行一次拷贝,下面的这个方法将会返回一个指向目标内存的指针

void* glMapBuffer(GLenum target, GLenum access)

GLboolean glUnmapBuffer(GLenum target) 如果在映射后target没有发生损坏,将会返回GL_TRUE;发生损坏的原因通常与系统相关,例如屏幕模式发生变化,这将影响图形内容的可用性。

7、使用glBufferData 或 glBufferSubData 返回后,可以对返回的内存区域中的数据进行任何操作。也就是说,这些函数在完成后不能与内存区域再有任何瓜葛,因此需要采用数据拷贝的方式。如果使用glMapBuffer,返回的指针是OpenGL端管理,调用glUnmapBuffer时,OpenGL依然管理这个指针指向的内存,而应用程序与这出内存已经没有任何瓜葛。这样的话即使数据需要移动或者拷贝,也是调用glUnmapBuffer之后才执行并且立即返回,而内容操作是在系统的空闲时间之内完成,不在受应用程序的影响。因此,OpenGL的数据拷贝操作与应用程序之后的操作实际上是同步进行的。

8、void* glMapBufferRange(GLenum target, Glintptr offset, GLsizeiptr length, GLbitfield access)是相对于上面有着更为严格访问限制的映射方式。

9、丢弃缓存数据,使得OpenGL能够完成一些优化工作,如内存紧密等

void glInvalidateBufferData(Gluint buffer)

void glInvalidateBufferSubData(GLuint buffer, GLintptr offset, Glsizeiptr length)是唯一一个可以抛弃缓存对象中区域数据的方法。

10、绘制命令分为两种:索引形式与非索引形式。所谓的索引意图是在三角形顶点重复的时候通过使用顶点数组中索引来避免顶点数组找那个存在相同的顶点数据。

void glDrawArrays(GLenum mode, GLint first, GLsizei count)

void glDrawElements(GLenum mode, GLsizei count, GLenum type, const GLvoid* indices)

有许多的绘制命令都是通过以上两个实现的。

存在两个特殊的绘制命令,它们的绘制参数不是从程序中得到,而是从缓存对象中获得,称之为间接绘制函数。

1) void glDrawArraysIndirect(GLenum node, const GLvoid* indirect)

使用它时,必须要将一个缓存对象绑定到GL_DRAW_INDIRECT_BUFFER上,它的特性与glDrawArraysInstanced完全一致。间接绘制缓存的 C 结构体形式如下

typedef struct DrawArraysIndirectCommand_t

{

GLuint count;

GLuint primCount;//表示多实例的个数

GLuint first;

GLuint baseInstance;//多实例顶点属性的偏移

} DrawArraysIndirectCommand;

2)void glDrawElementsIndirect(GLenum mode, GLenum type, const GLvoid* indirect)

它的特性与glDrawElements一致,使用限制也是一样的。

typedef struct DrawElementsIndirectCommand_t

{

GLuint count;

GLuint primCount;

GLuint firstIndex;

GLuint baseVertex;

GLuint baseInstance;

} DrawElementsIndirectCommand;

11、多实例渲染最大的不同在于需要启用多实例顶点属性 void glVertexAttribDivisor(GLuint index, GLuint divisor) 完成这项工作。divisor的值如果是0,那么该属性的多实例特性将被禁用,如果是其它值则是多实例点顶属性的间隔;index表示的是顶点属性的索引位置。vertex shader内存在对应实例id的内置变量 gl_InstanceID,从0开始累加,非多实例渲染时这个值一直保持为0。

OpenGL 编程指南 (2)的更多相关文章

  1. OpenGL编程指南(第七版)

    OpenGL编程指南(第七版) 转自:http://blog.csdn.net/w540982016044/article/details/21287645 在接触OpenGL中,配置显得相当麻烦,特 ...

  2. 编译opengl编程指南第八版示例代码通过

    最近在编译opengl编程指南第八版的示例代码,如下 #include <iostream> #include "vgl.h" #include "LoadS ...

  3. VS15 openGL 编程指南 配置库 triangle例子

    最近去图书馆借了一本书<OpenGL编程指南(原书第八版)>,今天倒腾了一天才把第一个例子运行出来. 所以,给大家分享一下,希望能快速解决配置问题. 一.下载需要的库文件 首先,我们需要去 ...

  4. [转]OpenGL编程指南(第9版)环境搭建--使用VS2017

    1.使用CMake Configure中选择VS2017 Win64 , Finish: 点击Generate. 2.进入build目录 打开GLFW.sln , 生成解决方案. 打开vermilio ...

  5. opengl编程指南

    第一章 opengl简单介绍 1.1 什么是opengl opengl是图形硬件的一种软件接口.        1>渲染(rendering)是计算机依据模型创建图像的过程. 2>模型(m ...

  6. OpenGL编程指南第版本学习笔记 --- OpenGL程序实现过程(win32 + OpenGL)

    1. 先上代码 头文件glCommon.h #include <GL/glew.h> #include <GL/GL.h> #include <GL/GLU.h> ...

  7. OpenGl编程指南第7版(红宝书)环境配制

    环境 OS:win7 旗舰版SP1 64位 编译器: VS 2013 express 的cl 软件 glut. 在这个页面https://www.opengl.org/resources/librar ...

  8. OpenGL编程指南(第九版) Tiangles 学习笔记

    ////////////////////////////////////////////////////////////////////////////// // // Triangles.cpp / ...

  9. 《OpenGL编程指南第七版》学习——编译时提示“error C2381: “exit” : 重定义;__declspec(noreturn) 不同”错误的解决办法

    解决办法一. #if defined(_WIN32) # ifndef GLUT_BUILDING_LIBextern _CRTIMP void __cdecl exit(int); 上面是glut. ...

  10. Opengl编程指南第二章:状态管理、几何绘图

    //http://blog.csdn.net/longhuihu/article/details/7701874 1.绘图基础 清除窗口 glClearColor(0.0, 0.0, 0.0, 0.0 ...

随机推荐

  1. Node.js文档-path

    用于处理文件路径和目录路径 引入 const path = require('path') path.extname(path) 返回扩展名.从最后一次出现 . 字符到字符串结束. const pat ...

  2. 学习使用add()()()迭代调用,柯里化处理

    将多个参数的函数,转换成单参数函数链 以add()()()举例 function add(){ 使用数组保存参数 let _args = Array.prototype.slice.call(argu ...

  3. 流程图GGEditor 之 自定义节点相关属性

    自定义节点 注册 -- registerNode 我们通过以下接口往 G6 全局注册节点: // 注册节点 G6.registerNode(name, { // 绘制 draw(item) {   r ...

  4. Java 代码块详解

    注:本文出自博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 注:本文原链接:https://www.cnblogs.com/chloneda/p/java-c ...

  5. 使用ASP.NET Core 3.x 构建 RESTful API - 5.1 输入验证

    说到验证,那就需要做三件事: 定义验证规则 按验证规则进行检查 报告验证的错误.在把错误报告给API消费者的时候,报告里并不包含到底是服务端还是API消费者引起的错误,这是状态码的工作.而通常响应的B ...

  6. redis缓存优化

    redis缓存优化 一.问题 在Javaweb项目中,如果每次刷新,所有资源都重新从数据库中读取,这样每次效率会很低,在这里可以使用redis非关系型数据库,将一些不经常变化得资源加载进内存中.提高效 ...

  7. Fhq Treap [FhqTreap 学习笔记]

    众所周知 Fhq Treap 是 fhq 神仙研究出来的平衡树- 具体实现 每个点实现一个 \(\text{rnd}\) 表示 rand 的值 为什么要 rand 呢 是为了保证树高为 \(\log ...

  8. 论文-MobileNetV2: Inverted Residuals and Linear Bottlenecks

    1.主要创新 1)提出了一种新的layer module:the inverted residual with linear bottleneck, 2)short connect被置于bottlen ...

  9. 在windows系统下,配置vue项目一键启动文件

    我的项目由客户端.后台管理.数据库和服务器三部分组件,每次启动项目都要一个一个启动,挺麻烦的,现在写一个.bat文件来批处理命令. 这个是我的启动文件内容. 第一行运行的我wampServer服务器, ...

  10. LOJ #6402. yww 与校门外的树 多项式求逆

    蛮神的一道题. code: #include <cmath> #include <cstring> #include <algorithm> #include &l ...