/usr/share/psychtoolbox-3/PsychHardware/BitsPlusToolbox/BitsPlusSetClut.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 | function BitsPlusSetClut(windowPtr, clutOrTexturePtr, rect, doFlip)
% BitsPlusSetClut(windowPtr, clutOrTexturePtr, [rect], [doFlip])
%
% Prior to using this routine, Bits++ box must be in
% framebuffer load mode.
%
% 'clutOrTexturePtr' will either be a 256x3 matrix in the range [0,2^16-1]
% or it will be a texture generated by BitsPlusPlusClut2Texture.
%
% 'rect' lets you define the rect that specifies where the magic code is
% written. For a typical application, this should be left empty. However,
% for programs that modify the projection matrix via MOGL, you will want to
% change this to draw the magic code in a more cosmetically appealing
% location.
%
% If 'doFlip' is set to 1, then BitsPlusSetClut will call flip at the
% end of the function. By default, this value is 1.
% 2/28/03 dhb, ptw Wrote it.
% 18/4/05 ejw converted it to run with OSX version of Psychtoolbox
if nargin < 2 || nargin > 4
error('Usage: BitsPlusSetClut(windowPtr, clut, [rect], [doFlip])');
end
switch nargin
case 2
rect = [];
doFlip = true;
case 3
doFlip = true;
end
% Make sure that 'rect' has valid dimensions.
if ~isempty(rect) && (size(rect, 1) ~= 1 || size(rect, 2) ~= 4)
error('rect must be a 4 element vector.');
end
% Decide if we've been passed a texture pointer or a clut matrix.
isTexture = isscalar(clutOrTexturePtr);
if ~isTexture
% Encode the LUT.
newClutRow = BitsPlusEncodeClutRow(clutOrTexturePtr);
end
% Find out how big the window is.
[screenWidth, screenHeight] = Screen('WindowSize', windowPtr);
% check that the screen width is at least 524 pixels
if screenWidth < 524
error('Window is not big enough to encode the Bits++ CLUT.');
end
if isempty(rect)
if isTexture
rect = [0, 0, 524, 1];
else
rect = [0, 0, size(newClutRow, 2), 1];
end
end
if isTexture
Screen('DrawTexture', windowPtr, clutOrTexturePtr, [0 0 524 1], rect, 0, 0);
else
% Scale the clut to match the color range.
colorRange = Screen('ColorRange', windowPtr);
newClutRow = newClutRow ./ 255 .* colorRange;
Screen('PutImage', windowPtr, newClutRow, rect);
end
if doFlip
Screen(windowPtr, 'Flip');
end
|