Merging r46725 through r46963 from trunk into soc-2011-tomato
[blender.git] / source / blender / blenkernel / BKE_node.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
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  * The Original Code is Copyright (C) 2005 Blender Foundation.
19  * All rights reserved.
20  *
21  * The Original Code is: all of this file.
22  *
23  * Contributor(s): Bob Holcomb.
24  *
25  * ***** END GPL LICENSE BLOCK *****
26  */
27
28 #ifndef __BKE_NODE_H__
29 #define __BKE_NODE_H__
30
31 /** \file BKE_node.h
32  *  \ingroup bke
33  */
34
35 #include "DNA_listBase.h"
36
37 #include "RNA_types.h"
38
39 /* not very important, but the stack solver likes to know a maximum */
40 #define MAX_SOCKET      64
41
42 struct bContext;
43 struct bNode;
44 struct bNodeLink;
45 struct bNodeSocket;
46 struct bNodeStack;
47 struct bNodeTree;
48 struct bNodeTreeExec;
49 struct GPUMaterial;
50 struct GPUNode;
51 struct GPUNodeStack;
52 struct ID;
53 struct ImageFormatData;
54 struct ListBase;
55 struct Main;
56 struct uiBlock;
57 struct uiLayout;
58 struct MTex;
59 struct PointerRNA;
60 struct rctf;
61 struct RenderData;
62 struct Scene;
63 struct Tex;
64 struct SpaceNode;
65 struct ARegion;
66 struct Object;
67
68 /* ************** NODE TYPE DEFINITIONS ***** */
69
70 /** Compact definition of a node socket.
71  * Can be used to quickly define a list of static sockets for a node,
72  * which are added to each new node of that type. 
73  *
74  * \deprecated New nodes should add default sockets in the initialization
75  * function instead. This struct is mostly kept for old nodes and should
76  * be removed some time.
77  */
78 typedef struct bNodeSocketTemplate {
79         int type, limit;
80         char name[64];  /* MAX_NAME */
81         float val1, val2, val3, val4;   /* default alloc value for inputs */
82         float min, max;
83         PropertySubType subtype;
84         int flag;
85         
86         /* after this line is used internal only */
87         struct bNodeSocket *sock;               /* used to hold verified socket */
88 } bNodeSocketTemplate;
89
90 typedef void (*NodeSocketButtonFunction)(const struct bContext *C, struct uiBlock *block, 
91                                                                                  struct bNodeTree *ntree, struct bNode *node, struct bNodeSocket *sock,
92                                                                                  const char *name, int x, int y, int width);
93
94 /** Defines a socket type.
95  * Defines the appearance and behavior of a socket in the UI.
96  */
97 typedef struct bNodeSocketType {
98         int type;
99         char ui_name[64];       /* MAX_NAME */
100         char ui_description[128];
101         int ui_icon;
102         char ui_color[4];
103         
104         const char *value_structname;
105         int value_structsize;
106         
107         NodeSocketButtonFunction buttonfunc;
108 } bNodeSocketType;
109
110 /** Template for creating a node.
111  * Stored required parameters to make a new node of a specific type.
112  */
113 typedef struct bNodeTemplate {
114         int type;
115         
116         struct Main *main;
117         struct Scene *scene;
118         struct bNodeTree *ngroup;       /* group tree */
119 } bNodeTemplate;
120
121 /** Defines a node type.
122  * Initial attributes and constants for a node as well as callback functions
123  * implementing the node behavior.
124  */
125 typedef struct bNodeType {
126         void *next, *prev;
127         short needs_free;               /* set for allocated types that need to be freed */
128         
129         int type;
130         char name[64];  /* MAX_NAME */
131         float width, minwidth, maxwidth;
132         float height, minheight, maxheight;
133         short nclass, flag, compatibility;
134         
135         /* templates for static sockets */
136         bNodeSocketTemplate *inputs, *outputs;
137         
138         char storagename[64];                   /* struct name for DNA */
139         
140         /// Main draw function for the node.
141         void (*drawfunc)(const struct bContext *C, struct ARegion *ar, struct SpaceNode *snode, struct bNodeTree *ntree, struct bNode *node);
142         /// Updates the node geometry attributes according to internal state before actual drawing.
143         void (*drawupdatefunc)(const struct bContext *C, struct bNodeTree *ntree, struct bNode *node);
144         /// Draw the option buttons on the node.
145         void (*uifunc)(struct uiLayout *, struct bContext *C, struct PointerRNA *ptr);
146         /// Additional parameters in the side panel.
147         void (*uifuncbut)(struct uiLayout *, struct bContext *C, struct PointerRNA *ptr);
148         /// Additional drawing on backdrop.
149         void (*uibackdropfunc)(struct SpaceNode* snode, struct ImBuf* backdrop, struct bNode* node, int x, int y);
150
151         /// Draw a node socket. Default draws the input value button.
152         NodeSocketButtonFunction drawinputfunc;
153         NodeSocketButtonFunction drawoutputfunc;
154
155         /// Optional custom label function for the node header.
156         const char *(*labelfunc)(struct bNode *);
157         /// Optional custom resize handle polling.
158         int (*resize_area_func)(struct bNode *node, int x, int y);
159         
160         /// Called when the node is updated in the editor.
161         void (*updatefunc)(struct bNodeTree *ntree, struct bNode *node);
162         /// Check and update if internal ID data has changed.
163         void (*verifyfunc)(struct bNodeTree *ntree, struct bNode *node, struct ID *id);
164         
165         /// Initialize a new node instance of this type after creation.
166         void (*initfunc)(struct bNodeTree *ntree, struct bNode *node, struct bNodeTemplate *ntemp);
167         /// Free the custom storage data.
168         void (*freestoragefunc)(struct bNode *node);
169         /// Make a copy of the custom storage data.
170         void (*copystoragefunc)(struct bNode *node, struct bNode *target);
171         
172         /// Create a template from an existing node.
173         struct bNodeTemplate (*templatefunc)(struct bNode *);
174         /** If a node can be made from the template in the given node tree.
175          * \note Node groups can not be created inside their own node tree.
176          */
177         int (*validfunc)(struct bNodeTree *ntree, struct bNodeTemplate *ntemp);
178         
179         /// Initialize a node tree associated to this node type.
180         void (*inittreefunc)(struct bNodeTree *ntree);
181         /// Update a node tree associated to this node type.
182         void (*updatetreefunc)(struct bNodeTree *ntree);
183         
184         /* group edit callbacks for operators */
185         /* XXX this is going to be changed as required by the UI */
186         struct bNodeTree *(*group_edit_get)(struct bNode *node);
187         struct bNodeTree *(*group_edit_set)(struct bNode *node, int edit);
188         void (*group_edit_clear)(struct bNode *node);
189         
190         /* Generate a temporary list of internal links (bNodeLink), for muting and disconnect operators.
191          * Result must be freed by caller!
192          */
193         ListBase (*internal_connect)(struct bNodeTree *, struct bNode *node);
194         
195         /* **** execution callbacks **** */
196         void *(*initexecfunc)(struct bNode *node);
197         void (*freeexecfunc)(struct bNode *node, void *nodedata);
198         void (*execfunc)(void *data, struct bNode *, struct bNodeStack **, struct bNodeStack **);
199         /* XXX this alternative exec function has been added to avoid changing all node types.
200          * when a final generic version of execution code is defined, this will be changed anyway
201          */
202         void (*newexecfunc)(void *data, int thread, struct bNode *, void *nodedata, struct bNodeStack **, struct bNodeStack **);
203         /* gpu */
204         int (*gpufunc)(struct GPUMaterial *mat, struct bNode *node, struct GPUNodeStack *in, struct GPUNodeStack *out);
205         /* extended gpu function */
206         int (*gpuextfunc)(struct GPUMaterial *mat, struct bNode *node, void *nodedata, struct GPUNodeStack *in, struct GPUNodeStack *out);
207 } bNodeType;
208
209 /* node->exec, now in use for composites (#define for break is same as ready yes) */
210 #define NODE_PROCESSING 1
211 #define NODE_READY              2
212 #define NODE_BREAK              2
213 #define NODE_FINISHED   4
214 #define NODE_FREEBUFS   8
215 #define NODE_SKIPPED    16
216
217 /* sim_exec return value */
218 #define NODE_EXEC_FINISHED      0
219 #define NODE_EXEC_SUSPEND       1
220
221 /* nodetype->nclass, for add-menu and themes */
222 #define NODE_CLASS_INPUT                        0
223 #define NODE_CLASS_OUTPUT                       1
224 #define NODE_CLASS_OP_COLOR                     3
225 #define NODE_CLASS_OP_VECTOR            4
226 #define NODE_CLASS_OP_FILTER            5
227 #define NODE_CLASS_GROUP                        6
228 #define NODE_CLASS_FILE                         7
229 #define NODE_CLASS_CONVERTOR            8
230 #define NODE_CLASS_MATTE                        9
231 #define NODE_CLASS_DISTORT                      10
232 #define NODE_CLASS_OP_DYNAMIC           11
233 #define NODE_CLASS_PATTERN                      12
234 #define NODE_CLASS_TEXTURE                      13
235 #define NODE_CLASS_EXECUTION            14
236 #define NODE_CLASS_GETDATA                      15
237 #define NODE_CLASS_SETDATA                      16
238 #define NODE_CLASS_MATH                         17
239 #define NODE_CLASS_MATH_VECTOR          18
240 #define NODE_CLASS_MATH_ROTATION        19
241 #define NODE_CLASS_PARTICLES            25
242 #define NODE_CLASS_TRANSFORM            30
243 #define NODE_CLASS_COMBINE                      31
244 #define NODE_CLASS_SHADER                       40
245 #define NODE_CLASS_LAYOUT                       100
246
247 /* nodetype->compatibility */
248 #define NODE_OLD_SHADING        1
249 #define NODE_NEW_SHADING        2
250
251 /* node resize directions */
252 #define NODE_RESIZE_TOP         1
253 #define NODE_RESIZE_BOTTOM      2
254 #define NODE_RESIZE_RIGHT       4
255 #define NODE_RESIZE_LEFT        8
256
257 /* enum values for input/output */
258 #define SOCK_IN         1
259 #define SOCK_OUT        2
260
261 struct bNodeTreeExec;
262
263 typedef void (*bNodeTreeCallback)(void *calldata, struct ID *owner_id, struct bNodeTree *ntree);
264 typedef void (*bNodeClassCallback)(void *calldata, int nclass, const char *name);
265 typedef struct bNodeTreeType
266 {
267         int type;                                               /* type identifier */
268         char idname[64];                                /* id name for RNA identification */
269         
270         ListBase node_types;                    /* type definitions */
271         
272         /* callbacks */
273         void (*free_cache)(struct bNodeTree *ntree);
274         void (*free_node_cache)(struct bNodeTree *ntree, struct bNode *node);
275         void (*foreach_nodetree)(struct Main *main, void *calldata, bNodeTreeCallback func);            /* iteration over all node trees */
276         void (*foreach_nodeclass)(struct Scene *scene, void *calldata, bNodeClassCallback func);        /* iteration over all node classes */
277
278         /* calls allowing threaded composite */
279         void (*localize)(struct bNodeTree *localtree, struct bNodeTree *ntree);
280         void (*local_sync)(struct bNodeTree *localtree, struct bNodeTree *ntree);
281         void (*local_merge)(struct bNodeTree *localtree, struct bNodeTree *ntree);
282
283         /* Tree update. Overrides nodetype->updatetreefunc! */
284         void (*update)(struct bNodeTree *ntree);
285         /* Node update. Overrides nodetype->updatefunc! */
286         void (*update_node)(struct bNodeTree *ntree, struct bNode *node);
287         
288         int (*validate_link)(struct bNodeTree *ntree, struct bNodeLink *link);
289
290         /* Default internal linking. */
291         ListBase (*internal_connect)(struct bNodeTree *, struct bNode *node);
292 } bNodeTreeType;
293
294 /* ************** GENERIC API, TREES *************** */
295
296 struct bNodeTreeType *ntreeGetType(int type);
297 struct bNodeType *ntreeGetNodeType(struct bNodeTree *ntree);
298 struct bNodeSocketType *ntreeGetSocketType(int type);
299
300 struct bNodeTree *ntreeAddTree(const char *name, int type, int nodetype);
301 void                    ntreeInitTypes(struct bNodeTree *ntree);
302
303 void                    ntreeFreeTree(struct bNodeTree *ntree);
304 struct bNodeTree *ntreeCopyTree(struct bNodeTree *ntree);
305 void                    ntreeSwitchID(struct bNodeTree *ntree, struct ID *sce_from, struct ID *sce_to);
306 void                    ntreeMakeLocal(struct bNodeTree *ntree);
307 int                             ntreeHasType(struct bNodeTree *ntree, int type);
308
309 void                    ntreeUpdateTree(struct bNodeTree *ntree);
310 /* XXX Currently each tree update call does call to ntreeVerifyNodes too.
311  * Some day this should be replaced by a decent depsgraph automatism!
312  */
313 void                    ntreeVerifyNodes(struct Main *main, struct ID *id);
314
315 void                    ntreeGetDependencyList(struct bNodeTree *ntree, struct bNode ***deplist, int *totnodes);
316
317 /* XXX old trees handle output flags automatically based on special output node types and last active selection.
318  * new tree types have a per-output socket flag to indicate the final output to use explicitly.
319  */
320 void                    ntreeSetOutput(struct bNodeTree *ntree);
321 void                    ntreeInitPreview(struct bNodeTree *, int xsize, int ysize);
322 void                    ntreeClearPreview(struct bNodeTree *ntree);
323
324 void                    ntreeFreeCache(struct bNodeTree *ntree);
325
326 int                             ntreeNodeExists(struct bNodeTree *ntree, struct bNode *testnode);
327 int                             ntreeOutputExists(struct bNode *node, struct bNodeSocket *testsock);
328 struct bNodeTree *ntreeLocalize(struct bNodeTree *ntree);
329 void                    ntreeLocalSync(struct bNodeTree *localtree, struct bNodeTree *ntree);
330 void                    ntreeLocalMerge(struct bNodeTree *localtree, struct bNodeTree *ntree);
331
332 /* ************** GENERIC API, NODES *************** */
333
334 struct bNodeSocket *nodeAddSocket(struct bNodeTree *ntree, struct bNode *node, int in_out, const char *name, int type);
335 struct bNodeSocket *nodeInsertSocket(struct bNodeTree *ntree, struct bNode *node, int in_out, struct bNodeSocket *next_sock, const char *name, int type);
336 void nodeRemoveSocket(struct bNodeTree *ntree, struct bNode *node, struct bNodeSocket *sock);
337 void nodeRemoveAllSockets(struct bNodeTree *ntree, struct bNode *node);
338
339 void                    nodeAddToPreview(struct bNode *, float *, int, int, int);
340
341 struct bNode    *nodeAddNode(struct bNodeTree *ntree, struct bNodeTemplate *ntemp);
342 void                    nodeUnlinkNode(struct bNodeTree *ntree, struct bNode *node);
343 void                    nodeUniqueName(struct bNodeTree *ntree, struct bNode *node);
344
345 void                    nodeRegisterType(struct bNodeTreeType *ttype, struct bNodeType *ntype);
346 void                    nodeMakeDynamicType(struct bNode *node);
347 int                             nodeDynamicUnlinkText(struct ID *txtid);
348
349 void                    nodeFreeNode(struct bNodeTree *ntree, struct bNode *node);
350 struct bNode    *nodeCopyNode(struct bNodeTree *ntree, struct bNode *node);
351
352 struct bNodeLink *nodeAddLink(struct bNodeTree *ntree, struct bNode *fromnode, struct bNodeSocket *fromsock, struct bNode *tonode, struct bNodeSocket *tosock);
353 void                    nodeRemLink(struct bNodeTree *ntree, struct bNodeLink *link);
354 void                    nodeRemSocketLinks(struct bNodeTree *ntree, struct bNodeSocket *sock);
355 void                    nodeInternalRelink(struct bNodeTree *ntree, struct bNode *node);
356
357 void                    nodeToView(struct bNode *node, float x, float y, float *rx, float *ry);
358 void                    nodeFromView(struct bNode *node, float x, float y, float *rx, float *ry);
359 void                    nodeAttachNode(struct bNode *node, struct bNode *parent);
360 void                    nodeDetachNode(struct bNode *node);
361
362 struct bNode    *nodeFindNodebyName(struct bNodeTree *ntree, const char *name);
363 int                             nodeFindNode(struct bNodeTree *ntree, struct bNodeSocket *sock, struct bNode **nodep, int *sockindex, int *in_out);
364
365 struct bNodeLink *nodeFindLink(struct bNodeTree *ntree, struct bNodeSocket *from, struct bNodeSocket *to);
366 int                             nodeCountSocketLinks(struct bNodeTree *ntree, struct bNodeSocket *sock);
367
368 void                    nodeSetActive(struct bNodeTree *ntree, struct bNode *node);
369 struct bNode    *nodeGetActive(struct bNodeTree *ntree);
370 struct bNode    *nodeGetActiveID(struct bNodeTree *ntree, short idtype);
371 int                             nodeSetActiveID(struct bNodeTree *ntree, short idtype, struct ID *id);
372 void                    nodeClearActiveID(struct bNodeTree *ntree, short idtype);
373 struct bNode    *nodeGetActiveTexture(struct bNodeTree *ntree);
374
375 void                    nodeUpdate(struct bNodeTree *ntree, struct bNode *node);
376 int                             nodeUpdateID(struct bNodeTree *ntree, struct ID *id);
377
378 void                    nodeFreePreview(struct bNode *node);
379
380 int                             nodeSocketIsHidden(struct bNodeSocket *sock);
381 void                    nodeSocketSetType(struct bNodeSocket *sock, int type);
382
383 /* ************** NODE TYPE ACCESS *************** */
384
385 struct bNodeTemplate nodeMakeTemplate(struct bNode *node);
386 int                             nodeValid(struct bNodeTree *ntree, struct bNodeTemplate *ntemp);
387 const char*             nodeLabel(struct bNode *node);
388 struct bNodeTree *nodeGroupEditGet(struct bNode *node);
389 struct bNodeTree *nodeGroupEditSet(struct bNode *node, int edit);
390 void                    nodeGroupEditClear(struct bNode *node);
391
392 /* Init a new node type struct with default values and callbacks */
393 void                    node_type_base(struct bNodeTreeType *ttype, struct bNodeType *ntype, int type,
394                                const char *name, short nclass, short flag);
395 void                    node_type_socket_templates(struct bNodeType *ntype, struct bNodeSocketTemplate *inputs, struct bNodeSocketTemplate *outputs);
396 void                    node_type_size(struct bNodeType *ntype, int width, int minwidth, int maxwidth);
397 void                    node_type_init(struct bNodeType *ntype, void (*initfunc)(struct bNodeTree *ntree, struct bNode *node, struct bNodeTemplate *ntemp));
398 void                    node_type_valid(struct bNodeType *ntype, int (*validfunc)(struct bNodeTree *ntree, struct bNodeTemplate *ntemp));
399 void                    node_type_storage(struct bNodeType *ntype,
400                                                                   const char *storagename,
401                                                                   void (*freestoragefunc)(struct bNode *),
402                                                                   void (*copystoragefunc)(struct bNode *, struct bNode *));
403 void                    node_type_label(struct bNodeType *ntype, const char *(*labelfunc)(struct bNode *));
404 void                    node_type_template(struct bNodeType *ntype, struct bNodeTemplate (*templatefunc)(struct bNode *));
405 void                    node_type_update(struct bNodeType *ntype,
406                                                                  void (*updatefunc)(struct bNodeTree *ntree, struct bNode *node),
407                                                                  void (*verifyfunc)(struct bNodeTree *ntree, struct bNode *node, struct ID *id));
408 void                    node_type_tree(struct bNodeType *ntype,
409                                                            void (*inittreefunc)(struct bNodeTree *),
410                                                            void (*updatetreefunc)(struct bNodeTree *));
411 void                    node_type_group_edit(struct bNodeType *ntype,
412                                                                          struct bNodeTree *(*group_edit_get)(struct bNode *node),
413                                                                          struct bNodeTree *(*group_edit_set)(struct bNode *node, int edit),
414                                                                          void (*group_edit_clear)(struct bNode *node));
415
416 void                    node_type_exec(struct bNodeType *ntype, void (*execfunc)(void *data, struct bNode *, struct bNodeStack **,
417                                                                          struct bNodeStack **));
418 void                    node_type_exec_new(struct bNodeType *ntype,
419                                                                    void *(*initexecfunc)(struct bNode *node),
420                                                                    void (*freeexecfunc)(struct bNode *node, void *nodedata),
421                                                                    void (*newexecfunc)(void *data, int thread, struct bNode *, void *nodedata,
422                                                                                        struct bNodeStack **, struct bNodeStack **));
423 void                    node_type_internal_connect(struct bNodeType *ntype, ListBase (*internal_connect)(struct bNodeTree *, struct bNode *));
424 void                    node_type_gpu(struct bNodeType *ntype, int (*gpufunc)(struct GPUMaterial *mat, struct bNode *node,
425                                                                       struct GPUNodeStack *in, struct GPUNodeStack *out));
426 void                    node_type_gpu_ext(struct bNodeType *ntype, int (*gpuextfunc)(struct GPUMaterial *mat, struct bNode *node,
427                                                                              void *nodedata, struct GPUNodeStack *in,
428                                                                              struct GPUNodeStack *out));
429 void                    node_type_compatibility(struct bNodeType *ntype, short compatibility);
430
431 /* ************** COMMON NODES *************** */
432
433 #define NODE_GROUP              2
434 #define NODE_FORLOOP    3
435 #define NODE_WHILELOOP  4
436 #define NODE_FRAME              5
437 #define NODE_GROUP_MENU         10000
438 #define NODE_DYNAMIC_MENU       20000
439
440 /* look up a socket on a group node by the internal group socket */
441 struct bNodeSocket *node_group_find_input(struct bNode *gnode, struct bNodeSocket *gsock);
442 struct bNodeSocket *node_group_find_output(struct bNode *gnode, struct bNodeSocket *gsock);
443
444 struct bNodeSocket *node_group_add_socket(struct bNodeTree *ngroup, const char *name, int type, int in_out);
445 struct bNodeSocket *node_group_expose_socket(struct bNodeTree *ngroup, struct bNodeSocket *sock, int in_out);
446 void node_group_expose_all_sockets(struct bNodeTree *ngroup);
447 void node_group_remove_socket(struct bNodeTree *ngroup, struct bNodeSocket *gsock, int in_out);
448
449 struct bNode    *node_group_make_from_selected(struct bNodeTree *ntree);
450 int                             node_group_ungroup(struct bNodeTree *ntree, struct bNode *gnode);
451
452 /* in node_common.c */
453 void register_node_type_frame(struct bNodeTreeType *ttype);
454
455 /* ************** SHADER NODES *************** */
456
457 struct ShadeInput;
458 struct ShadeResult;
459
460 /* note: types are needed to restore callbacks, don't change values */
461 /* range 1 - 100 is reserved for common nodes */
462 /* using toolbox, we add node groups by assuming the values below don't exceed NODE_GROUP_MENU for now */
463
464 #define SH_NODE_OUTPUT          1
465
466 #define SH_NODE_MATERIAL        100
467 #define SH_NODE_RGB                     101
468 #define SH_NODE_VALUE           102
469 #define SH_NODE_MIX_RGB         103
470 #define SH_NODE_VALTORGB        104
471 #define SH_NODE_RGBTOBW         105
472 #define SH_NODE_TEXTURE         106
473 #define SH_NODE_NORMAL          107
474 #define SH_NODE_GEOMETRY        108
475 #define SH_NODE_MAPPING         109
476 #define SH_NODE_CURVE_VEC       110
477 #define SH_NODE_CURVE_RGB       111
478 #define SH_NODE_CAMERA          114
479 #define SH_NODE_MATH            115
480 #define SH_NODE_VECT_MATH       116
481 #define SH_NODE_SQUEEZE         117
482 #define SH_NODE_MATERIAL_EXT    118
483 #define SH_NODE_INVERT          119
484 #define SH_NODE_SEPRGB          120
485 #define SH_NODE_COMBRGB         121
486 #define SH_NODE_HUE_SAT         122
487 #define NODE_DYNAMIC            123
488
489 #define SH_NODE_OUTPUT_MATERIAL                 124
490 #define SH_NODE_OUTPUT_WORLD                    125
491 #define SH_NODE_OUTPUT_LAMP                             126
492 #define SH_NODE_FRESNEL                                 127
493 #define SH_NODE_MIX_SHADER                              128
494 #define SH_NODE_ATTRIBUTE                               129
495 #define SH_NODE_BACKGROUND                              130
496 #define SH_NODE_BSDF_ANISOTROPIC                131
497 #define SH_NODE_BSDF_DIFFUSE                    132
498 #define SH_NODE_BSDF_GLOSSY                             133
499 #define SH_NODE_BSDF_GLASS                              134
500 #define SH_NODE_BSDF_TRANSLUCENT                137
501 #define SH_NODE_BSDF_TRANSPARENT                138
502 #define SH_NODE_BSDF_VELVET                             139
503 #define SH_NODE_EMISSION                                140
504 #define SH_NODE_NEW_GEOMETRY                    141
505 #define SH_NODE_LIGHT_PATH                              142
506 #define SH_NODE_TEX_IMAGE                               143
507 #define SH_NODE_TEX_SKY                                 145
508 #define SH_NODE_TEX_GRADIENT                    146
509 #define SH_NODE_TEX_VORONOI                             147
510 #define SH_NODE_TEX_MAGIC                               148
511 #define SH_NODE_TEX_WAVE                                149
512 #define SH_NODE_TEX_NOISE                               150
513 #define SH_NODE_TEX_MUSGRAVE                    152
514 #define SH_NODE_TEX_COORD                               155
515 #define SH_NODE_ADD_SHADER                              156
516 #define SH_NODE_TEX_ENVIRONMENT                 157
517 #define SH_NODE_OUTPUT_TEXTURE                  158
518 #define SH_NODE_HOLDOUT                                 159
519 #define SH_NODE_LAYER_WEIGHT                    160
520 #define SH_NODE_VOLUME_TRANSPARENT              161
521 #define SH_NODE_VOLUME_ISOTROPIC                162
522 #define SH_NODE_GAMMA                                   163
523 #define SH_NODE_TEX_CHECKER                             164
524 #define SH_NODE_BRIGHTCONTRAST                  165
525 #define SH_NODE_LIGHT_FALLOFF                   166
526 #define SH_NODE_OBJECT_INFO                             167
527
528 /* custom defines options for Material node */
529 #define SH_NODE_MAT_DIFF   1
530 #define SH_NODE_MAT_SPEC   2
531 #define SH_NODE_MAT_NEG    4
532 /* custom defines: states for Script node. These are bit indices */
533 #define NODE_DYNAMIC_READY      0 /* 1 */
534 #define NODE_DYNAMIC_LOADED     1 /* 2 */
535 #define NODE_DYNAMIC_NEW        2 /* 4 */
536 #define NODE_DYNAMIC_UPDATED    3 /* 8 */
537 #define NODE_DYNAMIC_ADDEXIST   4 /* 16 */
538 #define NODE_DYNAMIC_ERROR      5 /* 32 */
539 #define NODE_DYNAMIC_REPARSE    6 /* 64 */
540 #define NODE_DYNAMIC_SET        15 /* sign */
541
542 /* API */
543
544 struct bNodeTreeExec *ntreeShaderBeginExecTree(struct bNodeTree *ntree, int use_tree_data);
545 void                    ntreeShaderEndExecTree(struct bNodeTreeExec *exec, int use_tree_data);
546 void                    ntreeShaderExecTree(struct bNodeTree *ntree, struct ShadeInput *shi, struct ShadeResult *shr);
547 void                    ntreeShaderGetTexcoMode(struct bNodeTree *ntree, int osa, short *texco, int *mode);
548 void                    nodeShaderSynchronizeID(struct bNode *node, int copyto);
549
550                                 /* switch material render loop */
551 extern void (*node_shader_lamp_loop)(struct ShadeInput *, struct ShadeResult *);
552 void                    set_node_shader_lamp_loop(void (*lamp_loop_func)(struct ShadeInput *, struct ShadeResult *));
553
554 void                    ntreeGPUMaterialNodes(struct bNodeTree *ntree, struct GPUMaterial *mat);
555
556
557 /* ************** COMPOSITE NODES *************** */
558
559 /* output socket defines */
560 #define RRES_OUT_IMAGE                          0
561 #define RRES_OUT_ALPHA                          1
562 #define RRES_OUT_Z                                      2
563 #define RRES_OUT_NORMAL                         3
564 #define RRES_OUT_UV                                     4
565 #define RRES_OUT_VEC                            5
566 #define RRES_OUT_RGBA                           6
567 #define RRES_OUT_DIFF                           7
568 #define RRES_OUT_SPEC                           8
569 #define RRES_OUT_SHADOW                         9
570 #define RRES_OUT_AO                                     10
571 #define RRES_OUT_REFLECT                        11
572 #define RRES_OUT_REFRACT                        12
573 #define RRES_OUT_INDIRECT                       13
574 #define RRES_OUT_INDEXOB                        14
575 #define RRES_OUT_INDEXMA                        15
576 #define RRES_OUT_MIST                           16
577 #define RRES_OUT_EMIT                           17
578 #define RRES_OUT_ENV                            18
579 #define RRES_OUT_DIFF_DIRECT            19
580 #define RRES_OUT_DIFF_INDIRECT          20
581 #define RRES_OUT_DIFF_COLOR                     21
582 #define RRES_OUT_GLOSSY_DIRECT          22
583 #define RRES_OUT_GLOSSY_INDIRECT        23
584 #define RRES_OUT_GLOSSY_COLOR           24
585 #define RRES_OUT_TRANSM_DIRECT          25
586 #define RRES_OUT_TRANSM_INDIRECT        26
587 #define RRES_OUT_TRANSM_COLOR           27
588
589 /* note: types are needed to restore callbacks, don't change values */
590 #define CMP_NODE_VIEWER         201
591 #define CMP_NODE_RGB            202
592 #define CMP_NODE_VALUE          203
593 #define CMP_NODE_MIX_RGB        204
594 #define CMP_NODE_VALTORGB       205
595 #define CMP_NODE_RGBTOBW        206
596 #define CMP_NODE_NORMAL         207
597 #define CMP_NODE_CURVE_VEC      208
598 #define CMP_NODE_CURVE_RGB      209
599 #define CMP_NODE_ALPHAOVER      210
600 #define CMP_NODE_BLUR           211
601 #define CMP_NODE_FILTER         212
602 #define CMP_NODE_MAP_VALUE      213
603 #define CMP_NODE_TIME           214
604 #define CMP_NODE_VECBLUR        215
605 #define CMP_NODE_SEPRGBA        216
606 #define CMP_NODE_SEPHSVA        217
607 #define CMP_NODE_SETALPHA       218
608 #define CMP_NODE_HUE_SAT        219
609 #define CMP_NODE_IMAGE          220
610 #define CMP_NODE_R_LAYERS       221
611 #define CMP_NODE_COMPOSITE      222
612 #define CMP_NODE_OUTPUT_FILE    223
613 #define CMP_NODE_TEXTURE        224
614 #define CMP_NODE_TRANSLATE      225
615 #define CMP_NODE_ZCOMBINE       226
616 #define CMP_NODE_COMBRGBA       227
617 #define CMP_NODE_DILATEERODE    228
618 #define CMP_NODE_ROTATE         229
619 #define CMP_NODE_SCALE          230
620 #define CMP_NODE_SEPYCCA        231
621 #define CMP_NODE_COMBYCCA       232
622 #define CMP_NODE_SEPYUVA        233
623 #define CMP_NODE_COMBYUVA       234
624 #define CMP_NODE_DIFF_MATTE     235
625 #define CMP_NODE_COLOR_SPILL    236
626 #define CMP_NODE_CHROMA_MATTE   237
627 #define CMP_NODE_CHANNEL_MATTE  238
628 #define CMP_NODE_FLIP           239
629 #define CMP_NODE_SPLITVIEWER    240
630 #define CMP_NODE_INDEX_MASK     241
631 #define CMP_NODE_MAP_UV         242
632 #define CMP_NODE_ID_MASK        243
633 #define CMP_NODE_DEFOCUS        244
634 #define CMP_NODE_DISPLACE       245
635 #define CMP_NODE_COMBHSVA       246
636 #define CMP_NODE_MATH           247
637 #define CMP_NODE_LUMA_MATTE     248
638 #define CMP_NODE_BRIGHTCONTRAST 249
639 #define CMP_NODE_GAMMA          250
640 #define CMP_NODE_INVERT         251
641 #define CMP_NODE_NORMALIZE      252
642 #define CMP_NODE_CROP           253
643 #define CMP_NODE_DBLUR          254
644 #define CMP_NODE_BILATERALBLUR  255
645 #define CMP_NODE_PREMULKEY  256
646 #define CMP_NODE_DIST_MATTE     257
647 #define CMP_NODE_VIEW_LEVELS    258
648 #define CMP_NODE_COLOR_MATTE 259
649 #define CMP_NODE_COLORBALANCE 260
650 #define CMP_NODE_HUECORRECT 261
651 #define CMP_NODE_MOVIECLIP      262
652 #define CMP_NODE_STABILIZE2D    263
653 #define CMP_NODE_TRANSFORM      264
654 #define CMP_NODE_MOVIEDISTORTION        265
655 #define CMP_NODE_DOUBLEEDGEMASK    266
656 #define CMP_NODE_OUTPUT_MULTI_FILE__DEPRECATED  267     /* DEPRECATED multi file node has been merged into regular CMP_NODE_OUTPUT_FILE */
657 #define CMP_NODE_MASK           268
658
659 #define CMP_NODE_GLARE          301
660 #define CMP_NODE_TONEMAP        302
661 #define CMP_NODE_LENSDIST       303
662
663 #define CMP_NODE_COLORCORRECTION 312
664 #define CMP_NODE_MASK_BOX       313
665 #define CMP_NODE_MASK_ELLIPSE   314
666 #define CMP_NODE_BOKEHIMAGE     315
667 #define CMP_NODE_BOKEHBLUR      316
668 #define CMP_NODE_SWITCH         317
669
670 /* channel toggles */
671 #define CMP_CHAN_RGB            1
672 #define CMP_CHAN_A                      2
673 #define CMP_CHAN_R                      4
674 #define CMP_CHAN_G                      8
675 #define CMP_CHAN_B                      16
676
677 /* filter types */
678 #define CMP_FILT_SOFT           0
679 #define CMP_FILT_SHARP          1
680 #define CMP_FILT_LAPLACE        2
681 #define CMP_FILT_SOBEL          3
682 #define CMP_FILT_PREWITT        4
683 #define CMP_FILT_KIRSCH         5
684 #define CMP_FILT_SHADOW         6
685
686 /* scale node type, in custom1 */
687 #define CMP_SCALE_RELATIVE              0
688 #define CMP_SCALE_ABSOLUTE              1
689 #define CMP_SCALE_SCENEPERCENT  2
690 #define CMP_SCALE_RENDERPERCENT 3
691
692
693 /* API */
694 struct CompBuf;
695 struct bNodeTreeExec *ntreeCompositBeginExecTree(struct bNodeTree *ntree, int use_tree_data);
696 void ntreeCompositEndExecTree(struct bNodeTreeExec *exec, int use_tree_data);
697 void ntreeCompositExecTree(struct bNodeTree *ntree, struct RenderData *rd, int rendering, int do_previews);
698 void ntreeCompositTagRender(struct Scene *sce);
699 int ntreeCompositTagAnimated(struct bNodeTree *ntree);
700 void ntreeCompositTagGenerators(struct bNodeTree *ntree);
701 void ntreeCompositForceHidden(struct bNodeTree *ntree, struct Scene *scene);
702 void ntreeCompositClearTags(struct bNodeTree *ntree);
703
704 struct bNodeSocket *ntreeCompositOutputFileAddSocket(struct bNodeTree *ntree, struct bNode *node,
705                                                      const char *name, struct ImageFormatData *im_format);
706 int ntreeCompositOutputFileRemoveActiveSocket(struct bNodeTree *ntree, struct bNode *node);
707 void ntreeCompositOutputFileSetPath(struct bNode *node, struct bNodeSocket *sock, const char *name);
708 void ntreeCompositOutputFileSetLayer(struct bNode *node, struct bNodeSocket *sock, const char *name);
709 /* needed in do_versions */
710 void ntreeCompositOutputFileUniquePath(struct ListBase *list, struct bNodeSocket *sock, const char defname[], char delim);
711 void ntreeCompositOutputFileUniqueLayer(struct ListBase *list, struct bNodeSocket *sock, const char defname[], char delim);
712
713 /* ************** TEXTURE NODES *************** */
714
715 struct TexResult;
716
717 #define TEX_NODE_OUTPUT     401
718 #define TEX_NODE_CHECKER    402
719 #define TEX_NODE_TEXTURE    403
720 #define TEX_NODE_BRICKS     404
721 #define TEX_NODE_MATH       405
722 #define TEX_NODE_MIX_RGB    406
723 #define TEX_NODE_RGBTOBW    407
724 #define TEX_NODE_VALTORGB   408
725 #define TEX_NODE_IMAGE      409
726 #define TEX_NODE_CURVE_RGB  410
727 #define TEX_NODE_INVERT     411
728 #define TEX_NODE_HUE_SAT    412
729 #define TEX_NODE_CURVE_TIME 413
730 #define TEX_NODE_ROTATE     414
731 #define TEX_NODE_VIEWER     415
732 #define TEX_NODE_TRANSLATE  416
733 #define TEX_NODE_COORD      417
734 #define TEX_NODE_DISTANCE   418
735 #define TEX_NODE_COMPOSE    419
736 #define TEX_NODE_DECOMPOSE  420
737 #define TEX_NODE_VALTONOR   421
738 #define TEX_NODE_SCALE      422
739 #define TEX_NODE_AT         423
740
741 /* 501-599 reserved. Use like this: TEX_NODE_PROC + TEX_CLOUDS, etc */
742 #define TEX_NODE_PROC      500
743 #define TEX_NODE_PROC_MAX  600
744
745 /* API */
746 int  ntreeTexTagAnimated(struct bNodeTree *ntree);
747 void ntreeTexCheckCyclics(struct bNodeTree *ntree);
748
749 struct bNodeTreeExec *ntreeTexBeginExecTree(struct bNodeTree *ntree, int use_tree_data);
750 void ntreeTexEndExecTree(struct bNodeTreeExec *exec, int use_tree_data);
751 int ntreeTexExecTree(struct bNodeTree *ntree, struct TexResult *target, float *coord, float *dxt, float *dyt, int osatex, short thread, struct Tex *tex, short which_output, int cfra, int preview, struct ShadeInput *shi, struct MTex *mtex);
752
753
754 /*************************************************/
755
756 void init_nodesystem(void);
757 void free_nodesystem(void);
758
759 void clear_scene_in_nodes(struct Main *bmain, struct Scene *sce);
760
761 #endif