Fixing Makefiles for new nodes module, part 1:
[blender.git] / source / blender / nodes / intern / CMP_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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, 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 #ifndef CMP_NODE_UTILS_H_
31 #define CMP_NODE_UTILS_H_
32
33 #include <stdlib.h>
34 #include <string.h>
35 #include <math.h>
36
37 #include "MEM_guardedalloc.h"
38
39 #include "DNA_camera_types.h" /* qdn: defocus node, need camera info */
40 #include "DNA_action_types.h"
41 #include "DNA_color_types.h"
42 #include "DNA_ipo_types.h"
43 #include "DNA_ID.h"
44 #include "DNA_image_types.h"
45 #include "DNA_material_types.h"
46 #include "DNA_node_types.h"
47 #include "DNA_object_types.h"
48 #include "DNA_scene_types.h"
49 #include "DNA_space_types.h"
50 #include "DNA_screen_types.h"
51 #include "DNA_texture_types.h"
52 #include "DNA_userdef_types.h"
53
54 #include "BKE_blender.h"
55 #include "BKE_colortools.h"
56 #include "BKE_global.h"
57 #include "BKE_image.h"
58 #include "BKE_main.h"
59 #include "BKE_material.h"
60 #include "BKE_texture.h"
61 #include "BKE_utildefines.h"
62 #include "BKE_library.h"
63
64 #include "../CMP_node.h"
65
66 #include "BLI_arithb.h"
67 #include "BLI_blenlib.h"
68 #include "BLI_rand.h"
69 #include "BLI_threads.h"
70
71 #include "IMB_imbuf_types.h"
72 #include "IMB_imbuf.h"
73
74 #include "RE_pipeline.h"
75 #include "RE_shader_ext.h"
76 #include "RE_render_ext.h"
77
78 /* *************************** operations support *************************** */
79
80 /* general signal that's in output sockets, and goes over the wires */
81 typedef struct CompBuf {
82         float *rect;
83         int x, y, xrad, yrad;
84         short type, malloc;
85         rcti disprect;          /* cropped part of image */
86         int xof, yof;           /* relative to center of target image */
87         
88         void (*rect_procedural)(struct CompBuf *, float *, float, float);
89         bNode *node;            /* only in use for procedural bufs */
90         
91         struct CompBuf *next, *prev;    /* for pass-on, works nicer than reference counting */
92 } CompBuf;
93
94 /* defines also used for pixel size */
95 #define CB_RGBA         4
96 #define CB_VEC4         4
97 #define CB_VEC3         3
98 #define CB_VEC2         2
99 #define CB_VAL          1
100
101 /* defines for RGBA channels */
102 #define CHAN_R  0
103 #define CHAN_G  1
104 #define CHAN_B  2
105 #define CHAN_A  3
106
107
108
109 CompBuf *alloc_compbuf(int sizex, int sizey, int type, int alloc);
110 CompBuf *dupalloc_compbuf(CompBuf *cbuf);
111 CompBuf *pass_on_compbuf(CompBuf *cbuf);
112 void free_compbuf(CompBuf *cbuf);
113 void print_compbuf(char *str, CompBuf *cbuf);
114
115 CompBuf *get_cropped_compbuf(rcti *drect, float *rectf, int rectx, int recty, int type);
116 CompBuf *scalefast_compbuf(CompBuf *inbuf, int newx, int newy);
117 CompBuf *typecheck_compbuf(CompBuf *inbuf, int type);
118 float *compbuf_get_pixel(CompBuf *cbuf, float *rectf, int x, int y, int xrad, int yrad);
119
120 /* **************************************************** */
121
122 /* Pixel-to-Pixel operation, 1 Image in, 1 out */
123 void composit1_pixel_processor(bNode *node, CompBuf *out, CompBuf *src_buf, float *src_col,
124                                                                           void (*func)(bNode *, float *, float *), 
125                                                                           int src_type);
126 /* Pixel-to-Pixel operation, 2 Images in, 1 out */
127 void composit2_pixel_processor(bNode *node, CompBuf *out, CompBuf *src_buf, float *src_col,
128                                                                           CompBuf *fac_buf, float *fac, void (*func)(bNode *, float *, float *, float *), 
129                                                                           int src_type, int fac_type);
130
131 /* Pixel-to-Pixel operation, 3 Images in, 1 out */
132 void composit3_pixel_processor(bNode *node, CompBuf *out, CompBuf *src1_buf, float *src1_col, CompBuf *src2_buf, float *src2_col, 
133                                                                           CompBuf *fac_buf, float *fac, void (*func)(bNode *, float *, float *, float *, float *), 
134                                                                           int src1_type, int src2_type, int fac_type);
135
136 /* Pixel-to-Pixel operation, 4 Images in, 1 out */
137 void composit4_pixel_processor(bNode *node, CompBuf *out, CompBuf *src1_buf, float *src1_col, CompBuf *fac1_buf, float *fac1, 
138                                                                           CompBuf *src2_buf, float *src2_col, CompBuf *fac2_buf, float *fac2, 
139                                                                           void (*func)(bNode *, float *, float *, float *, float *, float *), 
140                                                                           int src1_type, int fac1_type, int src2_type, int fac2_type);
141
142 CompBuf *valbuf_from_rgbabuf(CompBuf *cbuf, int channel);
143 void generate_preview(bNode *node, CompBuf *stackbuf);
144
145 void do_copy_rgba(bNode *node, float *out, float *in);
146 void do_copy_rgb(bNode *node, float *out, float *in);
147 void do_copy_value(bNode *node, float *out, float *in);
148 void do_copy_a_rgba(bNode *node, float *out, float *in, float *fac);
149
150 void do_rgba_to_yuva(bNode *node, float *out, float *in);
151 void do_rgba_to_hsva(bNode *node, float *out, float *in);
152 void do_rgba_to_ycca(bNode *node, float *out, float *in);
153 void do_yuva_to_rgba(bNode *node, float *out, float *in);
154 void do_hsva_to_rgba(bNode *node, float *out, float *in);
155 void do_ycca_to_rgba(bNode *node, float *out, float *in);
156
157 void gamma_correct_compbuf(CompBuf *img, int inversed);
158
159 extern void node_ID_title_cb(void *node_v, void *unused_v);
160
161 #endif