uniform sampler2D tex; uniform sampler2D dtex; uniform mat4 invprojm; uniform vec2 screen; in vec2 uv; out vec4 FragColor; float focalDepth = 10.; float maxblur = 1.; float range = 100.; void main() { float curdepth = texture(dtex, uv).x; vec4 FragPos = invprojm * (2.0f * vec4(uv, curdepth, 1.0f) - 1.0f); FragPos /= FragPos.w; float depth = FragPos.z; float blur = clamp(abs(depth - focalDepth) / range, -maxblur, maxblur); vec2 offset = 10. / screen; vec4 col = texture2D(tex, uv); // Weight from here http://artmartinsh.blogspot.fr/2010/02/glsl-lens-blur-filter-with-bokeh.html col += texture2D(tex, uv + (vec2(0.0, 0.4) * offset) * blur); col += texture2D(tex, uv + (vec2(0.15, 0.37) * offset) * blur); col += texture2D(tex, uv + (vec2(0.29,0.29) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.37,0.15) * offset) * blur); col += texture2D(tex, uv + (vec2(0.4, 0.0) * offset) * blur); col += texture2D(tex, uv + (vec2(0.37, -0.15) * offset) * blur); col += texture2D(tex, uv + (vec2(0.29, -0.29) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.15, -0.37) * offset) * blur); col += texture2D(tex, uv + (vec2(0.0, -0.4) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.15, 0.37) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.29, 0.29) * offset) * blur); col += texture2D(tex, uv + (vec2(0.37, 0.15) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.4, 0.0) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.37, -0.15) * offset) * blur); col += texture2D(tex, uv + (vec2(-0.29, -0.29) * offset) * blur); col += texture2D(tex, uv + (vec2(0.15, -0.37) * offset) * blur); col += texture2D(tex, uv + (vec2(0.15, 0.37) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(-0.37, 0.15) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(0.37, -0.15) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(-0.15, -0.37) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(-0.15, 0.37) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(0.37, 0.15) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(-0.37, -0.15) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(0.15, -0.37) * offset) * blur * 0.9); col += texture2D(tex, uv + (vec2(0.29, 0.29) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(0.4, 0.0) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(0.29, -0.29) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(0.0, -0.4) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(-0.29, 0.29) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(-0.4, 0.0) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(-0.29, -0.29) * offset) * blur * 0.7); col += texture2D(tex, uv + (vec2(0.0, 0.4) * offset) * blur *0.7); col += texture2D(tex, uv + (vec2(0.29, 0.29) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(0.4, 0.0) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(0.29, -0.29) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(0.0, -0.4) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(-0.29, 0.29) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(-0.4, 0.0) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(-0.29, -0.29) * offset) * blur * 0.4); col += texture2D(tex, uv + (vec2(0.0, 0.4) * offset) * blur * 0.4); FragColor = vec4(col.xyz / 41.0, 1.); }