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

« back to all changes in this revision

Viewing changes to source/blender/compositor/operations/COM_MixSubtractOperation.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_MixSubtractOperation.h"
24
 
 
25
 
MixSubtractOperation::MixSubtractOperation() : MixBaseOperation()
26
 
{
27
 
        /* pass */
28
 
}
29
 
 
30
 
void MixSubtractOperation::executePixel(float output[4], float x, float y, PixelSampler sampler)
31
 
{
32
 
        float inputColor1[4];
33
 
        float inputColor2[4];
34
 
        float inputValue[4];
35
 
        
36
 
        this->m_inputValueOperation->read(inputValue,   x, y, sampler);
37
 
        this->m_inputColor1Operation->read(inputColor1,   x, y, sampler);
38
 
        this->m_inputColor2Operation->read(inputColor2,   x, y, sampler);
39
 
        
40
 
        float value = inputValue[0];
41
 
        if (this->useValueAlphaMultiply()) {
42
 
                value *= inputColor2[3];
43
 
        }
44
 
        output[0] = inputColor1[0] - value * (inputColor2[0]);
45
 
        output[1] = inputColor1[1] - value * (inputColor2[1]);
46
 
        output[2] = inputColor1[2] - value * (inputColor2[2]);
47
 
        output[3] = inputColor1[3];
48
 
 
49
 
        clampIfNeeded(output);
50
 
}
51