Chapter5 基础纹理

Contents:
====================================================

| 任务     | 使用的函数
====================================================
| 载入纹理图像 | glTexImage / glTexSubImage
====================================================

| 设置纹理贴图参数 | glTexParameter
====================================================
| 管理多重纹理 | glGenTextures / glDeleteTextures / glBindTexture
====================================================
| 生成Mip贴图 | glGenerateMipmap
====================================================
| 使用各向异性过滤 | glGetFloatv / glTexParameter
====================================================
| 载入压缩纹理 | glCompressedTexImage / glCompressedTexSubImage
====================================================

5.1.1 像素包装
在默认情况下,OpenGL采用4个字节的对齐方式。
我们在向OpenGL提交图像数据或从OpenGL获取图像数据时,OpenGL需要知道我们想要在内存中对数据进行怎样的包装或解包装操作。

我们可以使用下列函数改变或者回复像素的存储方式。
void glPixelStorei(GLenum pname, GLint param);
void glPixelStoref(GLenum pname, GLfloat param);

glPixelStorei(GL_UNPACK_ALIGNMENT, 1); 其中GL_UNPACK_ALIGNMENT指定OpenGL如何从数据缓存区中解包图像数据。

GL_PACK_ALIGNMENT : 告诉OpenGL如何将从像素缓冲区中读取并放置到一个用户指定的内存缓冲区的数据进行包装.

5.1.2 像素图
void glReadPixels(GLint x, GLint y ,GLSizei width, GLSizei height, GLenum format, GLenum type, const void *pixels);

5.1.3 包装的像素格式
默认情况下,对于GLReadPixels函数来说,读取操作在双缓冲区渲染环境下将在后台缓存区进行,而在单缓存区渲染环境下则在前台缓存区进行。我们可以使用下面函数改变这些像素操作的源。
void glReadBuffer(GLenum mode);
mode : GL_FRONT GL_BACK GL_LEFT GL_RIGHT GL_FRONT_LEFT GL_FRONT_RIGHT GL_BACK_LEFT GL_BACK_RIGHT 或者 GL_NONE

5.1.4 保存像素
GLTools库中的gltWirteTGA函数从前台颜色缓存区找那个读取颜色数据,并将这个数据存储到一个Targa文件格式的图形文件中。

GLint glWriteRGA(const char *szFileName)
{
FILE *pFile;
TGAHEADER tgaHeader;
unsigned long lImageSize;
GLbyte *pBits = NULL;
GLint iViewport[4];
GLenum lastBuffer;

//get viewport size
glGetIntegerv(GL_VIEWPORT, iViewport);

lImageSize = iViewport[2] * 3 * iViewport[3];

//alloc block
pBits = (GLbyte*)malloc(lImageSize);
if(pBits == NULL)
return 0;

//read from color buffer
glPixelStorei(GL_PACK_ALIGMENT, 1);
glPixelStorei(GL_PACK_ROW_LENGTH, 0);
glPixelStorei(GL_PACK_SKIP_ROWS, 0);
glPixekStorei(GL_PACK_SKIP_PIXELS, 0);

//获取当前读取缓冲区设置并进行保存
//切换到前台缓冲区并进行读取操作,最后恢复读取缓存区状态
glGetIntegerv(GL_READ_BUFFER, &lastBuffer);
glReadBuffer(GL_FRONT);
glReadPixels(0, 0, iViewport[2], iViewport[3], GL_BRG, GL_UNSIGNED_BYTE, pBits);
glReadBuffer(lastBuffer);

//初始化Targa头
⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯

//open file
pFile = fopen(szFileName, "wb");
if(pFile == NULL)
{
free(pBits);
return 0;
}

fwrite(&tgaHeader, sizeof(TGAHEADER), 1, pFile);
fwirte(pBites, lImageSize, 1, pFile);

free(pBits);
fclose((pFile);

return 1;
}

5.1.5 读取像素
从磁盘中载入Targa文件的函数
GLbyte *gltReadRGABits(const char* szFileName, GLint *iWidth, GLint *iHeght, GLint *iComponents, GLenum *eFormat);

5.2 载入纹理
void glTexImage1D(GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border,GLenum format,GLenum type, void *data);
void glTexImage2D(GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border,GLenum format,GLenum type, void *data);
void glTexImage3D(GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border,GLenum format,GLenum type, void *data);
【param】
target : GL_TEXTURE_1D,GL_TEXTURE_2D,GL_TEXTURE_3D我们也可以指定代理GL_PROXY_TEXTURE_1D,⋯⋯并使用glGetTexParameter函数提取代理查询的结果
level: mip贴图层次

5.2.1 使用颜色缓冲区

一维和二维纹理也可以从颜色缓冲区加载数据。
void glCopyTexImage1D(GLenum target, GLint level, GLenum internalformat,GLint x, GLint y, GLsizei width, GLint border);
void glCopyTexImage2D(GLenum target, GLint level, GLenum internalformat,GLint x, GLint y, GLsizei width, GLint border);
void glCopyTexImage3D(GLenum target, GLint level, GLenum internalformat,GLint x, GLint y, GLsizei width, GLint border);

从颜色缓冲区读取纹理,并插入或替换原来纹理的一部分。
void glCopyTexSubImage1D(GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width);
⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯

5.2.2 纹理对象
void glGenTextures(GLsizei n, GLuint *textures);
n: 纹理对象数量
texutres: 纹理对象指针

绑定纹理状态:
void glBindTexure(GLenum target, GLuint texture);
target: GL_TEXTURE_1D,GL_TEXTURE_2D或GL_TEXTURE_3D
texture: 需要绑定的特定纹理对象
此后,所有的纹理加载和纹理参数设置只影响当前绑定的纹理对象

删除纹理对象:
void glBindTexure(GLsizei n,GLuint *texture);

判断纹理对象(句柄)有效性:
GLboolean glIsTexture(GLuint texture);

5.3 纹理应用

5.3.1 纹理坐标

5.3.2 纹理参数
很多参数的应用都会影响渲染的规则和纹理贴图的行为;
void glTexParameterf(GLenum target, GLenum pname, GLfloat param);
void glTexParameteri(GLenum target, GLenum pname, GLfloat param);
void glTexParameterfv(GLenum target, GLenum pname, GLfloat param);
void glTexParameteriv(GLenum target, GLenum pname, GLfloat param);

基本过滤:
根据一个拉伸或收缩的纹理贴图计算颜色片段的过程称为纹理过滤(Texture Fililtering).使用OpenGL的纹理参数函数,可以同时设置放大和缩小过滤器。这两种过滤器的参数名分别是
GL_TEXTURE_MAG_FILTER 和 GL_TEXTURE_MIN_FILTER。
我们可以从两种基本的过滤器GL_NEAREST 和GL_LINEAR中进行选择。

使用最邻近过滤的一个列子。使用下面两个函数,为放大和缩小过滤器设置纹理过滤器
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);

线性过滤器:
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);

纹理环绕:

OpenGL chapter5 基础纹理的更多相关文章

  1. Android OpenGL ES(八)----纹理编程框架

    1.把纹理载入进OpenGL中 我们的第一个任务就是把一个图像文件的数据载入到一个OpenGL的纹理中. 作为開始.让我们又一次舍弃第二篇的框架.又一次创建一个程序,新建一个util工具包,在该包下创 ...

  2. Linux OpenGL 实践篇-5 纹理

    纹理 在之前的实践中,我们所渲染的物体的表面颜色都是纯色或者根据顶点位置计算出的一个颜色,这种方式在表现物体细节方面是比较吃资源的,因为我们每增加一个细节,我们就需要定义更多的顶点及其属性.所以美术人 ...

  3. OpenGL 多线程共享纹理

    1:opengl 多线程共享纹理纹理: //解码时候使用opengl进行绘制,需要构建队列和两个线程,分别用于解码数据并且填充纹理和渲染. 主线程常见两个共享上下文: main() { ⋯⋯⋯⋯ gH ...

  4. Unity Shader入门精要学习笔记 - 第7章 基础纹理

    转自 冯乐乐的 <Unity Shader 入门精要> 纹理最初的目的就是使用一张图片来控制模型的外观.使用纹理映射技术,我们可以把一张图“黏”在模型表面,逐纹素地控制模型的颜色. 在美术 ...

  5. 【Unity Shader学习笔记】Unity基础纹理-单张纹理

    1 单张纹理 1.1 纹理 使用纹理映射(Texture Mapping)技术,我们把一张图片逐纹素(Texel)地控制模型的颜色. 美术人员建模时,会在建模软件中利用纹理展开技术把纹理映射坐标(Te ...

  6. Opengl ES之纹理贴图

    纹理可以理解为一个二维数组,它可以存储大量的数据,这些数据可以发送到着色器上.一般情况下我们所说的纹理是表示一副2D图,此时纹理存储的数据就是这个图的像素数据. 所谓的纹理贴图,就是使用Opengl将 ...

  7. 04: OpenGL ES 基础教程03 纹理

    前言 1:常用类: 1:纹理的作用 正文 一:常用类 上下文 顶点数据缓存 着色器 baseEffect 一:纹理 1.1:   纹理可以控制渲染的每个像素的颜色. 1.2: 纹素:与像素一样,保存每 ...

  8. 2.x最终照着教程,成功使用OpenGL ES 绘制纹理贴图,添加了灰度图

    在之前成功绘制变色的几何图形之后,今天利用Openg ES的可编程管线绘制出第一张纹理. 学校时候不知道OpenGL的重要性,怕晦涩的语法.没有跟老师学习OpenGL的环境配置,现在仅仅能利用coco ...

  9. OpenGL chapter3 基础渲染

    3.1 基础图形管线 三种向OpenGl着色器传递渲染数据的方法:属性,Uniform和纹理.3.2 创建坐标系 3.2.1 正投影 GLFrustum::SetOrthographic(⋯⋯): 3 ...

随机推荐

  1. python 学习日志

    1.pip is already installed if you're using Python 2 >=2.7.9 or Python 3 >=3.4 binaries downloa ...

  2. nw 注册快捷键

    var option = { key : "Escape", }; var shortcut = new gui.Shortcut(option); gui.App.registe ...

  3. css实现垂直居中的几种方法

    方法1.这个方法把一些 div 的显示方式设置为表格,因此我们可以使用表格的 vertical-align 属性. #wrapper { //代表父元素 display: table; } #cell ...

  4. E - 追求

    经历了那晚的竹林深处相识后静竹对数学念念不忘,产生了好感!为了追求数学,她想到了一招,要想搞定女友,搞定闺中密友.于是,她秘密与数学的好友斐波那契见面了.学数学的真是不一样,斐波那契的出现前提也是需要 ...

  5. 图片和span水平垂直居中

    <style type="text/css"> .content{ width:20%; height:60px; border:1px solid red; text ...

  6. c++  与  java  中的 继承

    C++ 代码: #include <iostream> #include <string> using namespace std; class Parent { public ...

  7. 最短路--spfa+队列优化模板

    spfa普通版就不写了,优化还是要的昂,spfa是可以判负环,接受负权边和重边的,判断负环只需要另开一个数组记录每个结点的入队次数,当有任意一个结点入队大于点数就表明有负环存在 #include< ...

  8. EXCEL函数LookUp, VLOOKUP,HLOOKUP应用详解(含中文参数解释)

    关于VLOOKUP函数的用法 “Lookup”的汉语意思是“查找”,在Excel中与“Lookup”相关的函数有三个:VLOOKUP.HLOOKUO和LOOKUP.下面介绍VLOOKUP函数的用法. ...

  9. linux 知识点

    关于登录Linux时,/etc/profile.~/.bash_profile等几个文件的执行过程. 在登录Linux时要执行文件的过程如下: 在刚登录Linux时,首先启动 /etc/profile ...

  10. 二、Jmeter录制脚本过程及Could not create script recorder报错、您的连接不是私密连接报错

    两个报错:Could not create script recorder报错和您的连接不是私密连接报错 1.录制过程 * 打开jmeter * 点击Templated,选择Recoding模版 * ...