Compositor: Speedup movie (un)distortion operation
[blender.git] / source / blender / compositor / operations / COM_MovieDistortionOperation.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  *              Sergey Sharybin
22  */
23
24 #ifndef _COM_MovieDistortionOperation_h_
25 #define _COM_MovieDistortionOperation_h_
26
27 #include "COM_NodeOperation.h"
28 #include "DNA_movieclip_types.h"
29 #include "MEM_guardedalloc.h"
30
31 extern "C" {
32 #  include "BKE_tracking.h"
33 }
34
35 class MovieDistortionOperation : public NodeOperation {
36 private:
37         SocketReader *m_inputOperation;
38         MovieClip *m_movieClip;
39         int m_margin[2];
40
41 protected:
42         bool m_apply;
43         int m_framenumber;
44
45         struct MovieDistortion *m_distortion;
46         int m_calibration_width, m_calibration_height;
47         float m_pixel_aspect;
48
49 public:
50         MovieDistortionOperation(bool distortion);
51         void executePixelSampled(float output[4],
52                                  float x, float y,
53                                  PixelSampler sampler);
54
55         void initExecution();
56         void deinitExecution();
57
58         void setMovieClip(MovieClip *clip) { this->m_movieClip = clip; }
59         void setFramenumber(int framenumber) { this->m_framenumber = framenumber; }
60         bool determineDependingAreaOfInterest(rcti *input,
61                                               ReadBufferOperation *readOperation,
62                                               rcti *output);
63
64 };
65
66 #endif