feat(OpenGL): lab2
This commit is contained in:
parent
2b6518a20f
commit
186f5db772
5 changed files with 205 additions and 34 deletions
8
OpenGL/lab2/src/ls.fs
Normal file
8
OpenGL/lab2/src/ls.fs
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
#version 330 core
|
||||||
|
out vec4 FragColor;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
FragColor = vec4(1.0); // set all 4 vector values to 1.0
|
||||||
|
}
|
||||||
|
|
12
OpenGL/lab2/src/ls.vs
Normal file
12
OpenGL/lab2/src/ls.vs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
#version 330 core
|
||||||
|
layout (location = 0) in vec3 aPos;
|
||||||
|
|
||||||
|
uniform mat4 trans;
|
||||||
|
uniform mat4 view;
|
||||||
|
uniform mat4 projection;
|
||||||
|
|
||||||
|
void main()
|
||||||
|
{
|
||||||
|
gl_Position = projection * view * trans * vec4(aPos, 1.0);
|
||||||
|
}
|
||||||
|
|
|
@ -13,14 +13,13 @@
|
||||||
const unsigned int SCR_WIDTH = 600;
|
const unsigned int SCR_WIDTH = 600;
|
||||||
const unsigned int SCR_HEIGHT = 600;
|
const unsigned int SCR_HEIGHT = 600;
|
||||||
|
|
||||||
|
|
||||||
// 四边形顶点
|
// 四边形顶点
|
||||||
float vertices[] = {
|
float vertices[] = {
|
||||||
// ---- 位置 ---- ---- 颜色 ---- - 纹理坐标 -
|
// ---- 位置 ---- -- 法向量-- - 纹理坐标 -
|
||||||
0.2f, 0.4f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, // 右上
|
0.2f, 0.4f, 0.0f, 0.0f, 0.0f, 1.0f, 1.0f, 1.0f, // 右上
|
||||||
0.2f, -0.4f, 0.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, // 右下
|
0.2f, -0.4f, 0.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, // 右下
|
||||||
-0.2f, -0.4f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, // 左下
|
-0.2f, -0.4f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, // 左下
|
||||||
-0.2f, 0.4f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f // 左上
|
-0.2f, 0.4f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 1.0f // 左上
|
||||||
};
|
};
|
||||||
|
|
||||||
// 索引
|
// 索引
|
||||||
|
@ -32,6 +31,9 @@ unsigned int indices[] = {
|
||||||
float deltaTime, lastTime;
|
float deltaTime, lastTime;
|
||||||
Camera camera = Camera(SCR_HEIGHT / 2.0f, SCR_HEIGHT / 2.0f);
|
Camera camera = Camera(SCR_HEIGHT / 2.0f, SCR_HEIGHT / 2.0f);
|
||||||
|
|
||||||
|
// lighting
|
||||||
|
glm::vec3 lightPos(1.2f, 1.0f, 2.0f);
|
||||||
|
|
||||||
void framebuffer_size_callback(GLFWwindow *window, int width, int height);
|
void framebuffer_size_callback(GLFWwindow *window, int width, int height);
|
||||||
void processInput(GLFWwindow *window);
|
void processInput(GLFWwindow *window);
|
||||||
void mouse_callback(GLFWwindow *window, double xpos, double ypos);
|
void mouse_callback(GLFWwindow *window, double xpos, double ypos);
|
||||||
|
@ -44,7 +46,6 @@ int main() {
|
||||||
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
|
||||||
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
|
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
|
||||||
glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
|
glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
|
||||||
// glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
|
|
||||||
|
|
||||||
// 创建窗口
|
// 创建窗口
|
||||||
GLFWwindow *window =
|
GLFWwindow *window =
|
||||||
|
@ -54,7 +55,12 @@ int main() {
|
||||||
glfwTerminate();
|
glfwTerminate();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
glfwMakeContextCurrent(window);
|
glfwMakeContextCurrent(window);
|
||||||
|
glfwSetInputMode(window, GLFW_CURSOR, GLFW_CURSOR_DISABLED);
|
||||||
|
glfwSetFramebufferSizeCallback(window, framebuffer_size_callback);
|
||||||
|
glfwSetCursorPosCallback(window, mouse_callback);
|
||||||
|
glfwSetScrollCallback(window, scroll_callback);
|
||||||
|
|
||||||
// 加载glad
|
// 加载glad
|
||||||
if (!gladLoadGLLoader((GLADloadproc)glfwGetProcAddress)) {
|
if (!gladLoadGLLoader((GLADloadproc)glfwGetProcAddress)) {
|
||||||
|
@ -62,12 +68,6 @@ int main() {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 设置视口
|
|
||||||
glfwSetInputMode(window, GLFW_CURSOR, GLFW_CURSOR_DISABLED);
|
|
||||||
glfwSetFramebufferSizeCallback(window, framebuffer_size_callback);
|
|
||||||
glfwSetCursorPosCallback(window, mouse_callback);
|
|
||||||
glfwSetScrollCallback(window, scroll_callback);
|
|
||||||
|
|
||||||
// 创建着色器程序
|
// 创建着色器程序
|
||||||
Shader shader = Shader("src/tex.vs", "src/tex.fs");
|
Shader shader = Shader("src/tex.vs", "src/tex.fs");
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@ int main() {
|
||||||
// 顶点属性
|
// 顶点属性
|
||||||
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void *)0);
|
glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float), (void *)0);
|
||||||
glEnableVertexAttribArray(0);
|
glEnableVertexAttribArray(0);
|
||||||
// 颜色属性
|
// 法向量属性
|
||||||
glVertexAttribPointer(1, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float),
|
glVertexAttribPointer(1, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(float),
|
||||||
(void *)(3 * sizeof(float)));
|
(void *)(3 * sizeof(float)));
|
||||||
glEnableVertexAttribArray(1);
|
glEnableVertexAttribArray(1);
|
||||||
|
@ -133,6 +133,19 @@ int main() {
|
||||||
shader.use();
|
shader.use();
|
||||||
// 绑定纹理
|
// 绑定纹理
|
||||||
shader.setInt("tex", 0);
|
shader.setInt("tex", 0);
|
||||||
|
// // 直射光
|
||||||
|
shader.setVec3("dirLight.direction", 2.0f, 0.0f, 0.0f);
|
||||||
|
shader.setVec3("dirLight.ambient", 0.2f, 0.2f, 0.2f);
|
||||||
|
shader.setVec3("dirLight.diffuse", 0.6f, 0.6f, 0.6f);
|
||||||
|
shader.setVec3("dirLight.specular", 0.7f, 0.7f, 0.7f);
|
||||||
|
// 点光源
|
||||||
|
shader.setVec3("pointLighs.position", glm::vec3(-0.5f, -2.0f, -0.5f));
|
||||||
|
shader.setVec3("pointLight.ambient", 0.2f, 0.2f, 0.2f);
|
||||||
|
shader.setVec3("pointLight.diffuse", 3.0f, 3.0f, 3.0f);
|
||||||
|
shader.setVec3("pointLight.specular", 3.0f, 3.0f, 3.0f);
|
||||||
|
shader.setFloat("pointLight.constant", 1.0f);
|
||||||
|
shader.setFloat("pointLight.linear", 0.00014f);
|
||||||
|
shader.setFloat("pointLight.quadratic", 0.0000007f);
|
||||||
|
|
||||||
// 开启深度测试
|
// 开启深度测试
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
|
@ -165,23 +178,34 @@ int main() {
|
||||||
shader.use();
|
shader.use();
|
||||||
glBindVertexArray(VAO);
|
glBindVertexArray(VAO);
|
||||||
|
|
||||||
|
shader.setVec3("viewPos", camera.Position);
|
||||||
shader.setMat4("view", view);
|
shader.setMat4("view", view);
|
||||||
shader.setMat4("projection", projection);
|
shader.setMat4("projection", projection);
|
||||||
|
|
||||||
|
// 设置材质
|
||||||
|
shader.setVec3("material.ambient", 1.0f, 0.5f, 0.31f);
|
||||||
|
shader.setVec3("material.diffuse", 1.0f, 0.5f, 0.31f);
|
||||||
|
shader.setVec3("material.specular", 0.5f, 0.5f, 0.5f);
|
||||||
|
shader.setFloat("material.shininess", 4.0f);
|
||||||
glm::mat4 trans(1.0f);
|
glm::mat4 trans(1.0f);
|
||||||
|
trans = glm::rotate(trans, glm::radians(-90.0f), glm::vec3(1.0, 0.0, 0.0));
|
||||||
trans = glm::rotate(trans, float(-sin((float)glfwGetTime())),
|
trans = glm::rotate(trans, float(-sin((float)glfwGetTime())),
|
||||||
glm::vec3(0.0, 1.0, 0.0));
|
glm::vec3(0.0, 1.0, 0.0));
|
||||||
trans = glm::translate(trans, glm::vec3(-0.2, 0.0, 0.0));
|
trans = glm::translate(trans, glm::vec3(-0.2, 0.0, 0.0));
|
||||||
shader.setMat4("trans", trans);
|
shader.setMat4("trans", trans);
|
||||||
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
||||||
|
|
||||||
|
// 设置材质
|
||||||
|
shader.setVec3("material.ambient", 1.0f, 0.5f, 0.31f);
|
||||||
|
shader.setVec3("material.diffuse", 0.75f, 0.6f, 0.23f);
|
||||||
|
shader.setVec3("material.specular", 0.62f, 0.55f, 0.37f);
|
||||||
|
shader.setFloat("material.shininess", 64.0f);
|
||||||
trans = glm::mat4(1.0f);
|
trans = glm::mat4(1.0f);
|
||||||
|
trans = glm::rotate(trans, glm::radians(-90.0f), glm::vec3(1.0, 0.0, 0.0));
|
||||||
trans = glm::rotate(trans, float(sin((float)glfwGetTime())),
|
trans = glm::rotate(trans, float(sin((float)glfwGetTime())),
|
||||||
glm::vec3(0.0, 1.0, 0.0));
|
glm::vec3(0.0, 1.0, 0.0));
|
||||||
trans = glm::translate(trans, glm::vec3(0.2, 0.0, 0.0));
|
trans = glm::translate(trans, glm::vec3(0.2, 0.0, 0.0));
|
||||||
trans = glm::rotate(trans, glm::radians(180.0f), glm::vec3(0.0, 1.0, 0.0));
|
trans = glm::rotate(trans, glm::radians(180.0f), glm::vec3(0.0, 1.0, 0.0));
|
||||||
// trans = glm::rotate(trans, (float)glfwGetTime(), glm::vec3(0.0, 0.5,
|
|
||||||
// 0.5)); trans = glm::scale(trans, glm::vec3(0.5, 0.5, 0.5));
|
|
||||||
shader.setMat4("trans", trans);
|
shader.setMat4("trans", trans);
|
||||||
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
|
||||||
|
|
||||||
|
@ -209,11 +233,8 @@ void processInput(GLFWwindow *window) {
|
||||||
camera.ProcessKeyboard(RIGHT, deltaTime);
|
camera.ProcessKeyboard(RIGHT, deltaTime);
|
||||||
if (glfwGetKey(window, GLFW_KEY_SPACE) == GLFW_PRESS)
|
if (glfwGetKey(window, GLFW_KEY_SPACE) == GLFW_PRESS)
|
||||||
camera.ProcessKeyboard(UP, deltaTime);
|
camera.ProcessKeyboard(UP, deltaTime);
|
||||||
if (glfwGetKey(window, GLFW_KEY_LEFT_SHIFT) == GLFW_PRESS)
|
|
||||||
camera.ProcessKeyboard(DOWN, deltaTime);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// 窗口大小改变时回调该函数
|
// 窗口大小改变时回调该函数
|
||||||
void framebuffer_size_callback(GLFWwindow *window, int width, int height) {
|
void framebuffer_size_callback(GLFWwindow *window, int width, int height) {
|
||||||
glViewport(0, 0, width, height);
|
glViewport(0, 0, width, height);
|
||||||
|
|
|
@ -1,14 +1,140 @@
|
||||||
#version 330 core
|
#version 330 core
|
||||||
out vec4 FragColor;
|
|
||||||
|
|
||||||
in vec3 ourColor;
|
struct Material {
|
||||||
|
vec3 ambient;
|
||||||
|
vec3 diffuse;
|
||||||
|
vec3 specular;
|
||||||
|
float shininess;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct DirLight {
|
||||||
|
vec3 direction;
|
||||||
|
|
||||||
|
vec3 ambient;
|
||||||
|
vec3 diffuse;
|
||||||
|
vec3 specular;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PointLight {
|
||||||
|
vec3 position;
|
||||||
|
|
||||||
|
float constant;
|
||||||
|
float linear;
|
||||||
|
float quadratic;
|
||||||
|
|
||||||
|
vec3 ambient;
|
||||||
|
vec3 diffuse;
|
||||||
|
vec3 specular;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct SpotLight {
|
||||||
|
vec3 position;
|
||||||
|
vec3 direction;
|
||||||
|
float cutOff;
|
||||||
|
float outerCutOff;
|
||||||
|
|
||||||
|
float constant;
|
||||||
|
float linear;
|
||||||
|
float quadratic;
|
||||||
|
|
||||||
|
vec3 ambient;
|
||||||
|
vec3 diffuse;
|
||||||
|
vec3 specular;
|
||||||
|
};
|
||||||
|
|
||||||
|
in vec3 FragPos;
|
||||||
|
in vec3 Normal;
|
||||||
in vec2 TexCoord;
|
in vec2 TexCoord;
|
||||||
|
|
||||||
uniform sampler2D tex;
|
uniform sampler2D tex;
|
||||||
|
|
||||||
|
uniform vec3 viewPos;
|
||||||
|
//直射光
|
||||||
|
uniform DirLight dirLight;
|
||||||
|
//点光源
|
||||||
|
uniform PointLight pointLight;
|
||||||
|
//材质
|
||||||
|
uniform Material material;
|
||||||
|
|
||||||
|
out vec4 FragColor;
|
||||||
|
|
||||||
|
vec3 CalcDirLight(DirLight light, vec3 normal, vec3 viewDir);
|
||||||
|
vec3 CalcPointLight(PointLight light, vec3 normal, vec3 fragPos, vec3 viewDir);
|
||||||
|
vec3 CalcSpotLight(SpotLight light, vec3 normal, vec3 fragPos, vec3 viewDir);
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
// FragColor = texture(tex, TexCoord) * vec4(ourColor, 1.0);
|
|
||||||
|
vec3 norm = normalize(Normal);
|
||||||
|
vec3 viewDir = normalize(viewPos - FragPos);
|
||||||
|
// 第一阶段:定向光照
|
||||||
|
vec3 result = CalcDirLight(dirLight, norm, viewDir);
|
||||||
|
// 第二阶段:点光源
|
||||||
|
result += CalcPointLight(pointLight, norm, FragPos, viewDir);
|
||||||
|
|
||||||
if (texture(tex, TexCoord).a < 0.7)
|
if (texture(tex, TexCoord).a < 0.7)
|
||||||
discard;
|
discard;
|
||||||
FragColor = texture(tex, TexCoord);
|
FragColor = vec4(result,1.0) * texture(tex, TexCoord);
|
||||||
|
}
|
||||||
|
|
||||||
|
// calculates the color when using a directional light.
|
||||||
|
vec3 CalcDirLight(DirLight light, vec3 normal, vec3 viewDir)
|
||||||
|
{
|
||||||
|
vec3 lightDir = normalize(-light.direction);
|
||||||
|
// diffuse shading
|
||||||
|
float diff = max(dot(normal, lightDir), 0.0);
|
||||||
|
// specular shading
|
||||||
|
vec3 reflectDir = reflect(-lightDir, normal);
|
||||||
|
float spec = pow(max(dot(viewDir, reflectDir), 0.0), material.shininess);
|
||||||
|
// combine results
|
||||||
|
vec3 ambient = light.ambient * material.ambient * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 diffuse = light.diffuse * diff *material.diffuse * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 specular = light.specular * spec * material.specular * vec3(texture(tex, TexCoord));
|
||||||
|
return (ambient + diffuse + specular);
|
||||||
|
}
|
||||||
|
|
||||||
|
// calculates the color when using a point light.
|
||||||
|
vec3 CalcPointLight(PointLight light, vec3 normal, vec3 fragPos, vec3 viewDir)
|
||||||
|
{
|
||||||
|
vec3 lightDir = normalize(light.position - fragPos);
|
||||||
|
// diffuse shading
|
||||||
|
float diff = max(dot(normal, lightDir), 0.0);
|
||||||
|
// specular shading
|
||||||
|
vec3 reflectDir = reflect(-lightDir, normal);
|
||||||
|
float spec = pow(max(dot(viewDir, reflectDir), 0.0), material.shininess);
|
||||||
|
// attenuation
|
||||||
|
float distance = length(light.position - fragPos);
|
||||||
|
float attenuation = 1.0 / (light.constant + light.linear * distance + light.quadratic * (distance * distance));
|
||||||
|
// combine results
|
||||||
|
vec3 ambient = light.ambient * material.ambient * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 diffuse = light.diffuse * diff *material.diffuse * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 specular = light.specular * spec * material.specular * vec3(texture(tex, TexCoord));
|
||||||
|
ambient *= attenuation;
|
||||||
|
diffuse *= attenuation;
|
||||||
|
specular *= attenuation;
|
||||||
|
return (ambient + diffuse + specular);
|
||||||
|
}
|
||||||
|
|
||||||
|
// calculates the color when using a spot light.
|
||||||
|
vec3 CalcSpotLight(SpotLight light, vec3 normal, vec3 fragPos, vec3 viewDir)
|
||||||
|
{
|
||||||
|
vec3 lightDir = normalize(light.position - fragPos);
|
||||||
|
// diffuse shading
|
||||||
|
float diff = max(dot(normal, lightDir), 0.0);
|
||||||
|
// specular shading
|
||||||
|
vec3 reflectDir = reflect(-lightDir, normal);
|
||||||
|
float spec = pow(max(dot(viewDir, reflectDir), 0.0), material.shininess);
|
||||||
|
// attenuation
|
||||||
|
float distance = length(light.position - fragPos);
|
||||||
|
float attenuation = 1.0 / (light.constant + light.linear * distance + light.quadratic * (distance * distance));
|
||||||
|
// spotlight intensity
|
||||||
|
float theta = dot(lightDir, normalize(-light.direction));
|
||||||
|
float epsilon = light.cutOff - light.outerCutOff;
|
||||||
|
float intensity = clamp((theta - light.outerCutOff) / epsilon, 0.0, 1.0);
|
||||||
|
// combine results
|
||||||
|
vec3 ambient = light.ambient * material.ambient * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 diffuse = light.diffuse * diff *material.diffuse * vec3(texture(tex, TexCoord));
|
||||||
|
vec3 specular = light.specular * spec * material.specular * vec3(texture(tex, TexCoord));
|
||||||
|
ambient *= attenuation * intensity;
|
||||||
|
diffuse *= attenuation * intensity;
|
||||||
|
specular *= attenuation * intensity;
|
||||||
|
return (ambient + diffuse + specular);
|
||||||
}
|
}
|
|
@ -1,19 +1,23 @@
|
||||||
#version 330 core
|
#version 330 core
|
||||||
layout (location = 0) in vec3 aPos;
|
layout(location = 0) in vec3 aPos;
|
||||||
layout (location = 1) in vec3 aColor;
|
layout(location = 1) in vec3 aNormal;
|
||||||
layout (location = 2) in vec2 aTexCoord;
|
layout(location = 2) in vec2 aTexCoord;
|
||||||
|
|
||||||
out vec3 ourColor;
|
|
||||||
out vec2 TexCoord;
|
out vec2 TexCoord;
|
||||||
|
out vec3 FragPos;
|
||||||
|
out vec3 Normal;
|
||||||
|
out vec2 TexCoords;
|
||||||
|
|
||||||
uniform mat4 trans;
|
uniform mat4 trans;
|
||||||
uniform mat4 view;
|
uniform mat4 view;
|
||||||
uniform mat4 projection;
|
uniform mat4 projection;
|
||||||
|
|
||||||
void main()
|
void main() {
|
||||||
{
|
// 计算角度
|
||||||
gl_Position = projection * view * trans * vec4(aPos, 1.0);
|
FragPos = vec3(trans * vec4(aPos, 1.0));
|
||||||
// gl_Position = trans * vec4(aPos, 1.0);
|
// 计算法向量
|
||||||
ourColor = aColor;
|
Normal = mat3(transpose(inverse(trans))) * aNormal;
|
||||||
TexCoord = aTexCoord;
|
|
||||||
|
gl_Position = projection * view * trans * vec4(aPos, 1.0);
|
||||||
|
TexCoord = aTexCoord;
|
||||||
}
|
}
|
||||||
|
|
Reference in a new issue