/usr/share/psychtoolbox-3/PsychOpenGL/moglMakeHDRTexture.m 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 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | function textureId = moglMakeHDRTexture(win, hdrImage, halffloat, poweroftwo)
% textureId = moglMakeHDRTexture(win, hdrImage [, halffloat][, poweroftwo])
%
% Create a high dynamic range Psychtoolbox texture from the given
% Matlab/Octave high dynamic range image matrix 'hdrImage' and attach
% it to the onscreen window 'win'.
%
% Before calling this function you must have called Screen('BeginOpenGL', win);
% with 'win' being the window handle for the onscreen window to
% which the texture should be attached.
%
% Returns a Psychtoolbox handle 'textureId' for the created 2D texture.
% The texture can be used like any other Psychtoolbox texture, just
% with the difference that it represents its color values with 32 bit
% floating point precision or 16 bit half floating point precision
% instead of 8 bpc fixed point precision.
%
% The optional flag 'halffloat', if set to 1, will trigger creation of a
% texture in half float format, ie. 16 bit floating point numbers instead
% of 32 bit ones. This saves 50% memory and bandwidth. It also allows to
% apply bilinear filtering during texture blits in hardware on GeForce 6000
% and higher.
%
% Normally, Psychtoolbox will try to select a GL_TEXTURE_RECTANGLE
% texture if the hardware supports it. You can enforce creation of
% a power-of-two GL_TEXTURE_2D by setting the optional 'poweroftwo'
% flag to a value of 1.
%
% 'hdrImage' must be a (height, width, 4) matrix of type 'double' or
% 'single', where channel 1=Red, 2=Green, 3=Blue, 4=Alpha. The numeric
% range (0.0 - 1.0) maps to (minimum intensity - maximum intensity).
%
% If you want to use the created 2D texture for 3D OpenGL rendering
% as well, you can use the Screen('GetOpenGLTexture') function to
% retrieve a standard OpenGL texture handle to it.
%
% If you don't want to create a pure 2D texture, but a cube map texture
% for use in 3D environment mapped lighting and such, then use the
% function moglMakeGLHDRTexture() instead. It can create cube-map
% textures for use with the OpenGL functions. These are not useable
% with the standard Psychtoolbox Screen() commands.
%
% History:
% 7.8.2006 Created (MK)
global GL;
if isempty(GL)
InitializeMatlabOpenGL;
end;
if nargin < 1
error('Required window handle ''win'' is missing.');
end
if nargin < 2
error('Required input ''hdrImage'' matrix is missing.');
end
if nargin < 3
halffloat = 0;
end
if nargin < 4
poweroftwo = 0;
end
if poweroftwo == 1
gltextarget = GL.TEXTURE_2D;
else
gltextarget = GL.TEXTURE_RECTANGLE_EXT;
end
% Call the routine that creates an OpenGL texture:
gltexid = moglMakeGLHDRTexture(hdrImage, gltextarget, halffloat);
% Assign the glTexture to Psychtoolbox:
textureId = Screen('SetOpenGLTexture', win, [], gltexid, gltextarget, size(hdrImage, 2), size(hdrImage, 1), 32);
% Return.
return;
|