57ebe2191ddec9a8961fc48fda415794fe464fdb
[blender.git] / source / blender / nodes / composite / node_composite_util.h
1 /*
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19  *
20  * The Original Code is Copyright (C) 2006 Blender Foundation.
21  * All rights reserved.
22  *
23  * The Original Code is: all of this file.
24  *
25  * Contributor(s): none yet.
26  *
27  * ***** END GPL LICENSE BLOCK *****
28  */
29
30 /** \file blender/nodes/composite/node_composite_util.h
31  *  \ingroup nodes
32  */
33
34
35 #ifndef NODE_COMPOSITE_UTIL_H_
36 #define NODE_COMPOSITE_UTIL_H_
37
38 #include <stdlib.h>
39 #include <string.h>
40 #include <math.h>
41
42 #include "MEM_guardedalloc.h"
43
44 #include "DNA_camera_types.h" /* qdn: defocus node, need camera info */
45 #include "DNA_color_types.h"
46 #include "DNA_ID.h"
47 #include "DNA_image_types.h"
48 #include "DNA_material_types.h"
49 #include "DNA_node_types.h"
50 #include "DNA_object_types.h"
51 #include "DNA_scene_types.h"
52 #include "DNA_texture_types.h"
53
54 #include "BLI_math.h"
55 #include "BLI_blenlib.h"
56 #include "BLI_rand.h"
57 #include "BLI_threads.h"
58 #include "BLI_utildefines.h"
59 #include "BLI_utildefines.h"
60
61 #include "BKE_blender.h"
62 #include "BKE_colortools.h"
63 #include "BKE_global.h"
64 #include "BKE_image.h"
65 #include "BKE_main.h"
66 #include "BKE_material.h"
67 #include "BKE_node.h"
68 #include "BKE_texture.h"
69
70 #include "BKE_library.h"
71 #include "BKE_object.h"
72
73 #include "node_util.h"
74
75 #include "IMB_imbuf_types.h"
76 #include "IMB_imbuf.h"
77
78 #include "RE_pipeline.h"
79 #include "RE_shader_ext.h"
80 #include "RE_render_ext.h"
81
82 /* *************************** operations support *************************** */
83
84 /* general signal that's in output sockets, and goes over the wires */
85 typedef struct CompBuf {
86         float *rect;
87         int x, y, xrad, yrad;
88         short type, malloc;
89         rcti disprect;          /* cropped part of image */
90         int xof, yof;           /* relative to center of target image */
91         
92         void (*rect_procedural)(struct CompBuf *, float *, float, float);
93         float procedural_size[3], procedural_offset[3];
94         int procedural_type;
95         bNode *node;            /* only in use for procedural bufs */
96         
97         struct CompBuf *next, *prev;    /* for pass-on, works nicer than reference counting */
98 } CompBuf;
99
100 /* defines also used for pixel size */
101 #define CB_RGBA         4
102 #define CB_VEC4         4
103 #define CB_VEC3         3
104 #define CB_VEC2         2
105 #define CB_VAL          1
106
107 /* defines for RGBA channels */
108 #define CHAN_R  0
109 #define CHAN_G  1
110 #define CHAN_B  2
111 #define CHAN_A  3
112
113
114
115 CompBuf *alloc_compbuf(int sizex, int sizey, int type, int alloc);
116 CompBuf *dupalloc_compbuf(CompBuf *cbuf);
117 CompBuf *pass_on_compbuf(CompBuf *cbuf);
118 void free_compbuf(CompBuf *cbuf);
119 void print_compbuf(char *str, CompBuf *cbuf);
120 void compbuf_set_node(struct CompBuf *cbuf, struct bNode *node);
121 void node_compo_pass_on(struct bNode *node, struct bNodeStack **nsin, struct bNodeStack **nsout);
122
123 CompBuf *get_cropped_compbuf(rcti *drect, float *rectf, int rectx, int recty, int type);
124 CompBuf *scalefast_compbuf(CompBuf *inbuf, int newx, int newy);
125 CompBuf *typecheck_compbuf(CompBuf *inbuf, int type);
126 void typecheck_compbuf_color(float *out, float *in, int outtype, int intype);
127
128 /* **************************************************** */
129
130 /* Pixel-to-Pixel operation, 1 Image in, 1 out */
131 void composit1_pixel_processor(bNode *node, CompBuf *out, CompBuf *src_buf, float *src_col,
132                                                                           void (*func)(bNode *, float *, float *), 
133                                                                           int src_type);
134 /* Pixel-to-Pixel operation, 2 Images in, 1 out */
135 void composit2_pixel_processor(bNode *node, CompBuf *out, CompBuf *src_buf, float *src_col,
136                                                                           CompBuf *fac_buf, float *fac, void (*func)(bNode *, float *, float *, float *), 
137                                                                           int src_type, int fac_type);
138
139 /* Pixel-to-Pixel operation, 3 Images in, 1 out */
140 void composit3_pixel_processor(bNode *node, CompBuf *out, CompBuf *src1_buf, float *src1_col, CompBuf *src2_buf, float *src2_col, 
141                                                                           CompBuf *fac_buf, float *fac, void (*func)(bNode *, float *, float *, float *, float *), 
142                                                                           int src1_type, int src2_type, int fac_type);
143
144 /* Pixel-to-Pixel operation, 4 Images in, 1 out */
145 void composit4_pixel_processor(bNode *node, CompBuf *out, CompBuf *src1_buf, float *src1_col, CompBuf *fac1_buf, float *fac1, 
146                                                                           CompBuf *src2_buf, float *src2_col, CompBuf *fac2_buf, float *fac2, 
147                                                                           void (*func)(bNode *, float *, float *, float *, float *, float *), 
148                                                                           int src1_type, int fac1_type, int src2_type, int fac2_type);
149
150 CompBuf *valbuf_from_rgbabuf(CompBuf *cbuf, int channel);
151 void generate_preview(void *data, bNode *node, CompBuf *stackbuf);
152
153 void do_copy_rgba(bNode *node, float *out, float *in);
154 void do_copy_rgb(bNode *node, float *out, float *in);
155 void do_copy_value(bNode *node, float *out, float *in);
156 void do_copy_a_rgba(bNode *node, float *out, float *in, float *fac);
157
158 void do_rgba_to_yuva(bNode *node, float *out, float *in);
159 void do_rgba_to_hsva(bNode *node, float *out, float *in);
160 void do_rgba_to_ycca(bNode *node, float *out, float *in);
161 void do_yuva_to_rgba(bNode *node, float *out, float *in);
162 void do_hsva_to_rgba(bNode *node, float *out, float *in);
163 void do_ycca_to_rgba(bNode *node, float *out, float *in);
164
165 void gamma_correct_compbuf(CompBuf *img, int inversed);
166 void premul_compbuf(CompBuf *img, int inversed);
167 void convolve(CompBuf* dst, CompBuf* in1, CompBuf* in2);
168
169 extern void node_ID_title_cb(void *node_v, void *unused_v);
170
171
172 /* utility functions used by glare, tonemap and lens distortion */
173 /* soms macros for color handling */
174 typedef float fRGB[4];
175 /* clear color */
176 #define fRGB_clear(c) { c[0]=c[1]=c[2]=0.f; }
177 /* copy c2 to c1 */
178 #define fRGB_copy(c1, c2) { c1[0]=c2[0];  c1[1]=c2[1];  c1[2]=c2[2]; c1[3]=c2[3]; }
179 /* add c2 to c1 */
180 #define fRGB_add(c1, c2) { c1[0]+=c2[0];  c1[1]+=c2[1];  c1[2]+=c2[2]; }
181 /* subtract c2 from c1 */
182 #define fRGB_sub(c1, c2) { c1[0]-=c2[0];  c1[1]-=c2[1];  c1[2]-=c2[2]; }
183 /* multiply c by float value s */
184 #define fRGB_mult(c, s) { c[0]*=s;  c[1]*=s;  c[2]*=s; }
185 /* multiply c2 by s and add to c1 */
186 #define fRGB_madd(c1, c2, s) { c1[0]+=c2[0]*s;  c1[1]+=c2[1]*s;  c1[2]+=c2[2]*s; }
187 /* multiply c2 by color c1 */
188 #define fRGB_colormult(c, cs) { c[0]*=cs[0];  c[1]*=cs[1];  c[2]*=cs[2]; }
189 /* multiply c2 by color c3 and add to c1 */
190 #define fRGB_colormadd(c1, c2, c3) { c1[0]+=c2[0]*c3[0];  c1[1]+=c2[1]*c3[1];  c1[2]+=c2[2]*c3[2]; }
191 /* multiply c2 by color rgb, rgb as separate arguments */
192 #define fRGB_rgbmult(c, r, g, b) { c[0]*=(r);  c[1]*=(g);  c[2]*=(b); }
193 /* swap colors c1 & c2 */
194 #define fRGB_swap(c1, c2) { float _t=c1[0];  c1[0]=c2[0];  c2[0]=_t;\
195                                                                   _t=c1[1];  c1[1]=c2[1];  c2[1]=_t;\
196                                                                   _t=c1[2];  c1[2]=c2[2];  c2[2]=_t;\
197                                                                   _t=c1[3];  c1[3]=c2[3];  c3[3]=_t;}
198
199 void qd_getPixel(CompBuf* src, int x, int y, float* col);
200 void qd_setPixel(CompBuf* src, int x, int y, float* col);
201 void qd_addPixel(CompBuf* src, int x, int y, float* col);
202 void qd_multPixel(CompBuf* src, int x, int y, float f);
203 void qd_getPixelLerpWrap(CompBuf* src, float u, float v, float* col);
204 void qd_getPixelLerp(CompBuf* src, float u, float v, float* col);
205 void qd_getPixelLerpChan(CompBuf* src, float u, float v, int chan, float* out);
206 CompBuf* qd_downScaledCopy(CompBuf* src, int scale);
207 void IIR_gauss(CompBuf* src, float sigma, int chan, int xy);
208 /* end utility funcs */
209
210 #endif