scale node - framing offset: compatible with camera shiftX/Y and the viewport option.
[blender.git] / source / blender / compositor / operations / COM_ScaleOperation.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_ScaleOperation_h_
24 #define _COM_ScaleOperation_h_
25
26 #include "COM_NodeOperation.h"
27
28 class ScaleOperation : public NodeOperation {
29 private:
30         SocketReader *inputOperation;
31         SocketReader *inputXOperation;
32         SocketReader *inputYOperation;
33         float centerX;
34         float centerY;
35 public:
36         ScaleOperation();
37         bool determineDependingAreaOfInterest(rcti *input, ReadBufferOperation *readOperation, rcti *output);
38         void executePixel(float *color, float x, float y, PixelSampler sampler, MemoryBuffer * inputBuffers[]);
39
40         void initExecution();
41         void deinitExecution();
42 };
43
44 class ScaleAbsoluteOperation : public NodeOperation {
45         SocketReader *inputOperation;
46         SocketReader *inputXOperation;
47         SocketReader *inputYOperation;
48         float centerX;
49         float centerY;
50
51 public:
52         ScaleAbsoluteOperation();
53         bool determineDependingAreaOfInterest(rcti *input, ReadBufferOperation *readOperation, rcti *output);
54         void executePixel(float *color, float x, float y, PixelSampler sampler, MemoryBuffer * inputBuffers[]);
55
56         void initExecution();
57         void deinitExecution();
58 };
59
60 class ScaleFixedSizeOperation : public NodeOperation {
61         SocketReader *inputOperation;
62         int newWidth;
63         int newHeight;
64         float relX;
65         float relY;
66
67         /* center is only used for aspect correction */
68         float offsetX;
69         float offsetY;
70         bool is_aspect;
71         bool is_crop;
72         /* set from other properties on initialization,
73          * check if we need to apply offset */
74         bool is_offset;
75 public:
76         ScaleFixedSizeOperation();
77         bool determineDependingAreaOfInterest(rcti *input, ReadBufferOperation *readOperation, rcti *output);
78         void determineResolution(unsigned int resolution[], unsigned int preferredResolution[]);
79         void executePixel(float *color, float x, float y, PixelSampler sampler, MemoryBuffer * inputBuffers[]);
80
81         void initExecution();
82         void deinitExecution();
83         void setNewWidth(int width) { this->newWidth = width; }
84         void setNewHeight(int height) { this->newHeight = height; }
85         void setIsAspect(bool is_aspect) { this->is_aspect = is_aspect; }
86         void setIsCrop(bool is_crop) { this->is_crop = is_crop; }
87         void setOffset(float x, float y) { this->offsetX = x; this->offsetY = y; }
88 };
89
90 #endif