Project

General

Profile

Download (3.07 KB) Statistics
| Branch: | Revision:

library / src / main / res / raw / blur2_fragment_shader.glsl @ fd2db957

1
//////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                          //
3
//                                                                                          //
4
// This file is part of Distorted.                                                          //
5
//                                                                                          //
6
// Distorted is free software: you can redistribute it and/or modify                        //
7
// it under the terms of the GNU General Public License as published by                     //
8
// the Free Software Foundation, either version 2 of the License, or                        //
9
// (at your option) any later version.                                                      //
10
//                                                                                          //
11
// Distorted is distributed in the hope that it will be useful,                             //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                           //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                            //
14
// GNU General Public License for more details.                                             //
15
//                                                                                          //
16
// You should have received a copy of the GNU General Public License                        //
17
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                       //
18
//////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
precision lowp float;
21

    
22
#if __VERSION__ != 100
23
in vec2 v_TexCoordinate;
24
out vec4 fragColor;
25
#define TEXTURE texture
26
#define FRAG_COLOR fragColor
27
#else
28
varying vec2 v_TexCoordinate;
29
#define TEXTURE texture2D
30
#define FRAG_COLOR gl_FragColor
31
#endif
32

    
33
uniform sampler2D u_ColorTexture;
34
uniform sampler2D u_DepthTexture;
35
uniform float u_Offsets[MAX_BLUR];
36
uniform float u_Weights[MAX_BLUR];
37
uniform int u_Radius;
38

    
39
//////////////////////////////////////////////////////////////////////////////////////////////
40

    
41
void main()
42
  {
43
  float depth = TEXTURE(u_DepthTexture,v_TexCoordinate).r;
44

    
45
  if( u_Radius>1 )
46
    {
47
    float offset = u_Offsets[u_Radius];
48

    
49
    depth = min(depth, TEXTURE(u_DepthTexture,vec2(v_TexCoordinate.x,v_TexCoordinate.y+offset)).r);
50
    depth = min(depth, TEXTURE(u_DepthTexture,vec2(v_TexCoordinate.x,v_TexCoordinate.y-offset)).r);
51
    depth = min(depth, TEXTURE(u_DepthTexture,vec2(v_TexCoordinate.x+offset,v_TexCoordinate.y)).r);
52
    depth = min(depth, TEXTURE(u_DepthTexture,vec2(v_TexCoordinate.x-offset,v_TexCoordinate.y)).r);
53
    }
54

    
55
  gl_FragDepth = depth;
56

    
57
  vec4 pixel= TEXTURE(u_ColorTexture,v_TexCoordinate) * u_Weights[0];
58

    
59
  for (int i=1; i<=u_Radius; i+=1)
60
    {
61
    pixel += ( TEXTURE(u_ColorTexture,vec2(v_TexCoordinate.x,v_TexCoordinate.y+u_Offsets[i])) +
62
               TEXTURE(u_ColorTexture,vec2(v_TexCoordinate.x,v_TexCoordinate.y-u_Offsets[i])) ) * u_Weights[i];
63
    }
64

    
65
  FRAG_COLOR = pixel;
66
  }
(4-4/9)