File: mass.frag

package info (click to toggle)
gem 1%3A0.94-8
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 25,636 kB
  • sloc: cpp: 174,297; ansic: 42,132; makefile: 3,852; sh: 1,096; objc: 389
file content (34 lines) | stat: -rw-r--r-- 980 bytes parent folder | download | duplicates (6)
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
// Cyrille Henry 2008
#extension GL_ARB_texture_rectangle : enable

uniform sampler2DRect texture_mass_old,texture_link;
varying vec2 coord;
uniform float init;

void main (void)
{
	vec4 color = vec4(0.,0.,1.,1.);
	if ( (coord.x < 92.) && (coord.y <  64.) )
	{
		vec4 pos = texture2DRect(texture_mass_old, coord)-vec4(0.5);
		vec4 force = texture2DRect(texture_link, coord)-vec4(0.5);

		force = min(max(force,vec4(-0.5)),vec4(0.5));
			// on vire les +inf et -inf qui peuvent poser pb en cas d'instabilités
		pos += force; 
			//increment de la position
	
		float reset = step(coord.x,1.);
//		reset *= step(mod(coord.y,10.),4.);
			// les point en x<1 sont tjrs reseté : ils sont dc imobiles

		color = mix(pos,vec4(coord.x/1000.,(coord.y-32.)/1000.,0.,0.),reset+(1.-reset)*init);
			// couleur de sortie mixé avec couleur d'initialisation

		color += vec4(0.5);
		color.a = 1.;
			// preparation de la sortie (ajout de l'offset + virer l'alpha)
	}

	gl_FragColor = color;
}