| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 | /* clang-format off */[vertex]#ifdef USE_GLES_OVER_GL#define lowp#define mediump#define highp#elseprecision highp float;precision highp int;#endifattribute highp vec2 vertex; // attrib:0/* clang-format on */uniform vec2 offset;uniform vec2 scale;varying vec2 uv_interp;void main() {	uv_interp = vertex.xy * 2.0 - 1.0;	vec2 v = vertex.xy * scale + offset;	gl_Position = vec4(v, 0.0, 1.0);}/* clang-format off */[fragment]#ifdef USE_GLES_OVER_GL#define lowp#define mediump#define highp#elseprecision mediump float;precision highp int;#endifuniform sampler2D source; //texunit:0/* clang-format on */uniform vec2 eye_center;uniform float k1;uniform float k2;uniform float upscale;uniform float aspect_ratio;varying vec2 uv_interp;void main() {	vec2 coords = uv_interp;	vec2 offset = coords - eye_center;	// take aspect ratio into account	offset.y /= aspect_ratio;	// distort	vec2 offset_sq = offset * offset;	float radius_sq = offset_sq.x + offset_sq.y;	float radius_s4 = radius_sq * radius_sq;	float distortion_scale = 1.0 + (k1 * radius_sq) + (k2 * radius_s4);	offset *= distortion_scale;	// reapply aspect ratio	offset.y *= aspect_ratio;	// add our eye center back in	coords = offset + eye_center;	coords /= upscale;	// and check our color	if (coords.x < -1.0 || coords.y < -1.0 || coords.x > 1.0 || coords.y > 1.0) {		gl_FragColor = vec4(0.0, 0.0, 0.0, 1.0);	} else {		coords = (coords + vec2(1.0)) / vec2(2.0);		gl_FragColor = texture2D(source, coords);	}}
 |