add fog on objects
This commit is contained in:
parent
1b7e6d9bb1
commit
deec0c2300
@ -10,8 +10,24 @@ in vec3 fragPos;
|
|||||||
in vec3 interpNormal;
|
in vec3 interpNormal;
|
||||||
in vec2 interpTexCoord;
|
in vec2 interpTexCoord;
|
||||||
|
|
||||||
|
float near = 0.02f;
|
||||||
|
float far = 100.0f;
|
||||||
|
|
||||||
|
float linearizeDepth(float depth)
|
||||||
|
{
|
||||||
|
return (2.0 * near * far) / (far + near - (depth * 2.0 - 1.0) * (far - near));
|
||||||
|
}
|
||||||
|
|
||||||
|
float logisticDepth(float depth, float steepness, float offset)
|
||||||
|
{
|
||||||
|
float zVal = linearizeDepth(depth);
|
||||||
|
return (1 / (1 + exp(-steepness * (zVal - offset))));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
|
float depth = logisticDepth(gl_FragCoord.z, 0.1f, 3.0f);
|
||||||
vec3 lightDir = normalize(lightPos-fragPos);
|
vec3 lightDir = normalize(lightPos-fragPos);
|
||||||
vec3 V = normalize(cameraPos-fragPos);
|
vec3 V = normalize(cameraPos-fragPos);
|
||||||
vec2 modifiedTexCoord = vec2(interpTexCoord.x, 1.0 - interpTexCoord.y); // Poprawka dla tekstur Ziemi, ktore bez tego wyswietlaja sie 'do gory nogami'
|
vec2 modifiedTexCoord = vec2(interpTexCoord.x, 1.0 - interpTexCoord.y); // Poprawka dla tekstur Ziemi, ktore bez tego wyswietlaja sie 'do gory nogami'
|
||||||
@ -21,6 +37,6 @@ void main()
|
|||||||
vec3 R = reflect(-normalize(lightDir),normal);
|
vec3 R = reflect(-normalize(lightDir),normal);
|
||||||
float ambient = 0.2;
|
float ambient = 0.2;
|
||||||
float specular = pow(max(0,dot(R,V)),1000);
|
float specular = pow(max(0,dot(R,V)),1000);
|
||||||
gl_FragColor = vec4(color*(ambient + (1-ambient)*diffuse)+vec3(1)*specular*0.2, 1.0);
|
gl_FragColor = vec4(color*(ambient + (1-ambient)*diffuse)+vec3(1)*specular*0.2, 1.0) * (1.0f - depth) + vec4(depth * vec3(0.0f, 0.109f, 0.447f), 1.0f);;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -258,9 +258,6 @@ void drawObjectColor(Core::RenderContext context, glm::mat4 modelMatrix, glm::ve
|
|||||||
|
|
||||||
glUseProgram(program);
|
glUseProgram(program);
|
||||||
|
|
||||||
glUniform3f(glGetUniformLocation(program, "objectColor"), color.x, color.y, color.z);
|
|
||||||
glUniform3f(glGetUniformLocation(program, "lightDir"), lightDir.x, lightDir.y, lightDir.z);
|
|
||||||
|
|
||||||
glm::mat4 transformation = perspectiveMatrix * cameraMatrix * modelMatrix;
|
glm::mat4 transformation = perspectiveMatrix * cameraMatrix * modelMatrix;
|
||||||
glUniformMatrix4fv(glGetUniformLocation(program, "modelViewProjectionMatrix"), 1, GL_FALSE, (float*)&transformation);
|
glUniformMatrix4fv(glGetUniformLocation(program, "modelViewProjectionMatrix"), 1, GL_FALSE, (float*)&transformation);
|
||||||
glUniformMatrix4fv(glGetUniformLocation(program, "modelMatrix"), 1, GL_FALSE, (float*)&modelMatrix);
|
glUniformMatrix4fv(glGetUniformLocation(program, "modelMatrix"), 1, GL_FALSE, (float*)&modelMatrix);
|
||||||
@ -293,7 +290,9 @@ void renderScene()
|
|||||||
cameraMatrix = createCameraMatrix();
|
cameraMatrix = createCameraMatrix();
|
||||||
perspectiveMatrix = Core::createPerspectiveMatrix();
|
perspectiveMatrix = Core::createPerspectiveMatrix();
|
||||||
|
|
||||||
|
glClearColor(0.219f, 0.407f, 0.658f, 1.0f);
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
float time = glutGet(GLUT_ELAPSED_TIME) / 1000.f;
|
float time = glutGet(GLUT_ELAPSED_TIME) / 1000.f;
|
||||||
glUseProgram(skyboxProgram);
|
glUseProgram(skyboxProgram);
|
||||||
glUniform1i(glGetUniformLocation(skyboxProgram, "skybox"), 0);
|
glUniform1i(glGetUniformLocation(skyboxProgram, "skybox"), 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user