123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #version 150
- ////////////////////////////////////////////////////////
- // GTU version 0.40
- // Author: aliaspider - aliaspider@gmail.com
- // License: GPLv3
- ////////////////////////////////////////////////////////
- ////////////////////////////////////////////////////////
- // SETTINGS
- ////////////////////////////////////////////////////////
- //#define CROP_OVERSCAN
- #define TV_COLOR_LEVELS
- //#define COMPOSITE_CONNECTION
- //#define NO_SCANLINES
- #define TV_HORIZONTAL_RESOLUTION 400.0
- #define TV_VERTICAL_RESOLUTION 300.0
- #define SIGNAL_RESOLUTION 280.0
- #define SIGNAL_RESOLUTION_I 83.0
- #define SIGNAL_RESOLUTION_Q 25.0
- #define TV_DISPLAY_GAMMA 2.4
- #define OUTPUT_DISPLAY_GAMMA 2.2
- ////////////////////////////////////////////////////////
- //
- ////////////////////////////////////////////////////////
- #define YIQ_to_RGB mat3x3( 1.0 , 1.0 , 1.0 , 0.9563 , -0.2721 , -1.1070 , 0.6210 , -0.6474 , 1.7046 )
- #define pi 3.14159265358
- #define a(x) abs(x)
- #define d(x,b) (pi*b*min(a(x)+0.5,1.0/b))
- #define e(x,b) (pi*b*min(max(a(x)-0.5,-1.0/b),1.0/b))
- #define STU(x,b) ((d(x,b)+sin(d(x,b))-e(x,b)-sin(e(x,b)))/(2.0*pi))
- #define X(i) (offset-(i))
- #define GETC (texture(source[0], vec2(texCoord.x - X*sourceSize[0].z,texCoord.y)).xyz)
- #ifdef COMPOSITE_CONNECTION
- #define VAL vec3((c.x*STU(X,(SIGNAL_RESOLUTION*sourceSize[0].z))),(c.y*STU(X,(SIGNAL_RESOLUTION_I*sourceSize[0].z))),(c.z*STU(X,(SIGNAL_RESOLUTION_Q*sourceSize[0].z))))
- #else
- #define VAL (c*STU(X,(SIGNAL_RESOLUTION*sourceSize[0].z)))
- #endif //COMPOSITE_CONNECTION
- #define PROCESS(i) X=X(i);c=GETC;tempColor+=VAL;
- uniform sampler2D source[];
- uniform vec4 sourceSize[];
- in Vertex {
- vec2 texCoord;
- };
- out vec4 fragColor;
- void main() {
-
- float offset = fract((texCoord.x * sourceSize[0].x) - 0.5);
- vec3 tempColor = vec3(0.0);
- float X;
- vec3 c;
- PROCESS(-6)PROCESS(-5)PROCESS(-4)PROCESS(-3)PROCESS(-2)PROCESS(-1)PROCESS( 0)
- PROCESS( 7)PROCESS( 6)PROCESS( 5)PROCESS( 4)PROCESS( 3)PROCESS( 2)PROCESS( 1)
-
- #ifdef COMPOSITE_CONNECTION
- tempColor=clamp(YIQ_to_RGB*tempColor,0.0,1.0);
- #endif
- tempColor=clamp(pow(tempColor,vec3(TV_DISPLAY_GAMMA)),0.0,1.0);
- fragColor = vec4(tempColor,1.0);
- }
|