LearnOpenGl练习题-纹理
题目地址:纹理 - LearnOpenGL CN
题目一:修改片段着色器,仅让笑脸图案朝另一个方向看:
#version 330 core
out vec4 FragColor;
in vec3 ourColor;
in vec2 TexCoord;
uniform sampler2D texture1;
uniform sampler2D texture2;
void main()
{
FragColor = mix(texture(texture1, TexCoord), texture(texture2, vec2(1.0 - TexCoord.x, TexCoord.y)), 0.2);
}
x
坐标从左延伸到右,修改成从右延伸到左,使左右进行转向;
题目二:尝试用不同的纹理环绕方式,设定一个从0.0f
到2.0f
范围内的(而不是原来的0.0f
到1.0f
)纹理坐标。试试看能不能在箱子的角落放置4个笑脸:
将范围设置为
0.0f
到2.0f
范围,原图片只占四分之一的位置,通过修改不同的环绕方式能产生不同的效果;
纹理环绕方式:
环绕方式 | 描述 |
---|---|
GL_REPEAT | 对纹理的默认行为。重复纹理图像。 |
GL_MIRRORED_REPEAT | 和GL_REPEAT一样,但每次重复图片是镜像放置的。 |
GL_CLAMP_TO_EDGE | 纹理坐标会被约束在0到1之间,超出的部分会重复纹理坐标的边缘,产生一种边缘被拉伸的效果。 |
GL_CLAMP_TO_BORDER | 超出的坐标为用户指定的边缘颜色。 |
题目三:尝试在矩形上只显示纹理图像的中间一部分,修改纹理坐标,达到能看见单个的像素的效果。尝试使用GL_NEAREST
的纹理过滤方式让像素显示得更清晰:
将范围缩小到不足
1
则会只显示局部纹理,设置过滤为GL_NEAREST
使像素边缘更明显;
纹理过滤:
纹理过滤选项 | 描述 |
---|---|
GL_NEAREST(邻近过滤) | 选择中心点最接近纹理坐标的那个像素。 |
GL_LINEAR(线性过滤) | 基于纹理坐标附近的纹理像素,计算出一个插值,近似出这些纹理像素之间的颜色。 |
题目四:使用一个uniform
变量作为mix
函数的第三个参数来改变两个纹理可见度,使用上和下键来改变箱子或笑脸的可见度:
C++添加代码
float mixValue = 0.2f;
int main()
{
//......
//激活着色器前
ourshader.setFloat("mixValue", mixValue);
//......
//输入检测后
ourshader.setFloat("mixValue", mixValue);
}
//根据窗口大小调整视口
void framebuffer_size_callback(GLFWwindow* window, int width, int height) {
//......
}
//检查输入
void processInput(GLFWwindow* window) {
//......
if (glfwGetKey(window, GLFW_KEY_UP) == GLFW_PRESS)
{
mixValue += 0.0001f;
if (mixValue >= 1.0f)
mixValue = 1.0f;
}
if (glfwGetKey(window, GLFW_KEY_DOWN) == GLFW_PRESS)
{
mixValue -= 0.0001f;
if (mixValue <= 0.0f)
mixValue = 0.0f;
}
}
片段着色器代码:
//添加uniform声明
uniform float mixValue;
void main()
{
FragColor = mix(texture(texture1, TexCoord), texture(texture2, vec2(1.0 - TexCoord.x, TexCoord.y)), mixValue);
}
程序完整代码
- 顶点着色器
#version 330 core
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aColor;
layout(location = 2) in vec2 aTexCoord;
out vec3 ourColor;
out vec2 TexCoord;
void