File: SCREENPixelSize.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 (57 lines) | stat: -rw-r--r-- 1,762 bytes parent folder | download | duplicates (6)
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
/*
    Psychtoolbox3/Source/Common/SCREENPixelSize.c

    AUTHORS:
    Allen.Ingling@nyu.edu   awi

    PLATFORMS:
    This file should build on any platform.

    HISTORY:
    1/14/03  awi    Created.

    DESCRIPTION:

    Return the current pixel size of a screen or window.

*/

#include "Screen.h"

// If you change the useString then also change the corresponding synopsis string in ScreenSynopsis.c
static char useString[] = "pixelSize=Screen('PixelSize', windowPtrOrScreenNumber)";
static char synopsisString[] =
    "Return the current pixel size of a screen or window. "
    "pixel size refers to the color depth of a pixel in bits - also known as bpp or bits per pixel, "
    "not to spatial size of the pixel. ";
static char seeAlsoString[] = "";

PsychError SCREENPixelSize(void)
{
    int     screenNumber;
    double  depth = 0;
    PsychWindowRecordType   *windowRecord;

    //all sub functions should have these two lines
    PsychPushHelp(useString, synopsisString, seeAlsoString);
    if(PsychIsGiveHelp()){PsychGiveHelp();return(PsychError_none);};

    //check to see if the user supplied superfluous arguments
    PsychErrorExit(PsychCapNumOutputArgs(1));
    PsychErrorExit(PsychCapNumInputArgs(1));

    //get specified screen number.
    if(PsychIsScreenNumberArg(1)){
        PsychCopyInScreenNumberArg(1, TRUE, &screenNumber);
        depth=(double)PsychGetScreenDepthValue(screenNumber);
    }else if(PsychIsWindowIndexArg(1)){
        PsychAllocInWindowRecordArg(1,TRUE,&windowRecord);
        depth=(double)windowRecord->depth;
    }else
        PsychErrorExit(PsychError_invalidNumdex);

    //Allocate a return matrix and load it with the depth values.
    PsychCopyOutDoubleArg(1, FALSE, depth);

    return(PsychError_none);
}