File: SCREENPixelSizes.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,765 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/SCREENPixelSizes.c

    AUTHORS:

    Allen.Ingling@nyu.edu		awi

    PLATFORMS:

    This file should build on any platform.

    HISTORY:

    12/03/02  awi		Created.

    DESCRIPTION:

    Return a list of the valid pixel sizes for the specified screen.

    TO DO:
 */

#include "Screen.h"

// If you change the useString then also change the corresponding synopsis string in ScreenSynopsis.c
static char useString[] = "pixelSizes=Screen('PixelSizes', windowPtrOrScreenNumber)";
static char synopsisString[] =
"List all possible pixelSizes for this screen available at the current height and width settings. "
"pixelSizes refer to the color depth of single pixels in bits - also known as bpp or bits per pixel. "
"If you change height and with settings the avaialable depths might change.";
static char seeAlsoString[] = "Resolutions Resolution";

PsychError SCREENPixelSizes(void)
{
    int screenNumber;
    PsychDepthType depths;
    
    //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.  This also sanity checks against the number of displays.
    PsychCopyInScreenNumberArg(kPsychUseDefaultArgPosition, TRUE, &screenNumber);
    
    //get the screen depths
    PsychInitDepthStruct(&depths);
    PsychGetScreenDepths(screenNumber, &depths);
    
    //Allocate a return matrix and load it with the depth values.
    PsychCopyOutDepthArg(1, FALSE, &depths);
    
    return(PsychError_none);
}