/usr/share/psychtoolbox-3/PsychGLImageProcessing/private/createnewcalibrationgrid.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 | function [scal] = createnewcalibrationgrid(scal)
% adjustable parameters:
% the number of rows and columns of dots. These will be evenly spaced
% across the display in a rectangular grid.
%
% bugs: getmouse does not return right x and y values. It may therefore
% make it a little hard to select the right points in the grid.
% MK: Set in calling routine, or overriden there by user input:
% scal.NxdotsG = 37;
% scal.NydotsG = 27;
% MK: Done in calling routine...
% % determine the arrangement of monitors, if more than one monitor is used
% scrns = Screen('Screens');
%
% % decide what monitor to calibrate. This won't be asked if there is only
% % one monitor
% if length(scrns)>1,
% if isempty(varargin),
% screenNumber = str2double(input(['Screen number of display to calibrate? [' num2str(scrns) '] '],'s'));
% else
% screenNumber = varargin{1};
% end
% else
% screenNumber = scrns;
% end
%
% if ~IsOctave
% commandwindow;
% pause(.5);
% end
%
% % all information concerning the calibration is put into the structure
% % scal. This structure will contain:
% % screen properties
% scal.screenNumber = screenNumber;
% [scal.windowPtr,scal.rect] = Screen('OpenWindow', screenNumber); % windowPtr: psychtoolbox reference to the active drawing window, % rect: resolution of the active drawing window in pixels [x(1) x(end) y(1) y(end)]
% all dots
scal.XCALIBDOTS = []; scal.YCALIBDOTS = []; % the x and y coordinates of all dots in pixels
scal.XCALIBDOTS_ORG = []; scal.YCALIBDOTS_ORG = []; % the x and y coordinates of all dots at their initial position in pixels
scal.XVALUES = []; scal.YVALUES = []; % probably, these can be removed.
scal.xStep = RectWidth(scal.rect)/(scal.NxdotsG + 1); % distance between dots in x-direction in pixels
scal.yStep = RectHeight(scal.rect)/(scal.NydotsG + 1); % distance between dots in y-direction in pixels
scal.nDots = scal.NxdotsG*scal.NydotsG; % total number of dots on the display
scal.xcm = []; scal.ycm = []; % positions of reference objects (hair crossings in case of the loom) the real world coordinates
% dot selection
scal.FITDOTLIST = []; % indices to the dot selection (index for 'dots' variable that is composed of XCALIBDOTS and YCALIBDOTS (without any further adjustment))
scal.SELECTXCALIBDOTS = []; scal.SELECTYCALIBDOTS = []; % the x and y coordinates of the dot selection in pixels
scal.SELECTXCALIBDOTS_ORG = []; scal.SELECTYCALIBDOTS_ORG = []; % the initial x and y coordinates of the dot selection in pixels (so before any adjustments)
% set the Nth order polynomial
scal.NOrderPoly = 3; % this must be three. Higher order ones cannot be used yet
% start creating the calibration grid
scal = NewCalibFile(scal); % calculate what the positions of the dots in pixels
scal.isDONTSTOP = 1; % only create calibration grid. Don't allow input from user. Continue to next step in calibraiton
scal = manual_calibrate(scal); % This function will update the XCALIBDOTS en YCALIBDOTS (positions of the dots in pixels). It needs an open onscreen window!
scal.isDONTSTOP = 0;
% MK: Disabled...
% eval(['save currentCalib[' num2str(scal.screenNumber) '].mat']); % save the data, just to be sure
% Screen('CloseAll');
% ShowCursor;
|