Computer Graphics (Q6)
data:image/s3,"s3://crabby-images/0e1bd/0e1bd1f10a6397d5e7900b8471d135d6bcc61ba8" alt=""
Lab 1: Teapots
A simple lab for which we lit teapots using phong lighting.
data:image/s3,"s3://crabby-images/88325/883254fbbd9a46ddfae788afa70ebad062b9f2a8" alt=""
Lab 2: More Teapots
A lab in which we lit several teapots using different shaders and shader techniques, including subroutines, to show our engines were flexible enough to handle it.
data:image/s3,"s3://crabby-images/fff19/fff19b40cf23fcfc6b221954a92d3be3c9f7dba9" alt=""
Lab 3: Even more Teapots
Part of lab 3, where we showed the difference between point lighting and directional lighting on teapots. Depending on light placement, it can be hard to see.
data:image/s3,"s3://crabby-images/944bc/944bca495019d380798c289e06cdbfa5be9afda9" alt=""
Lab 3: Cel shading
Another part of lab 3, where we wrote a shader to quantize lighting values to get cel shading with specifyable number of light levels.
data:image/s3,"s3://crabby-images/0c763/0c76349cac01f9772d677181b7da6f0080acb5db" alt=""
Lab 3: Fog
Another part of lab 3, where we wrote a fog shader so that further away objects using this shader get foggier. Demonstrated on a stack of dragon models made by me.
data:image/s3,"s3://crabby-images/2fda1/2fda104ebfa07344a2c324ca7e2f3eb53c608918" alt=""
Lab 3: Multiple lights
Another part of lab 3, where we wrote a shader that accepts multiple light sources so our objects can be lit using more than a single light source.
data:image/s3,"s3://crabby-images/f662a/f662aa635a49dd6c410351930360fcc0975633e9" alt=""
Lab 3: Spotlight
Another part of lab 3, where we wrote a shader that lights an area with a spotlight, rather than a point light or directional light.
data:image/s3,"s3://crabby-images/ffa15/ffa15dcf939f07a48c37c0657fa59b208aae6712" alt=""
Lab 4: Crate
Here we light a textured model. Pretty simple modification of previous shaders.
data:image/s3,"s3://crabby-images/17830/178309c6ea1d6961f7a6c4389ae491f1a867a1fc" alt=""
Lab 4: FrameBuffer
Here we render in multiple passes for the first time. By rendering from a secondary camera to a framebuffer, and using that as a texture on the cube, we get a representation of the world on a surface within the world.
data:image/s3,"s3://crabby-images/f9eb7/f9eb7096b6762144bf5a52873777873820911d6c" alt=""
Lab 4: Multiple Textures
Here we write a new shader that allows us to use multiple textures on the same model. First a cement texture, followed by a moss texture with transparency.
data:image/s3,"s3://crabby-images/bd39c/bd39c6efe8816f1e6af273f1bd8ac2993e12c155" alt=""
Lab 4: Normal Map
Here I wrote a shader that takes in a normal map to use for lighting, giving the illusion of a more detailed surface than is actually present. It is actually just a cube, but the sides light as if there is geometry present even as the light is moved.
data:image/s3,"s3://crabby-images/a6973/a6973d33ea0315d6829320bc9ad36af953a0b394" alt=""
Lab 4: Transparency
Here I write a shader that takes in a mask to determine which fragements to discard to allow for part of a texture to be applied to a model without having to alter the blend state or alpha values.
data:image/s3,"s3://crabby-images/1fbe2/1fbe2b656c04c5c48f31b88a4bd6978f27d87c6e" alt=""
Lab 5: Normal Hair
Here, using a geometry shader, the normals of the faces of, and the vertices of, a model are drawn as lines protruding from the mesh.
data:image/s3,"s3://crabby-images/b2dd7/b2dd7f55031d06608fdb11ed465956d34fd587a8" alt=""
Lab 5: Fractals
Here I applied a fractal shader that I wrote extracurricularly to a billboard for the billboarding assignment.
data:image/s3,"s3://crabby-images/96072/96072045206f8305522e2035c10167d33410cdb6" alt=""
Lab 5: More Fractals
Here I take strong advantage of the per-pixel intensity of my shader to render 200,000 planes with fractal shaders on them, that become more clear as you approach them.
data:image/s3,"s3://crabby-images/d7247/d724797a148c963f525d44b2e8a2c8ff75f6815b" alt=""
Lab 5: Wireframes
Here we write a wireframe shader to display on lines on top of a model so triangles can be identified.
data:image/s3,"s3://crabby-images/52752/52752e380705a5434e9b53476e70b1733f39c2f5" alt=""
Lab 6: Blur
Here shadows are blurred to make the edges appear smoother and make pixelation less visible.
data:image/s3,"s3://crabby-images/3272c/3272c150b4276c010af2e53c83f7a9d7074a8406" alt=""
Lab 6: Shadows
Here shadows are rendered using a depth texture and a custom shader.
data:image/s3,"s3://crabby-images/c46ae/c46ae6b6ec2ad8d1eb789e69308986957dcac424" alt=""
Lab 6: Volumetric Shadows
Here shadows are made pixel-perfect in a less-efficient manner by using a more complicated technique involving shadow volumes.
data:image/s3,"s3://crabby-images/2e921/2e921f57f7767d17c3e76389b004eb860786e702" alt=""
Lab 7: Particle Fire
Transparency, billboards, geometry shaders, combined and used over and over to make particles.
data:image/s3,"s3://crabby-images/6747e/6747eec18c6fe31063785d45c738408ecf944ec7" alt=""
Lab 7: Plane
A shader makes use of a sine curve to turn a flat plane into a continuously moving wavy plane by passing in time, amplitude, etc. to the shader.
data:image/s3,"s3://crabby-images/2557e/2557eb0a7626ad4e1b4c6585544af2fc3734301b" alt=""
Final Assignment
For the final assignment, I implemented edge detection and made a simple 3D matching game, where you must find and click the object whose edges are shown in the full 3D world.
PreviousNextProject Tech/Algorithms
GLSL (OpenGL Shading Language
Extended Details
Computer Graphics was another game-engine based course I took at Neumont. Here I have put together a slide show of screenshots from various shaders and assignments I wrote during the course.
Shaders were written in GLSL, and loaded using the game engine I created for the Game Libraries course. This was a very intense course, stretching my shader writing skills to new levels every week.
The most difficult assignment written for the course was the Volumetric Shadows assignment. In fact, I was the only student in that particular section to get the shader rendering properly. It was a 3-pass shader involving altering several OpenGL state changes we had never worked with before or had explained to us. Through thorough research and an intense coding session, I was able to overcome this, though it is quite inefficient.
Project Credits