/usr/share/psychtoolbox-3/PsychHardware/iViewXToolbox/eyeimagetest.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 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 | % iviewx
% 14-12-04 volgende zaken uitgeprobeerd.
% ET_SIM: start eye image
% ET_EIM: end eye image
% ET_IMG : image size
% er komt wel informatie over, maar het is onduidelijk wat deze
% precies betekent. (stukjes van 1336 char, en af en toe ook 15 char
% (die laatste lijken alleen spaces te zijn). Eye image is 384x288
% groot.
% ET_MOV ET_POS
% worden niet herkend door iviewx 1.6 build 10
fprintf([mfilename ' start\n']);
clear all;
try
red.right=KbName('RightArrow');
red.left=KbName('LeftArrow');
red.up=KbName('UpArrow');
red.down=KbName('DownArrow');
red.pos=KbName('p');
pnet('closeall');
host='192.168.1.2';
port=4444;
ivx=iViewXInitDefaults; %([],[], host, port);
ivx;
[result, ivx]=iViewXComm('open', ivx);
result
[result, ivx]=iViewXComm('check', ivx);
result
[success, ivx]=iViewX('setscreensize', ivx);
result=iViewXComm('send', ivx, ['ET_SIM']); % start eye_image
% [result, ivx]=iViewX('stoprecording', ivx);
% params='ET_REC';
% [result, ivx]=iViewX('command', ivx, params);
% params='ET_CAL 9';
% [result, ivx]=iViewX('command', ivx, params);
tEnd=getsecs+300;
while getsecs<tEnd
[keyIsDown,secs,keyCode] = KbCheck;
if 1==keyCode(ivx.modifierKey) && 1==keyCode(ivx.breakKey)
result=-1;
return;
break;
end
% duration=10;
% if 1==keyCode(red.left)
% result=iViewXComm('send', ivx, ['ET_MOV' ' LEFT ' num2str(duration)]);
% elseif 1==keyCode(red.right)
% result=iViewXComm('send', ivx, ['ET_MOV' ' RIGHT ' num2str(duration)]);
% elseif 1==keyCode(red.up)
% result=iViewXComm('send', ivx, ['ET_MOV' ' UP ' num2str(duration)]);
% elseif 1==keyCode(red.down)
% result=iViewXComm('send', ivx, ['ET_MOV' ' DOWN ' num2str(duration)]);
% end
%
if 1==keyCode(red.left)
result=iViewXComm('send', ivx, ['ET_MOV' ' LEFT ']);
elseif 1==keyCode(red.right)
result=iViewXComm('send', ivx, ['ET_MOV' ' RIGHT ']);
elseif 1==keyCode(red.up)
result=iViewXComm('send', ivx, ['ET_MOV' ' UP ' ]);
elseif 1==keyCode(red.down)
result=iViewXComm('send', ivx, ['ET_MOV' ' DOWN ' ]);
end
if 1==keyCode(red.down)
result=iViewXComm('send', ivx, ['ET_MOV' ' POS ' num2str(100) ' ' num2str(100) ]);
end
[data, ivx]=iViewXComm('receive', ivx);
if ~isempty(data)
data;
if strfind(data, 'ET_SPL')
elseif strfind(data, 'ET_CHG')
pt=str2num(data(8:end));
fprintf('Change to point: %d\n', pt);
elseif strfind(data, 'ET_PNT')
coords=str2num(data(8:end));
fprintf('Coords for point %d:\t%d\t%d\n', coords(1), coords(2), coords(3));
elseif strfind(data, 'ET_CSZ')
scr_size=str2num(data(8:end));
fprintf('Screen: %d\t%d\n', scr_size(1), scr_size(2));
elseif strfind(data, 'ET_IMG')
eye_size=str2num(data(8:end));
fprintf('Eye image: %d\t%d (total: %d)\n', eye_size(1), eye_size(2), eye_size(1)* eye_size(2));
ivx.udpmaxread=eye_size(1)* eye_size(2);
ivx.udpreadtimeout=1.0;
[data, ivx]=iViewXComm('receive', ivx);
ivx.udpmaxread=1000;
ivx.udpreadtimeout=0.1;
size(data)
decdata=base64decode(data)
% if length(data)==15
% data
% end
end
end
% result
i=i+1;
drawnow;
end
[result, ivx]=iViewXComm('close', ivx);
result=iViewXComm('send', ivx, ['ET_EIM']);
result
[result, ivx]=iViewX('stoprecording', ivx);
result
pnet('closeall');
fprintf([mfilename ' end\n']);
catch
%this "catch" section executes in case of an error in the "try" section
%above. Importantly, it closes the onscreen window if its open.
pnet('closeall');
Screen('CloseAll'); rethrow(lasterror);
end %try..catch..
|