These projects were made in one of my MSc courses, which introduced Vulkan APIs and different rendering techniques.
BlinnPhong shading
data:image/s3,"s3://crabby-images/8febf/8febf17d117b000e1052ca0be9e557cd44558d77" alt=""
Blinn-Phong fragment shader
data:image/s3,"s3://crabby-images/9a967/9a9679e38defcfe100a4fa14aba19d4ef7d0c696" alt="Fragment Shader"
PBR shading
data:image/s3,"s3://crabby-images/e6aea/e6aea56a3af7ddb421e4e376596265f93e48cafa" alt=""
PBR fragment shader
data:image/s3,"s3://crabby-images/37b5a/37b5a50d9f08348652eea072462fc189b2ba9d5f" alt=""
Animated Multiple lights
data:image/s3,"s3://crabby-images/5939f/5939f4338da717ecd90340d6a87c0b56d4d55e7d" alt="Lights"
Post-processing(Pixelate)
data:image/s3,"s3://crabby-images/af113/af113ff6330a2bafdced849a7ac1deac43e2517d" alt="Pixelate"
Fragment shader
1 2 3 4 5 6 7 8
| float width = screenSize.size.x; float height = screenSize.size.y; float T = 8.0f; // T * T tile vec2 size = textureSize(uTexColor,0); vec2 coord = vec2(v2fUV.x * width, v2fUV.y * height); vec2 pixelCoord = vec2(round(coord.x / T) * T, round(coord.y / T) * T); // get central corrdinate vec2 finalUVCoord = vec2(pixelCoord.x / width, pixelCoord.y / height); oColor = vec4(texture(uTexColor, finalUVCoord).rgb, 1.0f);
|