Project

General

Profile

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

library / src / main / res / raw / blur1_fragment_shader.glsl @ f2367b75

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
in vec2 v_TexCoordinate;
23
out vec4 fragColor;
24
uniform sampler2D u_ColorTexture;
25
uniform float u_Offsets[MAX_BLUR];
26
uniform float u_Weights[MAX_BLUR];
27
uniform int u_Radius;
28

    
29
//////////////////////////////////////////////////////////////////////////////////////////////
30

    
31
void main()
32
  {
33
  vec4 pixel= texture(u_ColorTexture,v_TexCoordinate) * u_Weights[0];
34

    
35
  for (int i=1; i<=u_Radius; i+=1)
36
    {
37
    pixel += ( texture(u_ColorTexture,vec2(v_TexCoordinate.x+u_Offsets[i],v_TexCoordinate.y)) +
38
               texture(u_ColorTexture,vec2(v_TexCoordinate.x-u_Offsets[i],v_TexCoordinate.y)) ) * u_Weights[i];
39
    }
40

    
41
  fragColor = pixel;
42
  }
(3-3/9)