File: vtkSSAAPassFS.glsl

package info (click to toggle)
vtk7 7.1.1%2Bdfsg1-12
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 125,776 kB
  • sloc: cpp: 1,539,582; ansic: 106,521; python: 78,038; tcl: 47,013; xml: 8,142; yacc: 5,040; java: 4,439; perl: 3,132; lex: 1,926; sh: 1,500; makefile: 122; objc: 83
file content (58 lines) | stat: -rw-r--r-- 2,092 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
//VTK::System::Dec

// ============================================================================
//
//  Program:   Visualization Toolkit
//  Module:    vtkSSAAPassFS.glsl
//
//  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
//  All rights reserved.
//  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
//
//     This software is distributed WITHOUT ANY WARRANTY; without even
//     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
//     PURPOSE.  See the above copyright notice for more information.
//
// ============================================================================

// thanks to Brad Larson for posting sample code that helped get this started

uniform sampler2D source;

// the output of this shader
//VTK::Output::Dec

uniform float texelWidthOffset;
uniform float texelHeightOffset;

varying vec2 tcoordVC;

// Note that the texel offsets should be 3/8 of a pixel in the
// resulting image not the source image. Also note that this
// filter is meant to be run one dimension at a time.
// in the equation below 1.5 corresponds to 4 texel offsets
// aka 3/8 * 4 = 1.5

// sinc(x) * sinc(x/a) = (a * sin(pi * x) * sin(pi * x / a)) / (pi^2 * x^2)
// Assuming a Lanczos constant of 2.0, and scaling values to max out at x = +/- 1.5

void main()
{
  vec2 firstOffset = vec2(texelWidthOffset, texelHeightOffset);

  vec4 fragmentColor = texture2D(source, tcoordVC) * 0.38026;

  fragmentColor += texture2D(source, tcoordVC - firstOffset) * 0.27667;
  fragmentColor += texture2D(source, tcoordVC + firstOffset) * 0.27667;

  fragmentColor += texture2D(source, tcoordVC - 2.0*firstOffset) * 0.08074;
  fragmentColor += texture2D(source, tcoordVC + 2.0*firstOffset) * 0.08074;

  fragmentColor += texture2D(source, tcoordVC - 3.0*firstOffset) * -0.02612;
  fragmentColor += texture2D(source, tcoordVC + 3.0*firstOffset) * -0.02612;

  fragmentColor += texture2D(source, tcoordVC - 4.0*firstOffset) * -0.02143;
  fragmentColor += texture2D(source, tcoordVC + 4.0*firstOffset) * -0.02143;

  gl_FragData[0] = fragmentColor;
}