From 44f2bd953d9fa6df63b9bf8fa1a1318b9f365e26 Mon Sep 17 00:00:00 2001 From: Faerbit Date: Mon, 15 Dec 2014 11:22:32 +0100 Subject: [PATCH 1/5] Replacing buildFrustum with standard glm call. --- graphics.cc | 15 ++------------- graphics.hh | 2 -- 2 files changed, 2 insertions(+), 15 deletions(-) diff --git a/graphics.cc b/graphics.cc index 9e944ee..390713a 100644 --- a/graphics.cc +++ b/graphics.cc @@ -97,7 +97,7 @@ void Graphics::render() depthShader->use(); // render depth textures for point lights glViewport(0, 0, cube_size, cube_size); - glm::mat4 depthProjectionMatrix_pointlights = glm::perspective(45.0f, 0.1f, farPlane, (float)cube_size/(float)cube_size); + glm::mat4 depthProjectionMatrix_pointlights = glm::perspective(1.571f, (float)cube_size/(float)cube_size, 0.1f, farPlane); glm::vec3 looking_directions[6] = {glm::vec3(1.0f, 0.0f, 0.0f), glm::vec3(-1.0f, 0.0f, 0.0f), glm::vec3(0.0f, 1.0f, 0.0f), glm::vec3(0.0f, -1.0f, 0.0f), glm::vec3(0.0f, 0.0f, 1.0f), glm::vec3(0.0f, 0.0f, -1.0f)}; @@ -159,7 +159,7 @@ void Graphics::render() lightingShader->use(); //set view and projection matrix - glm::mat4 lightingViewProjectionMatrix = buildFrustum(75.0f, 0.1f, farPlane, (float)windowSize.x/(float)windowSize.y) * buildViewMatrix(level); + glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level); lightingShader->setUniform("lightingViewProjectionMatrix", lightingViewProjectionMatrix); //set lighting parameters @@ -238,17 +238,6 @@ void Graphics::resize(glm::uvec2 windowSize) { depthTexture_far->resize(glm::vec2(windowSize.x, windowSize.y)); } -glm::mat4 Graphics::buildFrustum( float phiInDegree, float _near, float _far, float aspectRatio) { - - float phiHalfInRadians = 0.5*phiInDegree * (M_PI/180.0); - float top = _near * tan( phiHalfInRadians ); - float bottom = -top; - float left = bottom * aspectRatio; - float right = -left; - - return glm::frustum(left, right, bottom, top, _near, _far); -} - glm::mat4 Graphics::buildViewMatrix(Level* level) { //construct lookAt (cameraPosition = cameraCenter + cameraVector return glm::lookAt((level->getCameraCenter()->getPosition() + level->getCamera()->getVector()), diff --git a/graphics.hh b/graphics.hh index 8dd1018..416f5ce 100644 --- a/graphics.hh +++ b/graphics.hh @@ -14,8 +14,6 @@ class Graphics { Graphics(); void init(Level* level); void render(); - // to build the projection matrix: - glm::mat4 buildFrustum( float phiInDegree, float near, float far, float aspectRatio); glm::mat4 buildViewMatrix(Level* level); glm::uvec2 getWindowSize(); bool createWindow(); From 50c4b16367733bc30dd24e93a7f37be1ab828128 Mon Sep 17 00:00:00 2001 From: Faerbit Date: Mon, 15 Dec 2014 11:45:31 +0100 Subject: [PATCH 2/5] Moving MVP calculation to the CPU side. --- Shader/depth.vsh | 5 ++--- Shader/phong.vsh | 4 ++-- graphics.cc | 20 ++++++++------------ level.cc | 4 ++-- level.hh | 2 +- object.cc | 10 ++++++---- object.hh | 2 +- 7 files changed, 22 insertions(+), 25 deletions(-) diff --git a/Shader/depth.vsh b/Shader/depth.vsh index e3eba6a..f84c3cf 100644 --- a/Shader/depth.vsh +++ b/Shader/depth.vsh @@ -4,9 +4,8 @@ in vec3 aPosition; in vec3 aNormal; in vec3 aTexcoord; -uniform mat4 viewProjectionMatrix; -uniform mat4 modelMatrix; +uniform mat4 modelViewProjectionMatrix; void main() { - gl_Position = viewProjectionMatrix * modelMatrix * vec4(aPosition, 1.0); + gl_Position = modelViewProjectionMatrix * vec4(aPosition, 1.0); } diff --git a/Shader/phong.vsh b/Shader/phong.vsh index d2f840e..46932e1 100644 --- a/Shader/phong.vsh +++ b/Shader/phong.vsh @@ -1,7 +1,7 @@ #version 150 uniform mat4 modelMatrix; -uniform mat4 lightingViewProjectionMatrix; +uniform mat4 modelViewProjectionMatrix; uniform mat4 shadowMVP_near; uniform mat4 shadowMVP_middle; uniform mat4 shadowMVP_far; @@ -25,5 +25,5 @@ void main() shadowCoord_near = shadowMVP_near * modelMatrix * vec4(aPosition, 1.0); shadowCoord_middle = shadowMVP_middle * modelMatrix * vec4(aPosition, 1.0); shadowCoord_far = shadowMVP_far * modelMatrix * vec4(aPosition, 1.0); - gl_Position = lightingViewProjectionMatrix * modelMatrix * vec4(aPosition, 1.0); + gl_Position = modelViewProjectionMatrix * vec4(aPosition, 1.0); } diff --git a/graphics.cc b/graphics.cc index 390713a..e2991d1 100644 --- a/graphics.cc +++ b/graphics.cc @@ -110,7 +110,7 @@ void Graphics::render() glm::mat4 depthViewProjectionMatrix_face = depthProjectionMatrix_pointlights * glm::lookAt(level->getLights()->at(i_pointlight).getPosition(), level->getLights()->at(i_pointlight).getPosition() + looking_directions[i_face], glm::vec3(0.0f, 1.0f, 0.0f)); depthShader->setUniform("viewProjectionMatrix", depthViewProjectionMatrix_face); - level->render(depthShader, false); + level->render(depthShader, false, depthViewProjectionMatrix_face); if (!framebuffer_cube->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -124,8 +124,7 @@ void Graphics::render() glm::vec3 sunVector = (level->getCameraCenter()->getPosition() + level->getDirectionalLight()->getPosition()); glm::mat4 depthViewProjectionMatrix_near = glm::ortho(-5, 5, -5, 5, -5, 5) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - depthShader->setUniform("viewProjectionMatrix", depthViewProjectionMatrix_near); - level->render(depthShader, false); + level->render(depthShader, false, depthViewProjectionMatrix_near); if (!framebuffer_near->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -135,8 +134,7 @@ void Graphics::render() glClear(GL_DEPTH_BUFFER_BIT); glm::mat4 depthViewProjectionMatrix_middle = glm::ortho(-20, 20, -20, 20, -20, 20) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - depthShader->setUniform("viewProjectionMatrix", depthViewProjectionMatrix_middle); - level->render(depthShader, false); + level->render(depthShader, false, depthViewProjectionMatrix_middle); if (!framebuffer_middle->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -146,8 +144,7 @@ void Graphics::render() glClear(GL_DEPTH_BUFFER_BIT); glm::mat4 depthViewProjectionMatrix_far = glm::ortho(-farPlane/2.0f, farPlane/2.0f, -farPlane/2.0f, farPlane/2.0f, -farPlane/2.0f, farPlane/2.0f) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - depthShader->setUniform("viewProjectionMatrix", depthViewProjectionMatrix_far); - level->render(depthShader, false); + level->render(depthShader, false, depthViewProjectionMatrix_far); if (!framebuffer_far->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -158,10 +155,6 @@ void Graphics::render() lightingShader->use(); - //set view and projection matrix - glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level); - lightingShader->setUniform("lightingViewProjectionMatrix", lightingViewProjectionMatrix); - //set lighting parameters if (level->getLights()->size() > 0) { lightingShader->setUniform("lightCount", (int) level->getLights()->size()); @@ -227,8 +220,11 @@ void Graphics::render() lightingShader->setUniform("ambientColor", level->getAmbientLight()); lightingShader->setUniform("camera", level->getCameraPosition()); + //set view and projection matrix + glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level); + // render the level - level->render(lightingShader, true); + level->render(lightingShader, true, lightingViewProjectionMatrix); } void Graphics::resize(glm::uvec2 windowSize) { diff --git a/level.cc b/level.cc index c78b7c7..1aa5a87 100644 --- a/level.cc +++ b/level.cc @@ -294,11 +294,11 @@ void Level::load() { cameraCenter = object; } -void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass) { +void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix) { for(unsigned int i = 0; irender(shader, lightingPass); + objects.at(i)->render(shader, lightingPass, viewProjectionMatrix); } } } diff --git a/level.hh b/level.hh index 0ceb9c5..5f84031 100644 --- a/level.hh +++ b/level.hh @@ -18,7 +18,7 @@ class Level { ~Level(); void load(); void update(float runTime, glm::vec2 mouseDelta,bool wPressed, bool aPressed,bool sPressed, bool dPressed); - void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass); + void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix); glm::vec3 getAmbientLight(); Light* getDirectionalLight(); std::vector* getLights(); diff --git a/object.cc b/object.cc index 6e4fe82..c7b808b 100644 --- a/object.cc +++ b/object.cc @@ -12,7 +12,8 @@ Object::Object() { Object::~Object() { } -void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass) { +void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix) { + glm::mat4 modelMatrix = glm::translate(getPosition()) * getRotation() * glm::scale(glm::vec3(model.getScale())); if (lightingPass) { // set lightning parameters for this object shader->setUniform("ambientFactor", material.getAmbientFactor()); @@ -20,10 +21,11 @@ void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass) shader->setUniform("specularFactor", material.getSpecularFactor()); shader->setUniform("shininess", material.getShininess()); shader->setTexture("uTexture", material.getReference(), 0); + // set model matrix + shader->setUniform( "modelMatrix", modelMatrix); } - // set model matrix - glm::mat4 modelMatrix = glm::translate(getPosition()) * getRotation() * glm::scale(glm::vec3(model.getScale())); - shader->setUniform( "modelMatrix", modelMatrix); + glm::mat4 mvp = viewProjectionMatrix * modelMatrix; + shader->setUniform("modelViewProjectionMatrix", mvp); // draw model.getReference()->render(); } diff --git a/object.hh b/object.hh index 526b90c..234efe8 100644 --- a/object.hh +++ b/object.hh @@ -15,7 +15,7 @@ class Object : public Entity { glm::vec3 position, glm::vec3 rotation); Object(); ~Object(); - void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass); + void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjcetionMatrix); private: Model model; Material material; From 21009d00328607ddd262d2c7f72b0219f5befc4b Mon Sep 17 00:00:00 2001 From: Faerbit Date: Mon, 15 Dec 2014 11:53:31 +0100 Subject: [PATCH 3/5] Fixed a parenthesis. --- graphics.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/graphics.cc b/graphics.cc index e2991d1..454deac 100644 --- a/graphics.cc +++ b/graphics.cc @@ -235,7 +235,7 @@ void Graphics::resize(glm::uvec2 windowSize) { } glm::mat4 Graphics::buildViewMatrix(Level* level) { - //construct lookAt (cameraPosition = cameraCenter + cameraVector + //construct lookAt (cameraPosition = cameraCenter + cameraVector) return glm::lookAt((level->getCameraCenter()->getPosition() + level->getCamera()->getVector()), level->getCameraCenter()->getPosition(), glm::vec3(0.0f, 1.0f, 0.0f)); } From 36f72172888a252c57842f14ddb2c896cd6f6675 Mon Sep 17 00:00:00 2001 From: Faerbit Date: Mon, 15 Dec 2014 12:41:30 +0100 Subject: [PATCH 4/5] Moved calculation of shadowMVP to the CPU side. --- Shader/phong.vsh | 10 ++++------ graphics.cc | 27 ++++++++++++++++----------- level.cc | 5 +++-- level.hh | 3 ++- object.cc | 12 ++++++++++-- object.hh | 3 ++- 6 files changed, 37 insertions(+), 23 deletions(-) diff --git a/Shader/phong.vsh b/Shader/phong.vsh index 46932e1..d2806b9 100644 --- a/Shader/phong.vsh +++ b/Shader/phong.vsh @@ -2,9 +2,7 @@ uniform mat4 modelMatrix; uniform mat4 modelViewProjectionMatrix; -uniform mat4 shadowMVP_near; -uniform mat4 shadowMVP_middle; -uniform mat4 shadowMVP_far; +uniform mat4 shadowMVPs[35]; in vec3 aPosition; in vec3 aNormal; @@ -22,8 +20,8 @@ void main() fragPosition = modelMatrix * vec4(aPosition, 1.0); vNormal = inverse(transpose(mat3(modelMatrix))) * aNormal; vTexCoord = aTexCoord; - shadowCoord_near = shadowMVP_near * modelMatrix * vec4(aPosition, 1.0); - shadowCoord_middle = shadowMVP_middle * modelMatrix * vec4(aPosition, 1.0); - shadowCoord_far = shadowMVP_far * modelMatrix * vec4(aPosition, 1.0); + shadowCoord_near = shadowMVPs[0] * vec4(aPosition, 1.0); + shadowCoord_middle = shadowMVPs[1] * vec4(aPosition, 1.0); + shadowCoord_far = shadowMVPs[2] * vec4(aPosition, 1.0); gl_Position = modelViewProjectionMatrix * vec4(aPosition, 1.0); } diff --git a/graphics.cc b/graphics.cc index 454deac..c27d006 100644 --- a/graphics.cc +++ b/graphics.cc @@ -110,7 +110,7 @@ void Graphics::render() glm::mat4 depthViewProjectionMatrix_face = depthProjectionMatrix_pointlights * glm::lookAt(level->getLights()->at(i_pointlight).getPosition(), level->getLights()->at(i_pointlight).getPosition() + looking_directions[i_face], glm::vec3(0.0f, 1.0f, 0.0f)); depthShader->setUniform("viewProjectionMatrix", depthViewProjectionMatrix_face); - level->render(depthShader, false, depthViewProjectionMatrix_face); + level->render(depthShader, false, &depthViewProjectionMatrix_face); if (!framebuffer_cube->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -124,7 +124,7 @@ void Graphics::render() glm::vec3 sunVector = (level->getCameraCenter()->getPosition() + level->getDirectionalLight()->getPosition()); glm::mat4 depthViewProjectionMatrix_near = glm::ortho(-5, 5, -5, 5, -5, 5) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - level->render(depthShader, false, depthViewProjectionMatrix_near); + level->render(depthShader, false, &depthViewProjectionMatrix_near); if (!framebuffer_near->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -134,7 +134,7 @@ void Graphics::render() glClear(GL_DEPTH_BUFFER_BIT); glm::mat4 depthViewProjectionMatrix_middle = glm::ortho(-20, 20, -20, 20, -20, 20) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - level->render(depthShader, false, depthViewProjectionMatrix_middle); + level->render(depthShader, false, &depthViewProjectionMatrix_middle); if (!framebuffer_middle->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -144,7 +144,7 @@ void Graphics::render() glClear(GL_DEPTH_BUFFER_BIT); glm::mat4 depthViewProjectionMatrix_far = glm::ortho(-farPlane/2.0f, farPlane/2.0f, -farPlane/2.0f, farPlane/2.0f, -farPlane/2.0f, farPlane/2.0f) * glm::lookAt(sunVector, level->getCameraCenter()->getPosition(), glm::vec3(0,1,0)); - level->render(depthShader, false, depthViewProjectionMatrix_far); + level->render(depthShader, false, &depthViewProjectionMatrix_far); if (!framebuffer_far->isFrameBufferObjectComplete()) { printf("Framebuffer incomplete, unknown error occured during shadow generation!\n"); } @@ -200,15 +200,15 @@ void Graphics::render() 0.0, 0.0, 0.5, 0.0, 0.5, 0.5, 0.5, 1.0 ); - glm::mat4 depthBiasMVP_near = biasMatrix*depthViewProjectionMatrix_near; - glm::mat4 depthBiasMVP_middle = biasMatrix*depthViewProjectionMatrix_middle; - glm::mat4 depthBiasMVP_far = biasMatrix*depthViewProjectionMatrix_far; + glm::mat4 depthBiasVP_near = biasMatrix*depthViewProjectionMatrix_near; + glm::mat4 depthBiasVP_middle = biasMatrix*depthViewProjectionMatrix_middle; + glm::mat4 depthBiasVP_far = biasMatrix*depthViewProjectionMatrix_far; - lightingShader->setUniform("shadowMVP_near", depthBiasMVP_near); + //lightingShader->setUniform("shadowMVP_near", depthBiasVP_near); lightingShader->setTexture("shadowMap_near", depthTexture_near, 1); - lightingShader->setUniform("shadowMVP_middle", depthBiasMVP_middle); + //lightingShader->setUniform("shadowMVP_middle", depthBiasVP_middle); lightingShader->setTexture("shadowMap_middle", depthTexture_middle, 2); - lightingShader->setUniform("shadowMVP_far", depthBiasMVP_far); + //lightingShader->setUniform("shadowMVP_far", depthBiasVP_far); lightingShader->setTexture("shadowMap_far", depthTexture_far, 3); // set fog Parameters @@ -223,8 +223,13 @@ void Graphics::render() //set view and projection matrix glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level); + std::vector shadowVPs = std::vector(); + shadowVPs.push_back(depthBiasVP_near); + shadowVPs.push_back(depthBiasVP_middle); + shadowVPs.push_back(depthBiasVP_far); + // render the level - level->render(lightingShader, true, lightingViewProjectionMatrix); + level->render(lightingShader, true, &lightingViewProjectionMatrix, &shadowVPs); } void Graphics::resize(glm::uvec2 windowSize) { diff --git a/level.cc b/level.cc index 1aa5a87..560d3ba 100644 --- a/level.cc +++ b/level.cc @@ -294,11 +294,12 @@ void Level::load() { cameraCenter = object; } -void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix) { +void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, + glm::mat4* viewProjectionMatrix, std::vector* shadowVPs) { for(unsigned int i = 0; irender(shader, lightingPass, viewProjectionMatrix); + objects.at(i)->render(shader, lightingPass, viewProjectionMatrix, shadowVPs); } } } diff --git a/level.hh b/level.hh index 5f84031..364d392 100644 --- a/level.hh +++ b/level.hh @@ -18,7 +18,8 @@ class Level { ~Level(); void load(); void update(float runTime, glm::vec2 mouseDelta,bool wPressed, bool aPressed,bool sPressed, bool dPressed); - void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix); + void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, + glm::mat4* viewProjectionMatrix, std::vector* shadowVPs=0); glm::vec3 getAmbientLight(); Light* getDirectionalLight(); std::vector* getLights(); diff --git a/object.cc b/object.cc index c7b808b..601fed0 100644 --- a/object.cc +++ b/object.cc @@ -12,7 +12,8 @@ Object::Object() { Object::~Object() { } -void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjectionMatrix) { +void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, + glm::mat4* viewProjectionMatrix, std::vector* shadowVPs) { glm::mat4 modelMatrix = glm::translate(getPosition()) * getRotation() * glm::scale(glm::vec3(model.getScale())); if (lightingPass) { // set lightning parameters for this object @@ -23,8 +24,15 @@ void Object::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, shader->setTexture("uTexture", material.getReference(), 0); // set model matrix shader->setUniform( "modelMatrix", modelMatrix); + // set shadowMVPs + glm::mat4 shadowMVPs[35]; + for(unsigned int i = 0; (isize() && i<35); i++) { + shadowMVPs[i] = shadowVPs->at(i) * modelMatrix; + } + glUniformMatrix4fv(shader->getUniformLocation("shadowMVPs"), + sizeof(shadowMVPs), false, (GLfloat*) shadowMVPs); } - glm::mat4 mvp = viewProjectionMatrix * modelMatrix; + glm::mat4 mvp = (*viewProjectionMatrix) * modelMatrix; shader->setUniform("modelViewProjectionMatrix", mvp); // draw model.getReference()->render(); diff --git a/object.hh b/object.hh index 234efe8..321e9a0 100644 --- a/object.hh +++ b/object.hh @@ -15,7 +15,8 @@ class Object : public Entity { glm::vec3 position, glm::vec3 rotation); Object(); ~Object(); - void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, glm::mat4 viewProjcetionMatrix); + void render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, + glm::mat4* viewProjcetionMatrix, std::vector* shadowVPs); private: Model model; Material material; From cc93cf7259d6babdd7ad0b472daa7b88aee0beee Mon Sep 17 00:00:00 2001 From: Faerbit Date: Mon, 15 Dec 2014 12:55:48 +0100 Subject: [PATCH 5/5] Removing commented code. --- graphics.cc | 3 --- 1 file changed, 3 deletions(-) diff --git a/graphics.cc b/graphics.cc index c27d006..8f35b41 100644 --- a/graphics.cc +++ b/graphics.cc @@ -204,11 +204,8 @@ void Graphics::render() glm::mat4 depthBiasVP_middle = biasMatrix*depthViewProjectionMatrix_middle; glm::mat4 depthBiasVP_far = biasMatrix*depthViewProjectionMatrix_far; - //lightingShader->setUniform("shadowMVP_near", depthBiasVP_near); lightingShader->setTexture("shadowMap_near", depthTexture_near, 1); - //lightingShader->setUniform("shadowMVP_middle", depthBiasVP_middle); lightingShader->setTexture("shadowMap_middle", depthTexture_middle, 2); - //lightingShader->setUniform("shadowMVP_far", depthBiasVP_far); lightingShader->setTexture("shadowMap_far", depthTexture_far, 3); // set fog Parameters