File: EyelinkImageModeDisplay.c

package info (click to toggle)
psychtoolbox-3 3.0.19.14.dfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 86,796 kB
  • sloc: ansic: 176,245; cpp: 20,103; objc: 5,393; sh: 2,753; python: 1,397; php: 384; makefile: 193; java: 113
file content (96 lines) | stat: -rw-r--r-- 2,741 bytes parent folder | download | duplicates (7)
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
/*

	/osxptb/trunk/PsychSourceGL/Source/OSX/Eyelink/EyelinkImageModeDisplay.c
  
	PROJECTS: Eyelink 
  
	AUTHORS:
		cburns@berkeley.edu				cdb
		E.Peters@ai.rug.nl				emp
		f.w.cornelissen@med.rug.nl		fwc
  
	PLATFORMS:	Currently only OS X  
    
	HISTORY:

		11/23/05  cdb		Created.
		27/03/09  edf       added waiting loop and check that we made it into the mode

	TARGET LOCATION:

		Eyelink.mexmac resides in:
			EyelinkToolbox
*/

#include "PsychEyelink.h"

#define WAIT_MS 10
#define MAX_LOOPS 1000
#define ERR_BUFF_LEN 1000

static char useString[] = "[result =] Eyelink('ImageModeDisplay')";

static char synopsisString[] =
	"This handles display of the EyeLink camera images. "
	"While in imaging mode, it continuously requests "
	"and displays the current camera image. "
	"It also displays the camera name and threshold setting. "
	"Keys on the subject PC keyboard are sent to the tracker "
	"so the experimenter can use it during setup. "
	"It will exit when the tracker leaves "
	"imaging mode or disconnects. "
    "RETURNS: 0 if OK, 32767 (Ox7FFF or TERMINATE_KEY) if pressed, -1 if disconnect";

static char seeAlsoString[] = "";

/*
ROUTINE: EYELINKimagemodedisplay
PURPOSE:
   uses INT16 image_mode_display(void);

	This handles display of the EyeLink camera images
	While in imaging mode, it contiuously requests
	and displays the current camera image
	It also displays the camera name and threshold setting
	Keys on the subject PC keyboard are sent to the tracker
	so the experimenter can use it during setup.
	It will exit when the tracker leaves
	imaging mode or discannects

    RETURNS: 0 if OK, TERMINATE_KEY if pressed, -1 if disconnect*/

PsychError EyelinkImageModeDisplay(void)
{
	int		iResult		= 0;
	
	// Add help strings
	PsychPushHelp(useString, synopsisString, seeAlsoString);
	
	// Output help if asked
	if(PsychIsGiveHelp()) {
		PsychGiveHelp();
		return(PsychError_none);
	}
		
	// Check arguments
	PsychErrorExit(PsychCapNumInputArgs(0));
	PsychErrorExit(PsychRequireNumInputArgs(0));
	PsychErrorExit(PsychCapNumOutputArgs(1));
	
	// Verify eyelink is up and running
	EyelinkSystemIsConnected();
	EyelinkSystemIsInitialized();
	
	// Optionally dump the whole hookfunctions struct:
	if (Verbosity() > 5) { printf("Eyelink-Debug: ImageModeDisplay: PreOp: \n"); PsychEyelink_dumpHookfunctions(); }
	
	iResult = image_mode_display();
	
	// Optionally dump the whole hookfunctions struct:
	if (Verbosity() > 5) { printf("Eyelink-Debug: ImageModeDisplay: PostOp: \n"); PsychEyelink_dumpHookfunctions(); }

	// Assign output arg if available
	PsychCopyOutDoubleArg(1, FALSE, iResult);
	
	return(PsychError_none);
}