File: hpl1_PostEffect_Motion.fragment

package info (click to toggle)
scummvm 2.9.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 450,580 kB
  • sloc: cpp: 4,299,825; asm: 28,322; python: 12,901; sh: 11,302; java: 9,289; xml: 7,895; perl: 2,639; ansic: 2,465; yacc: 1,670; javascript: 1,020; makefile: 933; lex: 578; awk: 275; objc: 82; sed: 11; php: 1
file content (42 lines) | stat: -rw-r--r-- 1,006 bytes parent folder | download | duplicates (3)
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
// Copyright 2006-2010 (C) - Frictional Games
//
// This file is part of HPL1 Engine
//
// For conditions of distribution and use, see copyright notice in LICENSE-shaders
//

///////////////////////////////////////////////////////
// MOTION BLUR FRAGMENT PROGRAM 
// Credits to jonathan for optimization
///////////////////////////////////////////////////////

in vec4 vVtxPos;
in vec4 vPrevVtxPos;

OUTPUT

uniform sampler2DRect tex0; //screenTex
uniform vec2 halfScreenSize;

void main()
{
	vec2 wpos = gl_FragCoord.xy;
	vec2 p1 = vVtxPos.xy / vVtxPos.w;
	vec2 p2 = vPrevVtxPos.xy / vPrevVtxPos.w;

	vec2 velocity = (p2 - p1) * halfScreenSize;

	//Sample into scene texture along motion vector
	float samples = min( max( 1.0, ceil( max( abs( velocity.x ), abs( velocity.y ) ) / 2.0 ) ), 16.0 );
	float w = 1.0 / samples;  // weight
	vec2 s = velocity / samples; // step
	vec4 a = vec4(0.0);

	for(float i=0.0; i<samples; i+=1.0)
	{
		a += texture2DRect(tex0, wpos) * w;
		wpos += s;
	}

	outColor = a;
}