当前位置: 首页 > news >正文

长春电商网站建设公司建站技术论坛

长春电商网站建设公司,建站技术论坛,怎么在手机上传百度云wordpress,seo是付费还是免费推广前言 本篇在讲什么 本篇章记录对OpenGL中纹理使用的学习 本篇适合什么 适合初学OpenGL的小白 本篇需要什么 对C语法有简单认知 对OpenGL有简单认知 最好是有OpenGL超级宝典蓝宝书 依赖Visual Studio编辑器 本篇的特色 具有全流程的图文教学 重实践,轻理…
前言
本篇在讲什么

本篇章记录对OpenGL中纹理使用的学习
本篇适合什么

适合初学OpenGL的小白
本篇需要什么

C++语法有简单认知
OpenGL有简单认知
最好是有OpenGL超级宝典蓝宝书
依赖Visual Studio编辑器

本篇的特色

具有全流程的图文教学
重实践,轻理论,快速上手
提供全流程的源码内容


★提高阅读体验★

👉 ♠ 一级标题 👈

👉 ♥ 二级标题 👈

👉 ♣ 三级标题 👈

👉 ♦ 四级标题 👈


目录

  • ♠ 纹理
    • ♥ 创建并初始化纹理
    • ♥ 更新纹理数据
    • ♥ 纹理目标和类型
    • ♥ 读取纹理数据
    • ♥ 采样器类型
    • ♥ 演示示例
    • ♥ 从文件载入纹理
    • ♥ 案例分析
  • ♠ 推送
  • ♠ 结语


♠ 纹理

纹理是一种结构化的存储形式,可供着色器读写,常用于存储图像数据,我们常见的png、jpg等图片存储的也是图像数据,只不过是经过编码的数据,不能直接被GPU使用,而纹理格式可以直接被GPU读取渲染


♥ 创建并初始化纹理

在下面的代码中我们对一个纹理进行生成、初始化和绑定的操作

// The type used for names in OpenGL is GLuint
GLuint texture;// Generate a name for the texture
glGenTextures(1, &texture);// Now bind it to the context using the GL_TEXTURE_2D binding point
glBindTexture(GL_TEXTURE_2D, texture);// Specify the amount of storage we want to use for the texture
glTexStorage2D(GL_TEXTURE_2D,    // 2D texture1,                // 1 mipmap levelGL_RGBA32F,       // 32-bit floating-point RGBA data256, 256);        // 256 x 256 texels

要点1:通过glGenTextures接口创建一个纹理
要点2:通过glBindTexture将纹理绑定到上下文
要点3:通过glTexStorage2D分配纹理的格式和需要的内存空间


♥ 更新纹理数据

在纹理初始化完成后,我们为其更新数据

// Define some data to upload into the texture
float * data = new float[256 * 256 * 4];// generate_texture() is a function that fills memory with image data
generate_texture(data, 256, 256);// Assume the texture is already bound to the GL_TEXTURE_2D target
glTexSubImage2D(GL_TEXTURE_2D,  // 2D texture0,              // Level 00, 0,           // Offset 0, 0256, 256,       // 256 x 256 texels, replace entire imageGL_RGBA,        // Four channel dataGL_FLOAT,       // Floating point datadata);          // Pointer to data// Free the memory we allocated before - \GL now has our data
delete [] data;

要点1:通过generate_texture用图像数据填充内存
要点2:通过glTexSubImage2D更新纹理数据


♥ 纹理目标和类型

在上文中我们展示了通过GL_TEXTURE_2D来创建和绑定2D纹理目标,其实还有更多的类型,例如可以通过GL_TEXTURE_2DGL_TEXTURE_3D创建一维和三维纹理,下图展示纹理目标类型

纹理目标(GL_TEXTURE_*)说明
1D一维纹理
2D二维纹理
3D三维纹理
RECTANGLE矩形纹理
1D_ARRAY一维数组纹理
2D_ARRAY二维数组纹理
CUBE_MAP立方体贴图纹理
CUBE_MAP_ARRAY立方体贴图数组纹理
BUFFER缓冲纹理
2D_MULTISAMPLE二维多重采样纹理
2D_MULTISAMPLE_ARRAY二维数组多重采样纹理

♥ 读取纹理数据

存储数据后我们就可以读取数据,用于着色片段,着色器中的纹理以采样器变量形式存在,通用以取样器类型声明统一变量与外界相连接

表示二维纹理的采样器类型为sampler2D即对应我们上文绑定的目标GL_TEXTURE_2D,下列片段着色器代码演示如何读取纹理

"#version 430 core                                                              \n"
"                                                                               \n"
"uniform sampler2D s;                                                           \n"
"                                                                               \n"
"out vec4 color;                                                                \n"
"                                                                               \n"
"void main(void)                                                                \n"
"{                                                                              \n"
"    color = texture(s, gl_FragCoord.xy / textureSize(s, 0));                   \n"
"}   

要点1:采样器类型sampler2D是二维纹理类型
要点2:内置函数texture从纹理中抓取颜色数据


♥ 采样器类型

如前文所述,纹理的每个维度都有一个目标点用于绑定纹理对象,每个目标都有对应的采样器类型,下面列表展示目标点和其对应的采样器类型

纹理目标采样器类型
GL_TEXTURE_1Dsample1D
GL_TEXTURE_2Dsample2D
GL_TEXTURE_3Dsample3D
GL_TEXTURE_RECTANGLEsample2Drect
GL_TEXTURE_1D_ARRAYsample1Darray
GL_TEXTURE_2D_ARRAYsample2Darray
GL_TEXTURE_CUBE_MAPsampleCube
GL_TEXTURE_CUBE_MAP_ARRAYsampleCubeArray
GL_TEXTURE_BUFFERsampleBuffer
GL_TEXTURE_2D_MULTISAMPLEsample2DMS
GL_TEXTURE_2D_MULTISAMPLE_ARRAYsample2DMSArray

♥ 演示示例

全文代码这里粘了,具体参考OpenGL蓝宝书官方演示示例simpletexture,示例内包含和上文相同的代码,下图为效果图

在这里插入图片描述


♥ 从文件载入纹理

在上文我们已经学习到了通过编码生成纹理数据,但这并不符合实际应用中的情况,现实中我们往往是通过文件载入纹理数据,这一块,我们学习如何通过加载.ktx文件,显示纹理

#include <sb7ktx.h>// generate_texture() is a function that fills memory with image data
//generate_texture(data, 256, 256);texture = sb7::ktx::file::load("media/textures/pattern1.ktx");

在这里插入图片描述

这里我们只需要通过sb7::ktx::file::load方法加载ktx文件即可,返回值附加给我们的texture

注意:上述代码修改自超级宝典第七版例子simpletexture,generate_texture生成纹理数据替换成文件加载,就可以得到上图所示的效果,我们文件的纹理填充到三角形里面了


♥ 案例分析

官方提供了一个加载外星人图片的例子alienrain,运行效果如下图所示,我们简单分析一下

在这里插入图片描述

  • 随机的速度、角度、偏移
for (int i = 0; i < 256; i++)
{droplet_x_offset[i] = random_float() * 2.0f - 1.0f;droplet_rot_speed[i] = (random_float() + 0.5f) * ((i & 1) ? -3.0f : 3.0f);droplet_fall_speed[i] = random_float() + 0.2f;
}

给数组内生成了一组随机的速度、角度、偏移值,并绑定到统一变量的缓存内

  • 从本地加载外星人纹理
tex_alien_array = sb7::ktx::file::load("media/textures/aliens.ktx");
glBindTexture(GL_TEXTURE_2D_ARRAY, tex_alien_array);

从本地ktx文件内加载一组外星人纹理数据,绑定到纹理缓存数据内

  • 顶点着色器
"layout (location = 0) in int alien_index;    

用来从纹理数组取数据的下标

out VS_OUT                                                   
{                                                            flat int alien;                                          vec2 tc;                                                
} vs_out;                           

记录外星人纹理数据的下标

layout (std140) uniform droplets         
{                                        droplet_t droplet[256];              
};             

存储随机数值的统一变量

  • 片段着色器
layout (location = 0) out vec4 color;                                            
in VS_OUT                                               
{                                                           flat int alien;                                           vec2 tc;  
} fs_in;                                                               
uniform sampler2DArray tex_aliens;                                     
void main(void)                                               
{                                                             color = texture(tex_aliens, vec3(fs_in.tc, float(fs_in.alien)));   
}                       

根据顶点着色器传过来的外星人纹理数据的下标,从纹理数据缓存里取对应的纹理数据显示

  • 创建外星人纹理
int alien_index;
for (alien_index = 0; alien_index < 256; alien_index++)
{glVertexAttribI1i(0, alien_index);glDrawArrays(GL_TRIANGLE_STRIP, 0, 4);
}

在render方法里没帧都会循环给alien_index赋0-255的值,对应顶点着色器里的外星人的alien_index,所以没帧都会有255个外星人生成


♠ 推送

  • Github
https://github.com/KingSun5

♠ 结语

若是觉得博主的文章写的不错,不妨关注一下博主,点赞一下博文,另博主能力有限,若文中有出现什么错误的地方,欢迎各位评论指摘。

👉 本文属于原创文章,转载请评论留言,并在转载文章头部著名作者出处👈
http://www.15wanjia.com/news/165826.html

相关文章:

  • 打代码做网站的软件北京网站定制流程
  • 网站建设属于什么经济科目跨境电商app开发
  • 北京中邦亚通网站android代码打开wordpress
  • 怎么给公司做微网站长春专业企业网站建设工作室
  • 设计网站的制作框架深圳网站优化多少钱
  • 新建的网站必须要备案吗人们做网站怎么赚钱
  • 网站开发公司如何运营html5手机端开发
  • 为女朋友做网站网上购物软件排行榜
  • 物流网站有哪些增城企业网站建设
  • 网站广告的图片怎么做国家企业信用信息查询系统官网
  • 东莞网站建设(曼哈顿信科)国际室内设计公司排名
  • 成都高端网站建设哪家好做进化树的在线网站
  • 南坪网站建设哪里好推广网站的方法
  • 给女友惊喜做网站物业管理系统c语言
  • 网站开发公司比较有名网络营销是什么专业学的
  • 做设计那个素材网站最好邯郸网站设计 贝壳下拉
  • nas 做网站电商网站取名
  • 全国二级建造师注册信息查询网站知名网站
  • wordpress 查看版本seo优化网络公司
  • 郑州网站建设小程序西安招标信息网官网
  • 三亚凤凰镇网站建设兼职招聘网东莞公司注册要多少钱
  • 网站建设 西安世界局势最新消息军事
  • 网站建设先进材料wordpress文章新窗口
  • 网站开发平台及常用开发工具天天seo站长工具
  • 中诺建设集团网站国内十大旅游网站排名
  • 上海网站开发制网站建设背景资料
  • 公司做网站都咨询哪些问题沈阳建信建设工程有限公司位置
  • 公司网站建设调研问卷百度公司做网站优化多少钱
  • c语言做的网站有什么优缺点建设银行山西招聘网站
  • 网站建设要实现的目标菜鸟教程自学网