63 lines
1.9 KiB
Plaintext
63 lines
1.9 KiB
Plaintext
|
void main()
|
||
|
{
|
||
|
//variables
|
||
|
float internalresolution = 1278.0;
|
||
|
float4 c0 = Sample();
|
||
|
|
||
|
//blur
|
||
|
float4 blurtotal = float4(0.0, 0.0, 0.0, 0.0);
|
||
|
float blursize = 1.5;
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2(-blursize, -blursize) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2(-blursize, blursize) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2( blursize, -blursize) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2( blursize, blursize) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2(-blursize, 0.0) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2( blursize, 0.0) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2( 0.0, -blursize) * GetInvResolution());
|
||
|
blurtotal += SampleLocation(GetCoordinates() + float2( 0.0, blursize) * GetInvResolution());
|
||
|
blurtotal *= 0.125;
|
||
|
c0 = blurtotal;
|
||
|
|
||
|
//greyscale
|
||
|
float grey = ((0.3 * c0.r) + (0.4 * c0.g) + (0.3 * c0.b));
|
||
|
|
||
|
// brighten
|
||
|
grey = grey * 0.5 + 0.7;
|
||
|
|
||
|
// darken edges
|
||
|
float x = GetCoordinates().x * GetResolution().x;
|
||
|
float y = GetCoordinates().y * GetResolution().y;
|
||
|
if (x > internalresolution/2.0)
|
||
|
x = internalresolution-x;
|
||
|
if (y > internalresolution/2.0)
|
||
|
y = internalresolution-y;
|
||
|
if (x > internalresolution/2.0*0.95)
|
||
|
x = internalresolution/2.0*0.95;
|
||
|
if (y > internalresolution/2.0*0.95)
|
||
|
y = internalresolution/2.0*0.95;
|
||
|
x = -x+641.0;
|
||
|
y = -y+641.0;
|
||
|
|
||
|
/*****inline square root routines*****/
|
||
|
// bit of a performance bottleneck.
|
||
|
// neccessary to make the darkened area rounded
|
||
|
// instead of rhombus-shaped.
|
||
|
float sqrt = x / 10.0;
|
||
|
|
||
|
while ((sqrt*sqrt) < x)
|
||
|
sqrt+=0.1;
|
||
|
x = sqrt;
|
||
|
sqrt = y / 10.0;
|
||
|
while ((sqrt*sqrt) < y)
|
||
|
sqrt+=0.1;
|
||
|
y = sqrt;
|
||
|
|
||
|
x *= 2.0;
|
||
|
y *= 2.0;
|
||
|
grey -= x / 200.0;
|
||
|
grey -= y / 200.0;
|
||
|
|
||
|
// output
|
||
|
SetOutput(float4(0.0, grey, 0.0, 1.0));
|
||
|
}
|