/usr/share/psychtoolbox-3/PsychOpenGL/PsychGLSLShaders/CylinderProjectionShader.frag.txt is in psychtoolbox-3-common 3.0.12.20160126.dfsg1-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | /* Shader for application of a half-cylinder projection of textures during drawing.
*
* (C)2009 by Mario Kleiner. Licensed to you under MIT license.
*/
#extension GL_ARB_texture_rectangle : enable
const float onedivpi = 0.318309886183791;
uniform int doFilter;
uniform sampler2DRect Image;
uniform vec2 inSize;
uniform vec2 inOffset;
uniform vec2 outSize;
void main()
{
vec4 texcolor, tl, tr, bl, br;
/* Get wanted output pixel coordinates for which we should remap: */
/* texoutpos is the location of the output pixel for which we need */
/* to compute the final remapped color value */
vec2 texoutpos = (gl_TexCoord[0].st) - vec2(0.5, 0.5);
/* Apply 2D offset to output pixel location, as well as a 2D rescaling: */
/* This to account for situations where not the full display area of */
/* display device is used. */
texoutpos = clamp(texoutpos, vec2(0.0), outSize) / outSize;
/* Geometric remapping/warping: Recompute and assign modified components */
/* of texoutpos, based on texinpos and display geometry: */
float azimuth = (texoutpos.x * 2.0) - 1.0;
azimuth = acos(azimuth) * onedivpi;
/* Apply some rescaling to a total input image size of inSize, in case */
/* that not the full size of the input image is used: */
vec2 texinpos = inOffset + (vec2(azimuth, texoutpos.y) * inSize);
/* texinpos now contains the location of the final input image pixel to read */
/* for creation of the final output color pixel. This value may be fractional. */
/* Need to filter input image texture ourselves? */
if (doFilter > 0) {
/* Need to do our own bilinear filtering: Get colors of four nearest */
/* neighbour texels for given non-integral, fractional 'texinpos': */
tl=texture2DRect(Image, floor(texinpos));
tr=texture2DRect(Image, floor(texinpos) + vec2(1.0, 0.0));
bl=texture2DRect(Image, floor(texinpos) + vec2(0.0, 1.0));
br=texture2DRect(Image, floor(texinpos) + vec2(1.0, 1.0));
/* Perform weighted linear interpolation -- bilinear interpolation of the 4: */
tl=mix(tl,tr,fract(texinpos.x));
bl=mix(bl,br,fract(texinpos.x));
texcolor = mix(tl, bl, fract(texinpos.y));
}
else
{
/* Standard case: Hardware does bilinear filtering: */
texcolor = texture2DRect(Image, texinpos);
}
/* Multiply filtered texcolor with incoming fragment color (GL_MODULATE emulation): */
/* Assign result as output fragment color: */
gl_FragColor = texcolor * gl_Color;
}
|