Cleanup: style
[blender.git] / source / blender / compositor / operations / COM_DirectionalBlurOperation.h
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 #ifndef __COM_DIRECTIONALBLUROPERATION_H__
24 #define __COM_DIRECTIONALBLUROPERATION_H__
25 #include "COM_NodeOperation.h"
26 #include "COM_QualityStepHelper.h"
27
28 class DirectionalBlurOperation : public NodeOperation, public QualityStepHelper {
29 private:
30         SocketReader *m_inputProgram;
31         NodeDBlurData *m_data;
32
33         float m_center_x_pix, m_center_y_pix;
34         float m_tx, m_ty;
35         float m_sc, m_rot;
36
37 public:
38         DirectionalBlurOperation();
39
40         /**
41          * the inner loop of this program
42          */
43         void executePixel(float output[4], int x, int y, void *data);
44         
45         /**
46          * Initialize the execution
47          */
48         void initExecution();
49         
50         /**
51          * Deinitialize the execution
52          */
53         void deinitExecution();
54         
55         bool determineDependingAreaOfInterest(rcti *input, ReadBufferOperation *readOperation, rcti *output);
56         
57         void setData(NodeDBlurData *data) { this->m_data = data; }
58
59         void executeOpenCL(OpenCLDevice *device,
60                            MemoryBuffer *outputMemoryBuffer, cl_mem clOutputBuffer,
61                            MemoryBuffer **inputMemoryBuffers, list<cl_mem> *clMemToCleanUp,
62                            list<cl_kernel> *clKernelsToCleanUp);
63         
64 };
65 #endif