专栏首页小黑娃HenryOpenGL(八)--纹理相关APIOpenGL(八)--纹理相关API

OpenGL(八)--纹理相关APIOpenGL(八)--纹理相关API

OpenGL(八)--纹理相关API

1. 原始图像数据

//存储图像数据所占内存大小
size = 图像的高度 * 图像的宽度 * 每个像素所占字节数
  • 像素所占字节数:一般为4Byte,包含RGBA四个通道,每个通道为1Byte(8Bit)

2. 认识函数

  • 像素存储方式
//改变像素存储方式
void glPixelStorei(GLenum pname,GLint param);
//恢复像素存储方式
void glPixelStoref(GLenum pname,GLint param);

//举例:
//参数1:GL_UNPACK_ALIGNMENT 指定OpenGL 如何从数据缓存区中解包图像 数据
//参数2:表示参数GL_UNPACK_ALIGNMENT 设置的值
//参数1为GL_UNPACK_ALIGNMENT时, 参数二:指内存中每个像素⾏起点的排列请求,允许设置为1 (byte排列)、2(排列为偶数byte的⾏)、4(字word排列)、8(⾏从双字节 边界开始)
glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
  • 将颜色缓冲区中的内容作为像素图直接使用
//参数1:x,矩形左下⻆角的窗⼝坐标
//参数2:y,矩形左下⻆角的窗⼝坐标
//参数3:width,矩形的宽,以像素为单位 //参数4:height,矩形的⾼,以像素为单位
//参数5:format,OpenGL 的像素格式,参考 表1
//参数6:type,解释参数pixels指向的数据类型,告诉OpenGL 使⽤缓存区中的什么 数据类型来存储颜⾊分量,像素数据的数据类型,参考 表2 
//参数7:pixels,指向图形数据的指针
void glReadPixels(GLint x, GLint y, GLSizei width, GLSizei height, GLenum format, GLenum type, const void * pixels);

// 指定读取的缓存 
glReadBuffer(mode); 
 // 指定写⼊入的缓存
glWriteBuffer(mode);
  • 读取图像文件
//读取TAG图像文件,OpenGL中使用,在OpenGL ES中常用的是:png、jpeg
GLbyte *gltReadTGABits(const char *szFileName, GLint *iWidth, GLint *iHeight, GLint *iComponents, GLenum *eFormat, GLbyte *pData = NULL);
  • 载入纹理(load)
//通过此方式会将创建好的纹理载入到纹理对象里。
//target:`GL_TEXTURE_1D`、`GL_TEXTURE_2D`、`GL_TEXTURE_3D`。
//level:指定所加载的mip贴图层次。⼀般我们都把这个参数设置为0。
//internalformat:每个纹理理单元中存储多少颜⾊色成分。
//width、height、depth参数:指加载纹理理的宽度、⾼高度、深度。一般使用2的整数次⽅方。(OpenGL旧版中会有这个要求)
//border:允许为纹理贴图指定⼀个边框宽度。
//format、type、data参数:与上方glReadPixels函数对于的参数相同
void glTexImage2D(GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, void * data);

void glTexImage1D(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, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, void *data);
  • 更新纹理
void glTexSubImage1D(GLenum target, GLint level, GLint xOffset, GLsizei width, GLenum format, GLenum type, const GLvoid *data);
void glTexSubImage2D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid *data);
void glTexSubImage3D(GLenum target, GLint level, GLint xOffset, GLint yOffset, GLint zOffset, GLsizei width, GLsizei height, GLsizei depth, Glenum type, const GLvoid * data);
  • 插入替换纹理
void glCopyTexSubImage1D(GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsize width);
void glCopyTexSubImage2D(GLenum target, GLint level, GLint xoffset, GLint yOffset, GLint x, GLint y, GLsizei width, GLsizei height);
void glCopyTexSubImage3D(GLenum target, GLint level, GLint xoffset, GLint yOffset, GLint zOffset, GLint x, GLint y, GLsizei width, GLsizei height);
  • 使⽤用颜⾊色缓存区加载数据,形成新的纹理理使⽤用
void glCopyTexImage1D(GLenum target, GLint level, GLenum internalformt, GLint x, GLint y, GLsizei width, GLint border);
void glCopyTexImage2D(GLenum target, GLint level, GLenum internalformt, GLint x, GLint y, GLsizei width, GLsizei height, GLint border);

// x,y 在颜⾊缓存区中指定了开始读取纹理数据的位置; 
// 缓存区⾥的数据,是源缓存区通过glReadBuffer设置的。

3. 纹理对象

  • 生成纹理对象
//使⽤函数分配纹理对象
//指定纹理对象的数量 和 指针(指针指向⼀个⽆符号整形数组,由纹理对象标识符填充)。 
void glGenTextures(GLsizei n, GLuint * textTures);
//绑定纹理状态 //参数target:GL_TEXTURE_1D、GL_TEXTURE_2D、GL_TEXTURE_3D
//参数texture:需要绑定的纹理对象
void glBindTexture(GLenum target, GLunit texture);
//删除绑定纹理对象
//纹理对象 以及 纹理对象指针(指针指向⼀个⽆符号整形数组,由纹理对象标识符填充)。
void glDeleteTextures(GLsizei n, GLuint *textures); //测试纹理对象是否有效
//如果texture是⼀个已经分配空间的纹理对象,那么这个函数会返回GL_TRUE,否则会返回GL_FALSE。 
GLboolean glIsTexture(GLuint texture);
  • 设置纹理参数
//参数1:GL_TEXTURE_1D、GL_TEXTURE_2D、GL_TEXTURE_3D 
//参数2:GL_TEXTURE_WRAP_S、GL_TEXTURE_T、GL_TEXTURE_R,针对s,t,r坐标 
//参数3: 参数2对应类型
glTexParameterf(GLenum target, GLenum pname, GLFloat param);
glTexParameteri(GLenum target, GLenum pname, GLint param);
glTexParameterfv(GLenum target, GLenum pname, GLFloat *param);
glTexParameteriv(GLenum target, GLenum pname, GLint *param);
//参数1:target,指定这些参数将要应⽤在那个纹理模式上,⽐如GL_TEXTURE_1D、GL_TEXTURE_2D、GL_TEXTURE_3D。 
//参数2:pname,指定需要设置那个纹理参数
//参数3:param,设定特定的纹理参数的值
  • 设置过滤方式

参数说明

//参数3:GL_NEAREST、GL_LINEAR
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST) //纹理缩⼩时,使用邻近过滤
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR) //纹理放大时,使⽤线性过滤
  • 邻近过滤(GL_NEAREST)

GL_NEAREST

  • 线性过滤

GL_LINEAR

  • 效果对比
  • 设置环绕方式

参数说明

//参数3:GL_REPEAT、GL_CLAMP、GL_CLAMP_TO_EDGE、GL_CLAMP_TO_BORDER
glTextParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAR_S, GL_CLAMP_TO_EDGE);
glTextParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAR_T, GL_CLAMP_TO_EDGE);
  • 环绕方式效果对比
  • OpenGL 的像素格式

表一

  • 像素数据的数据类型

表二

4. 纹理坐标

2D纹理坐标左下角为原点(0,0),右上角为(1,1)!

坐标对应关系图示

  • 在笛卡尔坐标系中为:X,Y,Z
  • 在OpenGl坐标中表示为:S,T,R
  • 一一对应,无其他区别只是命名不同而已。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • OpenGL开发库的详细介绍zz

    开发基于OpenGL的应用程序,必须先了解OpenGL的库函数。它采用C语言风格,提供大量的函数来进行图形的处理和显示。OpenGL库函数的命名方式非常有规律...

    步行者08
  • OpenGL API 简介

    开发基于 OpenGL 的应用程序,必须先了解 OpenGL 的库函数。它采用 C 语言风格,提供大量的函数来进行图形的处理和显示。OpenGL 库函数的命名方...

    用户2930595
  • OpenGL ES学习阶段性总结

    前言 最近观看下面这本书有感,结合之前的学习,对OpenGL的知识进行回顾。 ? 概念 帧缓存:接收渲染结果的缓冲区,为GPU指定存储渲染结果的区域。 ...

    落影
  • 视频直播与虚拟现实的渲染 - OpenGL ES

    这是一篇OpenGL ES的学习笔记,介绍图像绘制里面用到的概念,学习OpenGL ES的基础知识备忘录。 教程 OpenGLES入门教程1-Tutorial0...

    落影
  • 全平台硬件解码渲染方法与优化实践

    大家好,我是来自PPTV的王斌。接下来我将围绕以下几个话题,为大家分享有关全平台硬件解码的渲染与优化的实践经验。

    LiveVideoStack
  • OpenGL 从入门到成魔-第7章-纹理和纹理坐标

    注:参考自bilibili系列视频,OpenGL 从入门到成魔-第7章-纹理和纹理坐标,更详细的内容可以从视频获取https://www.bilibili.co...

    瑶瑶
  • 【Android 音视频开发打怪升级:OpenGL渲染视频画面篇】一、初步了解OpenGL ES

    提到OpenGL,想必很多人都会说,我知道这个东西,可以用来渲染2D画面和3D模型,同时又会说,OpenGL很难、很高级,不知道怎么用。

    开发的猫
  • OpenGL ES初探:渲染流程及GLKit简介

    OpenGL是一套多功能开放标准库,用于处理可视化2D和3D数据。OpenGL可以将调用函数转换成图形处理命令并传送给底层图形硬件,因此OpenGL的绘制效率非...

    CC老师
  • (转载非原创)OpenGL ES 压缩纹理

    在实际应用特别是游戏中纹理占用了相当大的包体积,而且GPU无法直接解码目前流行的图片格式,图片必须转换为RGB等类型的格式才能上传到GPU内存,这显然增加了GP...

    xlj
  • 音视频开发之旅(37) -FFmpeg + OpenGLES 边解码边播放视频(一)

    视频是由一幅幅图像或者说一帧帧 YUV 数据组成 表示图片、视频的色彩空间有几种:YUV、RGB、HSV等,FFmpeg解码后的视频数据是YUV数据,而Open...

    音视频开发之旅
  • Android多媒体之GL-ES战记第二集--谜团立方

    张风捷特烈
  • OpenGLES-07 纹理

    前面的文章都是绘制实实在在的图形的,在OpenGL中,我们还可以使用纹理图片来渲染图形,使用图片可以让描绘出来的物体更加真实也可以让我们的开发更加简单。 资料:...

    清墨
  • 20分钟让你了解OpenGL ——OpenGL全流程详细解读

    | 导语 对于开发者来说,学习OpenGL或者其他图形API都不是一件容易的事情。即使是一些对OpenGL有一些经验的开发者,往往也未必对OpenGL有完整、...

    腾讯Bugly
  • FFmpeg + OpenGL ES 实现 3D 全景播放器

    前文中,我们已经利用 FFmpeg + OpenGLES + OpenSLES 实现了一个多媒体播放器,本文将基于此播放器实现一个酷炫的 3D 全景播放器。

    字节流动
  • OpenGL ES 2.0 (iOS)[01]: 一步从一个小三角开始

    1). 三个什么端点(屏幕坐标点)? 要回答这个问题要先了解 OpenGL ES 的坐标系在屏幕上是怎样分布的:

    半纸渊
  • 15.opengl高级-混合

    纹理缓和的计算也不复杂,根据alpha通道值做叠加或减除融合,详细可参考opengl-混合

    sumsmile
  • Android 基于OpenGl ES渲染yuv视频(十二)

    本文是基于前面两篇OpenGl理论学习的实际应用,更好的巩固一下前面的学习内容,重点讲下如何使用OpenGl去渲染一个yuv格式视频。

    PengJie
  • ShareREC for iOS录屏原理解析

    众所周知,由于iOS系统的封闭性,也出于保护用户隐私的角度,苹果并没有公开的API供开发者调用,来录制屏幕内容。导致许多游戏或者应用没有办法直接通过调用系统AP...

    LiveVideoStack
  • Android OpenGL开发实践 - GLSurfaceView对摄像头数据的再处理

    文首先对GLSurfaceView相关知识进行讲解,然后介绍Android系统如何获取摄像头数据并利用GLSurfaceView渲染到屏幕上。

    天天P图攻城狮

扫码关注云+社区

领取腾讯云代金券