首页 > 其他分享 >纹理

纹理

时间:2022-08-22 17:02:20浏览次数:38  
标签:layout color TexCoord 纹理 vec4 1.0

纹理坐标

float texCoords[] = {
		1.0f, 1.0f, //右上
		1.0f, 0.0f, //右下
		0.0f, 1.0f, //左上
		0.0f, 0.0f  //左下
	};

纹理环绕方式

把纹理坐标设置在(0,0)到(1,1)之外,会产生循环铺满

纹理过滤

邻近过滤:选择离纹理坐标最近的像素(默认)
线性过滤:线性插值

加载纹理

下载stb_image之后放到项目文件夹里,然后头文件

#define STB_IMAGE_IMPLEMENTATION
#include "stb_image.h"

加载图片:

int width, height, nrChannels;
unsigned char *data = stbi_load("container.jpg", &width, &height, &nrChannels, 0);

生成纹理

纹理也是ID引用的

glGenTextures(1, &texture);
glBindTexture(GL_TEXTURE_2D, texture);

然后在顶点上面加纹理坐标,加到最后之后

glVertexAttribPointer(2, 2, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void*)(6 * sizeof(float)));
glEnableVertexAttribArray(2);

在顶点shader里面,加第三个layout

#version 330 core
layout (location=0) in vec3 aPos;
layout (location=1) in vec3 aColor;
layout (location=2) in vec2 aTexCoord;

out vec4 color;
out vec2 TexCoord;

void main()
{
	gl_Position = vec4(aPos, 1.0f);
	color = vec4(aColor, 1.0f);
	TexCoord = aTexCoord;
}

片段着色器加uniform采样器

#version 330 core
in vec4 color;
in vec2 TexCoord;
out vec4 fragColor;
uniform sampler2D ourtexture;
void main()
{
	fragColor = texture(ourtexture, TexCoord) * color;
}

注意顶点坐标一定要仔细检查对应对,要不纹理会乱

标签:layout,color,TexCoord,纹理,vec4,1.0
From: https://www.cnblogs.com/IamIron-Man/p/16613408.html

相关文章

  • Unity3D学习笔记12——渲染纹理
    目录1.概述2.详论3.问题1.概述在文章《Unity3D学习笔记11——后处理》中论述了后处理是帧缓存(Framebuffer)技术实现之一;而另外一个帧缓存技术实现就是渲染纹理了。通......
  • 你所需要了解的几种纹理压缩格式原理
    本文基于资料收集,概括了几种纹理压缩格式的基本思想,希望对于学习有所帮助。为什么我们需要纹理压缩格式?例如R5G6B5、A4R4G4B4、A1R5G5B5、R8G8B8或A8R8G8B8等未经压缩......
  • 纹理映射
    三维模型中每个三角形的顶点都可以找到在贴图中的对应点 重心坐标:已知三角形三个顶点,通关重心坐标的方法,在三角形内进行平滑的过度,使得三角形内每个点都有相对应的值。......