2019-04-07 00:18:43 +02:00
# Appendix
data:image/s3,"s3://crabby-images/a3870/a387047f21a05ba3da97f5c108ee283839f2224a" alt="
2019-04-07 20:29:35 +02:00
The seqmented pane with the cobble texture and normal map and lighting applied to it.
2019-04-07 00:18:43 +02:00
"{#fig:img-base}
data:image/s3,"s3://crabby-images/94da0/94da01e9c726ff2ee184f248d36c73d161182061" alt="
The plane from @fig:img -base with a perlin noise displacement map applied to it
"{#fig:img-perlin-displacement}
data:image/s3,"s3://crabby-images/de0ef/de0ef5f519cc5a1f5cd351875d8261dfef41d55f" alt="
First rendering of the downloaded grass texture and normal map
"{#fig:img-wrong-handedness}
data:image/s3,"s3://crabby-images/56729/56729c22c52aa861ca6c19f9e2e2ae2cea728c8e" alt="
Rendering of the downloaded grass texture with flipped normal map handedness
"{#fig:img-flipped-handedness}
data:image/s3,"s3://crabby-images/aff7a/aff7aee97fed7502648108baac0bcb10f8693512" alt="
The field with grass texture, normal map and displacement map
"{#fig:img-fine-plane}
data:image/s3,"s3://crabby-images/6838a/6838ae94f640302ede25ba3acbc3a7facdd30764" alt="
How a mirrored-on-repeat texture behaves
"{#fig:img-gl-mirror}
```{.cpp #lst:new -tbn caption="Modified TBN matrix to account for the slope of the displacement"}
if (isDisplacementMapped) {
float o = texture(displaceTex, UV).r * 2 - 1;
float u = (texture(displaceTex, UV + vec2(0.0001, 0)).r*2-1 - o) / 0.0004; // magic numbers!
float v = (texture(displaceTex, UV + vec2(0, 0.0001)).r*2-1 - o) / 0.0004; // magic numbers!
TBN = mat3(
normalize(tangent + normal*u),
normalize(bitangent + normal*v),
normalize(cross(tangent + normal*u, bitangent + normal*v))
);
}
```
data:image/s3,"s3://crabby-images/29eda/29eda17928bf896634425f59b70989a210214e9e" alt="
The displaced field with the TBN matrix rotated along the slope of the displacement.
"{#fig:img-displacement-normals}
data:image/s3,"s3://crabby-images/78b58/78b5868f3e027fcbbd586bd05752f3ded969aa03" alt="
Car mesh loaded from car model, without transformations
"{#fig:img-car-meshes}
data:image/s3,"s3://crabby-images/4adb6/4adb67d52352405f59af60c8dfd6a8d8a4e41a54" alt="
Car mesh loaded from car model with transformations applied.
"{#fig:img-car-transformations}
data:image/s3,"s3://crabby-images/7dc48/7dc48ed5c0905eb0173817a19a176e8fbda575bc" alt="
Car mesh loaded from car model with transformations applied, rotated to make z point skyward.
"{#fig:img-car-coordinate-system}
data:image/s3,"s3://crabby-images/c0812/c081258385e2af8467cebe2f8f4c884d6e8d0a71" alt="
Diffuse colors loaded from car model
"{#fig:img-car-materials}
data:image/s3,"s3://crabby-images/7eb4a/7eb4adb7c16c6c48bb0f679e08be0900ae2be380" alt="
Diffuse, emissive and specular colors loaded from car model
"{#fig:img-material-colors}
data:image/s3,"s3://crabby-images/2004c/2004ca76e7851e7cd02259aef293a3dbca52c7a6" alt="
Car model with all colors, with reflection mapping applied.
"{#fig:img-reflection}
data:image/s3,"s3://crabby-images/c3395/c33950472cde96e7311b739dbbb2a13869db7597" alt="
The reflection map texture applied to the car
"{#fig:img-reflection-map}
data:image/s3,"s3://crabby-images/3e2aa/3e2aa2083ce587b7e76f501ecfe8264e92630cea" alt="
Tree model loaded from model file, no texture support yet.
"{#fig:img-tree}
data:image/s3,"s3://crabby-images/1b60e/1b60e38c76eceb3eb8324492ade2f4562c4b7e41" alt="
Tree model loaded from model file, textures applied.
"{#fig:img-tree-alpha}
data:image/s3,"s3://crabby-images/73074/73074e322c3813714b285e95b46dcb6d00fb05c3" alt="
Tree model with textures, transparent meshes rendered last in sorted order.
"{#fig:img-tree-sorted}
data:image/s3,"s3://crabby-images/2e1a0/2e1a079d87c89930e49833c03f9e6d40188732a4" alt="
Tree model with textures, transparent meshes rendered last in sorted order, with depthbuffer in read-only mode.
"{#fig:img-tree-depth-readonly}
```{.dot include="images/rendering-pipeline.dot" caption="The scene rendering pipline, handling transparent nodes" #fig:render -pipeline}
```
data:image/s3,"s3://crabby-images/455ba/455baa2cc06704f01043ac4db435428c3236299d" alt="
Grass model loaded, cloned and placed randomly throughout the scene
"{#fig:img-low-fps}
```{.cpp caption="The node uniforms being uploaded to the shader" #lst:uniform -upload}
glUniformMatrix4fv(s->location("MVP") , 1, GL_FALSE, glm::value_ptr(node->MVP));
glUniformMatrix4fv(s->location("MV") , 1, GL_FALSE, glm::value_ptr(node->MV));
glUniformMatrix4fv(s->location("MVnormal"), 1, GL_FALSE, glm::value_ptr(node->MVnormal));
glUniform2fv(s->location("uvOffset") , 1, glm::value_ptr(node->uvOffset));
glUniform3fv(s->location("diffuse_color") , 1, glm::value_ptr(node->diffuse_color));
glUniform3fv(s->location("emissive_color"), 1, glm::value_ptr(node->emissive_color));
glUniform3fv(s->location("specular_color"), 1, glm::value_ptr(node->specular_color));
glUniform1f( s->location("opacity"), node->opacity);
glUniform1f( s->location("shininess"), node->shininess);
glUniform1f( s->location("reflexiveness"), node->reflexiveness);
glUniform1f( s->location("displacementCoefficient"), node->displacementCoefficient);
glUniform1ui(s->location("isTextured"), node->isTextured);
glUniform1ui(s->location("isVertexColored"), node->isVertexColored);
glUniform1ui(s->location("isNormalMapped"), node->isNormalMapped);
glUniform1ui(s->location("isDisplacementMapped"), node->isDisplacementMapped);
glUniform1ui(s->location("isReflectionMapped"), node->isReflectionMapped);
glUniform1ui(s->location("isIlluminated"), node->isIlluminated);
glUniform1ui(s->location("isInverted"), node->isInverted);
```
```{.cpp caption="Function for caching the uniform locations per shader. The commented line is the old implementation." #lst:location -cache}
GLint inline Shader::location(std::string const& name) {
//return glGetUniformLocation(mProgram, name.c_str());
auto it = this->cache.find(name);
if (it == this->cache.end())
return this->cache[name] = glGetUniformLocation(mProgram, name.c_str());
return it->second;
}
```
```{.cpp caption="The uniform caching defines" #lst:uniform -cache}
bool shader_changed = s != prev_s;
#define cache(x) static decltype(node->x) cached_ ## x; \
if (shader_changed || cached_ ## x != node->x) { cached_ ## x = node->x;
#define um4fv(x) cache(x) glUniformMatrix4fv(s->location(#x), 1, GL_FALSE, glm::value_ptr(node->x)); }
#define u2fv(x) cache(x) glUniform2fv( s->location(#x), 1, glm::value_ptr(node->x)); }
#define u3fv(x) cache(x) glUniform3fv( s->location(#x), 1, glm::value_ptr(node->x)); }
#define u1f(x) cache(x) glUniform1f( s->location(#x), node->x); }
#define u1ui(x) cache(x) glUniform1ui( s->location(#x), node->x); }
```
data:image/s3,"s3://crabby-images/7fc29/7fc2956658c440bd9810bc2687e79aa1e914d4bc" alt="
Car, trees and grass combined into a night driving scene. Two yellow spot lights attached to the head lights, two yelllow point lights attached to the head lights, two red point lights attached to the read lights.
"{#fig:img-night-scene-lights}
data:image/s3,"s3://crabby-images/b4142/b4142bd8107ecdce6c6b2cca17ff40aae89cfb0c" alt="
A pink rim backlight applied to the car with strength of 0.3.
"{#fig:img-rim-lights}
data:image/s3,"s3://crabby-images/81aec/81aec70d4989797005b617169b7004822e505631" alt="
Visualisation of the transformed depth buffer, transformed into a 'point of focus' buffer. z=0 at the depth of the car, tends toward 1 otherwise.
"{#fig:img-depth-map}
data:image/s3,"s3://crabby-images/3ef01/3ef01d3f0bb0266b7eeb0a55396e4687f8ef2a3f" alt="
Depth of field applied to the scene
"{#fig:img-depth-of-field}
data:image/s3,"s3://crabby-images/d2f35/d2f35fc3aa67308a9997fdce2dd6103302a7582b" alt="
The vignette effect, applied to a white frame buffer
"{#fig:img-vingette}
data:image/s3,"s3://crabby-images/1ca34/1ca349bc5a539b9400f10c421bd0e77c81d4c971" alt="
The chromatic aberration effect. F is the point of focus. The transformed depthbuffer is centered around the vertical line crossing F.
"{#fig:img-what-is}
data:image/s3,"s3://crabby-images/43328/43328e129cc2b6f940ab903d74fb7b50962e3a86" alt="
Chromatic aberration applied to the scene, where the aberration coefficients have been multiplied by 3.
"{#fig:img-chromatic-aberration}
data:image/s3,"s3://crabby-images/4e411/4e41149d977193728b5a97448d0bd6912bd4b448" alt="
Noise/grain applied to the frame buffer.
"{#fig:img-noise}
data:image/s3,"s3://crabby-images/d1bd2/d1bd2963d9bbc62a331b521ecbdd786fd644a614" alt="
Noise/grain, multiplied by the depthbuffer/point of focus, applied to the frame buffer.
"{#fig:img-all-effects}
data:image/s3,"s3://crabby-images/11175/1117539b74a073c31bfcd154a70ae4977ea87766" alt="
The same scene, during the day. Spotlights have been turned off.
"{#fig:img-day}
2019-04-07 20:29:35 +02:00
data:image/s3,"s3://crabby-images/553f3/553f3b833b45a0ee7b8e6405f6f0a8a025adcdd6" alt="
The early-morning scene with some strong fog applied. The code was later changed to have the fog affect the background color as well.
"{#fig:img-fog}
```{.dot include="images/effect-order.dot" caption="A high-level graph representing the fragment shader for the scene" #fig:effect -order}
```