File: AlphaBlendSettingTest.m

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 (119 lines) | stat: -rw-r--r-- 4,671 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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
function failFlag=AlphaBlendSettingTest(screenNumber)

% failFlag=AlphaBlendSettingTest([screenNumber])
%
% Test that Screen('BlendFunction') recalls the same alpha blending values
% as previoulsy set.
%
% If no return argument is provided, then TestAlphaBlendSetting issues an error
% when a test fails.  If a return argument is supplied then it signals a
% failed test only by returning true, without issuing an error.  
%
% See also: AlphaBlendingTest, PsychAlphaBlending


% HISTORY
%
% mm/dd/yy
%
% 1/28/05   awi  Wrote it.



if nargin==0
    screenNumber=max(Screen('Screens'));
end
exitOnError=nargout < 1;
failFlag=0;

background=127;
w=Screen('OpenWindow', screenNumber, [], [], [], 2);
Screen('FillRect', w, background);
wRect=Screen('Rect',w);




%*************** test that we can set and read all allowable blending factors and combinations.

sourceBlendFactors={ 'GL_ZERO', 'GL_ONE', 'GL_DST_COLOR', 'GL_ONE_MINUS_DST_COLOR', 'GL_SRC_ALPHA', 'GL_ONE_MINUS_SRC_ALPHA', 'GL_DST_ALPHA', 'GL_ONE_MINUS_DST_ALPHA', 'GL_SRC_ALPHA_SATURATE'};
destinationBlendFactors={'GL_ZERO','GL_ONE', 'GL_SRC_COLOR', 'GL_ONE_MINUS_SRC_COLOR', 'GL_SRC_ALPHA', 'GL_ONE_MINUS_SRC_ALPHA', 'GL_DST_ALPHA', 'GL_ONE_MINUS_DST_ALPHA'};

numSourceFactors=length(sourceBlendFactors);
numDestinationFactors=length(destinationBlendFactors);
[initialSourceFactor, initialDestinationFactor]=Screen('BlendFunction', w);
for iSource=1:numSourceFactors
    for iDestination=1:numDestinationFactors
 
        if exitOnError
            fprintf('Setting blend function:\n');
            fprintf(['  source:      ' sourceBlendFactors{iSource} '\n']);
            fprintf(['  destination: ' destinationBlendFactors{iDestination} '\n']);
        end
        %test setting both source and destination
        Screen('BlendFunction', w, sourceBlendFactors{iSource}, destinationBlendFactors{iDestination});
        [sourceReport, destinationReport]=Screen('BlendFunction', w);
        if ~strcmp(sourceReport, sourceBlendFactors{iSource})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set source value');
            end
            failFlag=1;
        end
        if ~strcmp(destinationReport, destinationBlendFactors{iDestination})
            error('Screen(''BlendFunction'') failed to read back previosly set destination value');
        end
        %test setting only the destination
        Screen('BlendFunction', w, [], destinationBlendFactors{iDestination});
        [sourceReport, destinationReport]=Screen('BlendFunction', w);
        if ~strcmp(sourceReport, sourceBlendFactors{iSource})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set source value');
            end
            failFlag=1;
        end
        if ~strcmp(destinationReport, destinationBlendFactors{iDestination})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set destination value');
            end
            failFlag=1;
        end
        %test setting only the source using the empty matrix to indicate
        %default
        Screen('BlendFunction', w, sourceBlendFactors{iSource}, []);
        [sourceReport, destinationReport]=Screen('BlendFunction', w);
        if ~strcmp(sourceReport, sourceBlendFactors{iSource})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set source value');
            end
            failFlag=1;
        end
        if ~strcmp(destinationReport, destinationBlendFactors{iDestination})
            error('Screen(''BlendFunction'') failed to read back previosly set destination value');
        end
        %test setting only the source using the no argument to indicate
        %default
        Screen('BlendFunction', w, sourceBlendFactors{iSource});
        [sourceReport, destinationReport]=Screen('BlendFunction', w);
        if ~strcmp(sourceReport, sourceBlendFactors{iSource})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set source value');
            end
            failFlag=1;
        end
        if ~strcmp(destinationReport, destinationBlendFactors{iDestination})
            if exitOnError
                error('Screen(''BlendFunction'') failed to read back previosly set destination value');
            end
            failFlag=1;
        end
        if exitOnError
            fprintf('Passed');
            fprintf('\n\n');
        end
    end
end
Screen('BlendFunction', w, initialSourceFactor, initialDestinationFactor);
        
Screen('Close', w);