~ubuntu-branches/ubuntu/utopic/blender/utopic-proposed

« back to all changes in this revision

Viewing changes to source/blender/compositor/operations/COM_MixBurnOperation.cpp

  • Committer: Package Import Robot
  • Author(s): Matthias Klose
  • Date: 2014-02-19 11:24:23 UTC
  • mfrom: (14.2.23 sid)
  • Revision ID: package-import@ubuntu.com-20140219112423-rkmaz2m7ha06d4tk
Tags: 2.69-3ubuntu1
* Merge with Debian; remaining changes:
  - Configure without OpenImageIO on armhf, as it is not available on
    Ubuntu.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * Copyright 2011, Blender Foundation.
3
 
 *
4
 
 * This program is free software; you can redistribute it and/or
5
 
 * modify it under the terms of the GNU General Public License
6
 
 * as published by the Free Software Foundation; either version 2
7
 
 * of the License, or (at your option) any later version.
8
 
 *
9
 
 * This program is distributed in the hope that it will be useful,
10
 
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
 * GNU General Public License for more details.
13
 
 *
14
 
 * You should have received a copy of the GNU General Public License
15
 
 * along with this program; if not, write to the Free Software Foundation,
16
 
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
 
 *
18
 
 * Contributor: 
19
 
 *              Jeroen Bakker 
20
 
 *              Monique Dewanchand
21
 
 */
22
 
 
23
 
#include "COM_MixBurnOperation.h"
24
 
 
25
 
MixBurnOperation::MixBurnOperation() : MixBaseOperation()
26
 
{
27
 
        /* pass */
28
 
}
29
 
 
30
 
void MixBurnOperation::executePixel(float output[4], float x, float y, PixelSampler sampler)
31
 
{
32
 
        float inputColor1[4];
33
 
        float inputColor2[4];
34
 
        float inputValue[4];
35
 
        float tmp;
36
 
        
37
 
        this->m_inputValueOperation->read(inputValue, x, y, sampler);
38
 
        this->m_inputColor1Operation->read(inputColor1, x, y, sampler);
39
 
        this->m_inputColor2Operation->read(inputColor2, x, y, sampler);
40
 
        
41
 
        float value = inputValue[0];
42
 
        if (this->useValueAlphaMultiply()) {
43
 
                value *= inputColor2[3];
44
 
        }
45
 
        float valuem = 1.0f - value;
46
 
        
47
 
        tmp = valuem + value * inputColor2[0];
48
 
        if (tmp <= 0.0f)
49
 
                output[0] = 0.0f;
50
 
        else {
51
 
                tmp = 1.0f - (1.0f - inputColor1[0]) / tmp;
52
 
                if (tmp < 0.0f)
53
 
                        output[0] = 0.0f;
54
 
                else if (tmp > 1.0f)
55
 
                        output[0] = 1.0f;
56
 
                else
57
 
                        output[0] = tmp;
58
 
        }
59
 
        
60
 
        tmp = valuem + value * inputColor2[1];
61
 
        if (tmp <= 0.0f)
62
 
                output[1] = 0.0f;
63
 
        else {
64
 
                tmp = 1.0f - (1.0f - inputColor1[1]) / tmp;
65
 
                if (tmp < 0.0f)
66
 
                        output[1] = 0.0f;
67
 
                else if (tmp > 1.0f)
68
 
                        output[1] = 1.0f;
69
 
                else
70
 
                        output[1] = tmp;
71
 
        }
72
 
        
73
 
        tmp = valuem + value * inputColor2[2];
74
 
        if (tmp <= 0.0f)
75
 
                output[2] = 0.0f;
76
 
        else {
77
 
                tmp = 1.0f - (1.0f - inputColor1[2]) / tmp;
78
 
                if (tmp < 0.0f)
79
 
                        output[2] = 0.0f;
80
 
                else if (tmp > 1.0f)
81
 
                        output[2] = 1.0f;
82
 
                else
83
 
                        output[2] = tmp;
84
 
        }
85
 
        
86
 
        output[3] = inputColor1[3];
87
 
 
88
 
        clampIfNeeded(output);
89
 
}
90