From d18f2c340a8f07994397707245c026e36ed32912 Mon Sep 17 00:00:00 2001 From: xxxEGOxxx <91895255+xxxEGOxxx@users.noreply.github.com> Date: Fri, 10 Feb 2023 14:25:02 +0100 Subject: [PATCH] Rework textures --- cw 9/models/Glass_wall.obj | 8 +++--- cw 9/shaders/shader_texture.vert | 13 +++++++--- cw 9/src/ex_9_1.hpp | 42 +++++++++++++++++++------------- 3 files changed, 38 insertions(+), 25 deletions(-) diff --git a/cw 9/models/Glass_wall.obj b/cw 9/models/Glass_wall.obj index 3cdce50..de66f83 100644 --- a/cw 9/models/Glass_wall.obj +++ b/cw 9/models/Glass_wall.obj @@ -3,13 +3,13 @@ mtllib Glass_wall.mtl o GlassWall v 0.021167 -0.006553 5.110831 -v 0.021167 0.563067 5.110831 +v 0.021167 2.986208 5.110831 v 0.021167 -0.006553 -4.964877 -v 0.021167 0.563067 -4.964877 +v 0.021167 2.986208 -4.964877 v -0.023076 -0.006553 5.110831 -v -0.023076 0.563067 5.110831 +v -0.023076 2.986208 5.110831 v -0.023076 -0.006553 -4.964877 -v -0.023076 0.563067 -4.964877 +v -0.023076 2.986208 -4.964877 vn 1.0000 -0.0000 -0.0000 vn -0.0000 -0.0000 -1.0000 vn -1.0000 -0.0000 -0.0000 diff --git a/cw 9/shaders/shader_texture.vert b/cw 9/shaders/shader_texture.vert index e69c3c7..599c016 100644 --- a/cw 9/shaders/shader_texture.vert +++ b/cw 9/shaders/shader_texture.vert @@ -8,6 +8,7 @@ layout(location = 4) in vec3 vertexBitangent; uniform mat4 transformation; uniform mat4 modelMatrix; +uniform float size; out vec3 vecNormal; out vec3 worldPos; @@ -50,8 +51,12 @@ void main() vec3 SL = normalize(spotlightPos-worldPos); spotlightDirTS = TBN*SL; sunDirTS = TBN*sunDir; - - vecTex = vertexTexCoord; - vecTex.y = 1.0 - vecTex.y; - + if(size == 5){ + vecTex = vertexTexCoord * vec2(10,10); + vecTex.y = 1.0 - vecTex.y; + } + else{ + vecTex = vertexTexCoord; + vecTex.y = 1.0 - vecTex.y; + } } diff --git a/cw 9/src/ex_9_1.hpp b/cw 9/src/ex_9_1.hpp index 3ab1ad0..d287eb6 100644 --- a/cw 9/src/ex_9_1.hpp +++ b/cw 9/src/ex_9_1.hpp @@ -82,6 +82,7 @@ GLuint programSkybox; GLuint programSun; GLuint programTest; GLuint programTex; +GLuint programTexLarge; GLuint programDepth; Core::Shader_Loader shaderLoader; @@ -252,10 +253,15 @@ void drawObjectPBR(Core::RenderContext& context, glm::mat4 modelMatrix, glm::vec } -void drawObjectPBRWithTexture(Core::RenderContext& context, glm::mat4 modelMatrix, GLuint textureID, float roughness, float metallic) { +void drawObjectPBRWithTexture(Core::RenderContext& context, glm::mat4 modelMatrix, GLuint textureID, float roughness, float metallic, float size) { glUseProgram(programTex); glm::mat4 viewProjectionMatrix = createPerspectiveMatrix() * createCameraMatrix(); glm::mat4 transformation = viewProjectionMatrix * modelMatrix; + + + glUniform1f(glGetUniformLocation(programTex, "size"), size); + + /*glm::mat4 transformation = modelMatrix;*/ glUniformMatrix4fv(glGetUniformLocation(programTex, "transformation"), 1, GL_FALSE, (float*)&transformation); glUniformMatrix4fv(glGetUniformLocation(programTex, "modelMatrix"), 1, GL_FALSE, (float*)&modelMatrix); @@ -267,6 +273,7 @@ void drawObjectPBRWithTexture(Core::RenderContext& context, glm::mat4 modelMatri glUniform1f(glGetUniformLocation(programTex, "roughness"), roughness); glUniform1f(glGetUniformLocation(programTex, "metallic"), metallic); + //glUniform3f(glGetUniformLocation(program, "color"), color.x, color.y, color.z); glUniform3f(glGetUniformLocation(programTex, "cameraPos"), cameraPos.x, cameraPos.y, cameraPos.z); @@ -484,22 +491,22 @@ void renderScene(GLFWwindow* window) //draw texture with PBR - drawObjectPBRWithTexture(models::floorContext, glm::mat4(), texture::floorTexture, 0.8f, 0.0f); - drawObjectPBRWithTexture(models::glassWallContext, glm::mat4(), texture::glassWallTexture, 0.8f, 0.0f); - drawObjectPBRWithTexture(models::roomContext, glm::mat4(), texture::roomTexture, 0.8f, 0.0f); - drawObjectPBRWithTexture(models::fishContext, glm::mat4(), texture::fishTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::landContext, glm::mat4(), texture::landTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::sofaBaseContext, glm::mat4(), texture::sofaBaseTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::sofaContext, glm::mat4(), texture::sofaTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::roofContext, glm::mat4(), texture::roofTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::fish2Context, glm::mat4(), texture::fishTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::fish3Context, glm::mat4(), texture::fishTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::door1Context, glm::mat4(), texture::door1Texture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::door2Context, glm::mat4(), texture::door2Texture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::door3Context, glm::mat4(), texture::door3Texture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::doorhandleContext, glm::mat4(), texture::doorhandleTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::door_next_toContext, glm::mat4(), texture::door_next_toTexture, 0.5f, 0.0f); - drawObjectPBRWithTexture(models::door_next_to_doorhandleContext, glm::mat4(), texture::door_next_to_doorhandleTexture, 0.5f, 0.0f); + drawObjectPBRWithTexture(models::floorContext, glm::mat4(), texture::floorTexture, 0.8f, 0.0f,5); + drawObjectPBRWithTexture(models::glassWallContext, glm::mat4(), texture::glassWallTexture, 0.8f, 0.0f, 5); + drawObjectPBRWithTexture(models::roomContext, glm::mat4(), texture::roomTexture, 0.8f, 0.0f, 5); + drawObjectPBRWithTexture(models::fishContext, glm::mat4(), texture::fishTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::landContext, glm::mat4(), texture::landTexture, 0.5f, 0.0f, 5); + drawObjectPBRWithTexture(models::sofaBaseContext, glm::mat4(), texture::sofaBaseTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::sofaContext, glm::mat4(), texture::sofaTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::roofContext, glm::mat4(), texture::roofTexture, 0.5f, 0.0f, 5); + drawObjectPBRWithTexture(models::fish2Context, glm::mat4(), texture::fishTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::fish3Context, glm::mat4(), texture::fishTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::door1Context, glm::mat4(), texture::door1Texture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::door2Context, glm::mat4(), texture::door2Texture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::door3Context, glm::mat4(), texture::door3Texture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::doorhandleContext, glm::mat4(), texture::doorhandleTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::door_next_toContext, glm::mat4(), texture::door_next_toTexture, 0.5f, 0.0f, 0); + drawObjectPBRWithTexture(models::door_next_to_doorhandleContext, glm::mat4(), texture::door_next_to_doorhandleTexture, 0.5f, 0.0f, 0); //test depth buffer //glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); @@ -573,6 +580,7 @@ void init(GLFWwindow* window) //loading textures programTex = shaderLoader.CreateProgram("shaders/shader_texture.vert", "shaders/shader_texture.frag"); + texture::glassWallTexture = Core::LoadTexture("textures/glass.jpg"); texture::fishTexture = Core::LoadTexture("textures/fish.png"); texture::roomTexture = Core::LoadTexture("textures/wall.jpg");