maxShadowRenderCount now works correctly.
This commit is contained in:
parent
377902a255
commit
fd1f32be6a
@ -26,6 +26,7 @@ uniform float specularFactor;
|
||||
uniform vec3 camera;
|
||||
uniform float shininess;
|
||||
uniform int lightCount;
|
||||
uniform int maxShadowRenderCount;
|
||||
uniform vec3 directionalLightVector;
|
||||
uniform vec3 directionalColor;
|
||||
uniform float directionalIntensity;
|
||||
@ -115,45 +116,37 @@ void main()
|
||||
for(int i = 0; i<lightCount; i++) {
|
||||
vec3 lightDirection = vec3(fragPosition) - lightSources[i];
|
||||
float distance = length(lightDirection);
|
||||
float pointVisibility = 0.0f;
|
||||
float pointVisibility = 1.0f;
|
||||
// only take lights into account with meaningful contribution
|
||||
if (distance < farPlane) {
|
||||
if (i == 0) {
|
||||
if (i == 0 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube0, lightDirection);
|
||||
}
|
||||
if (i == 1) {
|
||||
if (i == 1 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube1, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 2) {
|
||||
if (i == 2 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube2, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 3) {
|
||||
if (i == 3 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube3, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 4) {
|
||||
if (i == 4 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube4, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 5) {
|
||||
if (i == 5 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube5, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 6) {
|
||||
if (i == 6 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube6, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 7) {
|
||||
if (i == 7 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube7, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 8) {
|
||||
if (i == 8 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube8, lightDirection);
|
||||
}
|
||||
|
||||
if (i == 9) {
|
||||
if (i == 9 && i<maxShadowRenderCount) {
|
||||
pointVisibility = samplePointShadow(shadowMap_cube9, lightDirection);
|
||||
}
|
||||
vec3 lightVector = normalize(lightSources[i]-vec3(fragPosition));
|
||||
|
47
graphics.cc
47
graphics.cc
@ -112,13 +112,13 @@ void Graphics::render(double time)
|
||||
glm::vec3(0.0f, 0.0f, -1.0f),glm::vec3(0.0f, -1.0f, 0.0f),glm::vec3(0.0f, -1.0f, 0.0f)};
|
||||
|
||||
framebuffer_cube->bind();
|
||||
for (unsigned int i_pointlight = 0; i_pointlight<closestLights->size() && i_pointlight < maxShadowRenderCount; i_pointlight++) {
|
||||
for (unsigned int i_pointlight = 0; i_pointlight<closestLights.size() && i_pointlight < maxShadowRenderCount; i_pointlight++) {
|
||||
// render each side of the cube
|
||||
for (int i_face = 0; i_face<6; i_face++) {
|
||||
glFramebufferTexture2D(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_TEXTURE_CUBE_MAP_POSITIVE_X + i_face, depth_cubeMaps.at(i_pointlight)->getObjectName(), 0);
|
||||
glClear(GL_DEPTH_BUFFER_BIT);
|
||||
glm::mat4 viewMatrix = glm::lookAt(closestLights->at(i_pointlight).getPosition(),
|
||||
closestLights->at(i_pointlight).getPosition() + looking_directions[i_face], upvectors[i_face]);
|
||||
glm::mat4 viewMatrix = glm::lookAt(closestLights.at(i_pointlight).getPosition(),
|
||||
closestLights.at(i_pointlight).getPosition() + looking_directions[i_face], upvectors[i_face]);
|
||||
glm::mat4 depthViewProjectionMatrix_face = depthProjectionMatrix_pointlights * viewMatrix;
|
||||
std::vector<glm::mat4> viewMatrixVector = std::vector<glm::mat4>();
|
||||
viewMatrixVector.push_back(viewMatrix);
|
||||
@ -200,43 +200,38 @@ bool Graphics::compareLightDistances(Light a, Light b) {
|
||||
}
|
||||
|
||||
void Graphics::updateClosestLights() {
|
||||
if (level->getLights()->size() <= 32) {
|
||||
this->closestLights = level->getLights();
|
||||
}
|
||||
else {
|
||||
closestLightsVector = std::vector<Light>(*level->getLights());
|
||||
std::sort(closestLightsVector.begin(),
|
||||
closestLightsVector.end(),
|
||||
[this](Light a, Light b) {return compareLightDistances(a, b); });
|
||||
closestLightsVector = std::vector<Light>(&closestLightsVector[0],
|
||||
&closestLightsVector[31]);
|
||||
closestLights = &closestLightsVector;
|
||||
}
|
||||
closestLights = std::vector<Light>(*level->getLights());
|
||||
std::sort(closestLights.begin(),
|
||||
closestLights.end(),
|
||||
[this](Light a, Light b) {return compareLightDistances(a, b); });
|
||||
closestLights = std::vector<Light>(&closestLights[0],
|
||||
&closestLights[31]);
|
||||
}
|
||||
|
||||
void Graphics::updateShaderLights() {
|
||||
updateClosestLights();
|
||||
if (closestLights->size() > 0) {
|
||||
lightingShader->setUniform("lightCount", (int) closestLights->size());
|
||||
if (closestLights.size() > 0) {
|
||||
lightingShader->setUniform("lightCount", (int) closestLights.size());
|
||||
lightingShader->setUniform("maxShadowRenderCount", std::min((int) closestLights.size(), (int)maxShadowRenderCount));
|
||||
|
||||
// Build light position array
|
||||
glm::vec3 lightSources[closestLights->size()];
|
||||
for(unsigned int i = 0; i<closestLights->size(); i++) {
|
||||
lightSources[i] = closestLights->at(i).getPosition();
|
||||
glm::vec3 lightSources[closestLights.size()];
|
||||
for(unsigned int i = 0; i<closestLights.size(); i++) {
|
||||
lightSources[i] = closestLights.at(i).getPosition();
|
||||
}
|
||||
glUniform3fv(lightingShader->getUniformLocation("lightSources"),
|
||||
sizeof(lightSources), (GLfloat*) lightSources);
|
||||
// Build light colour array
|
||||
glm::vec3 lightColours[closestLights->size()];
|
||||
for(unsigned int i = 0; i<closestLights->size(); i++) {
|
||||
lightColours[i] = closestLights->at(i).getColour();
|
||||
glm::vec3 lightColours[closestLights.size()];
|
||||
for(unsigned int i = 0; i<closestLights.size(); i++) {
|
||||
lightColours[i] = closestLights.at(i).getColour();
|
||||
}
|
||||
glUniform3fv(lightingShader->getUniformLocation("lightColors"),
|
||||
sizeof(lightColours), (GLfloat*) lightColours);
|
||||
// Build light attenuation array
|
||||
float lightIntensities[closestLights->size()];
|
||||
for(unsigned int i = 0; i<closestLights->size(); i++) {
|
||||
lightIntensities[i] = closestLights->at(i).getIntensity();
|
||||
float lightIntensities[closestLights.size()];
|
||||
for(unsigned int i = 0; i<closestLights.size(); i++) {
|
||||
lightIntensities[i] = closestLights.at(i).getIntensity();
|
||||
}
|
||||
glUniform1fv(lightingShader->getUniformLocation("lightIntensities"),
|
||||
sizeof(lightIntensities), (GLfloat*) lightIntensities);
|
||||
|
@ -28,8 +28,7 @@ class Graphics {
|
||||
float nearPlane;
|
||||
float farPlane;
|
||||
// pointer to either use the vector from the level or from here
|
||||
std::vector<Light>* closestLights;
|
||||
std::vector<Light> closestLightsVector; // contains the 32 closest lights
|
||||
std::vector<Light> closestLights;
|
||||
ACGL::OpenGL::SharedShaderProgram lightingShader;
|
||||
ACGL::OpenGL::SharedShaderProgram depthCubeShader;
|
||||
ACGL::OpenGL::SharedShaderProgram depthShader;
|
||||
|
Loading…
Reference in New Issue
Block a user