一、一些概念:

GLTools: 一些有用且可复用的函数

GLEW: OpenGL API的一些扩展机制

GLUT: OpenGL Utility toolkit, OpenGL跨平台相关,隐藏平台相关细节

RC代表渲染环境(Rendering Context),是运行中的OpenGL状态机句柄

固定渲染模式限制了开发者的自由,目前一般都是采用核心模式(Core-profile)。

跨距Stride

可以用2个数组分别描述位置和颜色信息,这样必须保证两个数组中顶点的位置和颜色是否一一对应。

除了这种方式,还可以选择一个数组存储两种信息的方式:“顶点1位置+顶点1颜色+顶点2位置+顶点2颜色+”,这样就引出了跨距的概念,即一个顶点和颜色占用的空间个数之和。

OpenGL的操作方式

由跨距可以看出,OpenGL操作时,一般都是将所需的数据准备好,然后调用glDrawElements函数一次绘制完成,而不是通过某个函数一个顶点一个顶点的去渲染,这是OpenGL渲染的一个特点。

二、开发重点

1. 顶点着色器

每个顶点执行一次,比如我们绘制一个线段,包含了2个顶点,那就是执行2次顶点着色器。我们传递给顶点着色器的数据不仅包含了每个顶点的位置,也包含颜色

2. 片段着色器

3. 将数据传递给着色器

顶点和片段着色器用于描述如何绘制图形图像的环节;

GLSL:OpenGL编写着色器具体实现的编程语言;

三、归一化坐标

顶点的归一化坐标是[-1,1];

纹理的归一化坐标是[0,1],两位维度分别是S、T,一般称为ST纹理坐标或UV坐标;如果设置的纹理坐标小于1,意思是将纹理的一小部分贴到顶点坐标中去;大于1,纹理边界将会拉伸。

纹理坐标方向性在Android上与我们平时熟悉的Bitmap、Canvas等一致,都是顶点在左上角。

四、纹理

1. 纹理:在OpenGL中简单理解就是一张图片

2. 纹理ID:纹理的直接引用

3. 纹理单元:纹理的操作容器,有GL_TEXTURE0、GL_TEXTURE1、GL_TEXTURE2等,纹理单元的数量是有限的,最多16个。所以最多只能同时操作16个纹理。在切换使用纹理单元的使用,使用glActiveTexture方法。

4. 纹理目标:一个纹理单元中包含了多个类型的纹理目标,有GL_TEXTURE_1D,GL_TEXTURE_2D等

5. 纹理ID与纹理单元的关系

OpenGL要操作一个纹理,那么是将纹理ID装进纹理单元这个容器里,然后再通过操作纹理单元的方式去实现。

OpenGL的大部分纹理一般都只接受RGBA类型的数据,如果不是RGBA,比如YUV420P格式,可以在显卡中进行转换。

五、glDrawArrays顶点法和glDrawElements索引法的绘制区别

1. glDrawArrays只能是依次输入所绘制的每个三角形的每个数据,而glDrawElements需要输入每个定点(无需重复),外加一个绘制时的索引数组。

glDrawArrays传输或指定的数据是最终的真实数据,在绘制时效能更好;

glDrawElements指定的是真实数据的调用索引,在内存/显存占用上更节省;

glDrawArrays的数据空间损耗在顶点定义处;glDrawElements的数据空间损耗在顶点索引的定义处;

2. 适用情况

如果顶点复用情况较少,可以采用glDrawArrays;如果顶点复用情况多,画的图形较多,而且大不相同的时候,优先采用glDrawElements。

顶点法内存计算方式:顶点数 * 顶点属性数 * 顶点数据格式类型;

索引法内存计算方式:顶点数 * 顶点属性数 * 顶点数据格式类型 + 索引数 * 索引数据格式类型

3. 输入坐标时一定要输入完整,比如带.0f。

4. draw mode

比较关键的一个参数,2D绘制一般采用GL_TRIANGLE_STRIP或GL_TRIANGLE_FAN。

GL_TRIANGLE_STRIP:相邻3个点构成一个三角形,不包括首位两个点,例如ABC、BCD、CDE、DEF

GL_TRIANGLE_FAN:第一个点和之后所有相邻的2个点构成一个三角形,例如ABC、ACD、ADE、AEF

六、纹理

1. 环绕方式

GL_CLAMP_TO_EDGE:纹理坐标会被约束在0到1之间,超出的部分会重复纹理坐标的边缘,产生一种边缘被拉伸的效果

GL_REPEAT:对纹理的默认行为。重复纹理图像。

2. 纹理过滤

GL_NEAREST邻近过滤,是OpenGL默认的纹理过滤方式。当设置为GL_NEAREST的时候,OpenGL会选择中心点最接近纹理坐标的那个像素。

GL_LINEAR线性过滤,它会基于纹理坐标附近的纹理像素,计算出一个插值,近似出这些纹理像素之间的颜色。

OpenGL笔记(一) 绘制三角形的更多相关文章

  1. Android OpenGL 入门示例----绘制三角形和正方形

    Android上对OpenGl的支持是无缝的,所以才有众多3D效果如此逼真的游戏,在Camera的一些流程中也有用到GLSurfaceView的情况.本文记录OpenGL在Android上的入门级示例 ...

  2. Linux OpenGL 实践篇-3 绘制三角形

    本次实践是绘制两个三角形,重点理解顶点数组对象和OpenGL缓存的使用. 顶点数组对象 顶点数组对象负责管理一组顶点属性,顶点属性包括位置.法线.纹理坐标等. OpenGL缓存 OpenGL缓存实质上 ...

  3. iOS OpenGL ES简单绘制三角形

    OpenGL 是用于2D/3D图形编程的一套基于C语言的统一接口. windows,Linux,Unix上均可兼容. OpenGL ES 是在OpenGL嵌入式设备上的版本, android/iOS ...

  4. Android OpenGL ES(十)绘制三角形Triangle .

    三角形为OpenGL ES支持的面,同样创建一个DrawTriangle Activity,定义6个顶点使用三种不同模式来绘制三角形: float vertexArray[] = { -0.8f, - ...

  5. OpenGL学习(2)——绘制三角形

    在创建窗口的基础上,添加代码实现三角形的绘制. 声明和定义变量 在屏幕上绘制一个三角形需要的变量有: 三角形的三个顶点坐标: Vertex Buffer Object 将顶点数据存储在GPU的内存中: ...

  6. opengl绘制三角形

    顶点数组对象:Vertex Array Object,VAO 顶点缓冲对象:Vertex Buffer Object,VBO 索引缓冲对象:Element Buffer Object,EBO或Inde ...

  7. 1.opengl绘制三角形

    顶点数组对象:Vertex Array Object,VAO,用于存储顶点状态配置信息,每当界面刷新时,则通过VAO进行绘制. 顶点缓冲对象:Vertex Buffer Object,VBO,通过VB ...

  8. OpenGL学习(2)——绘制三角形(补)

    对上一篇的补充,通过绘制三角形来完成矩形的绘制.此外,完成章节后练习. 绘制矩形 一个矩形由两个三角形组成,因此绘制矩形需要绘制两个三角形,一共6个顶点,其中2个顶点重复画了两次. 为了减小开销,仅储 ...

  9. CSS学习笔记(8)--纯CSS绘制三角形(各种角度)

    纯CSS绘制三角形(各种角度) CSS三角形绘制方法,学会了这个,其它的也就简单.   我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多 ...

  10. OpenSceneGraph 笔记--如何导出三角形数据

    OpenSceneGraph 笔记--如何导出三角形数据 转载:http://blog.csdn.net/pizi0475/article/details/5384389 在OpenSceneGrap ...

随机推荐

  1. bzoj3167 [Heoi2013]Sao

    传送门 这题神坑啊……明明是你菜 首先大家都知道原题等价于给每个点分配一个$1$~$n$且两两不同的权值,同时还需要满足一些大于/小于关系的方案数. 先看一眼数据范围,既然写明了$n\le 1000$ ...

  2. cf1000F. One Occurrence(线段树 set)

    题意 题目链接 Sol (真后悔没打这场EDU qwq) 首先把询问离线,预处理每个数的\(pre, nxt\),同时线段树维护\(pre\)(下标是\(pre\),值是\(i\)),同时维护一下最大 ...

  3. [微信小程序] 微信小程序富文本-wxParse的使用

    最近小程序蛮火的,公司要做于是学了一点点小程序 不知道你们有没有遇到过这种问题: 从公司服务器获取的文章内容是有HTML标签格式的一段内容,但是微信是不支持这些标签的,怎么办呢? 1.一般网站后台的文 ...

  4. Android sdcard之read-only

    AndroidManifest.xml是否加入了SDCard的权限设置 <!-- 创建与删除文件权限 --> <uses-permission android:name=" ...

  5. 那些年vue踩过的坑

    1.前言 学习Vue前端框架已经一个月了,作为一个web刚入门的菜鸟,在学习的过程中,网上有些技术博客往往没有什么可以借鉴的地方,在这里 我特意将我从开始一直到登录的过程记录下来.希望看到我的文章的朋 ...

  6. Android Toast:是一个类,主要管理消息的提示

    Toast:是一个类,主要管理消息的提示.makeText(),是Toast的一个方法,用来显示信息,分别有三个参数.第一个参数:this,是上下文参数,指当前页面显示第二个参数:“string st ...

  7. 一:JavaWeb和Tomcat的安装

    1.Java Web 是java技术用来解决相关web互联网领域的技术总和. 2.Servlet是Java Servlet的简称,称为小服务程序或服务器连接器,用Java编写的服务器端程序 3.JSP ...

  8. leetCode题解之寻找string中最后一个word的长度

    1.题目描述 返回一个 string中最后一个单词的长度.单词定义为没有空格的连续的字符,比如 ‘a’,'akkk'. 2.问题分析 从后向前扫描,如果string是以空格‘  ’结尾的,就不用计数, ...

  9. STL中set和map

    set 可以认为是数学上的集合,集合中的元素不允许有重复.set特有的操作是高效的插入.删除和执行基本查找. set的插入方法是 insert,由于集合元素的唯一性,insert操作不一定会成功,in ...

  10. npm run dev时报错“events.js:160 throw er; // Unhandled 'error' event”

    经查,此问题由端口占用导致,node服务器默认端口8080已被其他程序占用,关闭占用端口的程序或者修改node服务器的默认端口即可解决此问题