doxygen: prevent GPL license block from being parsed as doxygen comment.
[blender.git] / source / blender / nodes / intern / TEX_nodes / TEX_curves.c
1 /*
2  *
3  * ***** BEGIN GPL LICENSE BLOCK *****
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version. 
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software Foundation,
17  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18  *
19  * The Original Code is Copyright (C) 2005 Blender Foundation.
20  * All rights reserved.
21  *
22  * The Original Code is: all of this file.
23  *
24  * Contributor(s): Robin Allen
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 #include "../TEX_util.h"
30
31 /* **************** CURVE Time  ******************** */
32
33 /* custom1 = sfra, custom2 = efra */
34 static bNodeSocketType time_outputs[]= {
35         { SOCK_VALUE, 0, "Value",       1.0f, 0.0f, 1.0f, 1.0f, 0.0f, 1.0f },
36         { -1, 0, "" }
37 };
38
39 static void time_colorfn(float *out, TexParams *p, bNode *node, bNodeStack **UNUSED(in), short UNUSED(thread))
40 {
41         /* stack order output: fac */
42         float fac= 0.0f;
43         
44         if(node->custom1 < node->custom2)
45                 fac = (p->cfra - node->custom1)/(float)(node->custom2-node->custom1);
46         
47         fac = curvemapping_evaluateF(node->storage, 0, fac);
48         out[0] = CLAMPIS(fac, 0.0f, 1.0f);
49 }
50
51 static void time_exec(void *data, bNode *node, bNodeStack **in, bNodeStack **out)
52 {
53         tex_output(node, in, out[0], &time_colorfn, data);
54 }
55
56
57 static void time_init(bNode* node)
58 {
59    node->custom1= 1;
60    node->custom2= 250;
61    node->storage= curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
62 }
63
64 void register_node_type_tex_curve_time(ListBase *lb)
65 {
66         static bNodeType ntype;
67         
68         node_type_base(&ntype, TEX_NODE_CURVE_TIME, "Time", NODE_CLASS_INPUT, NODE_OPTIONS,
69                                    NULL, time_outputs);
70         node_type_size(&ntype, 140, 100, 320);
71         node_type_init(&ntype, time_init);
72         node_type_storage(&ntype, "CurveMapping", node_free_curves, node_copy_curves);
73         node_type_exec(&ntype, time_exec);
74         
75         nodeRegisterType(lb, &ntype);
76 }
77
78 /* **************** CURVE RGB  ******************** */
79 static bNodeSocketType rgb_inputs[]= {
80         {       SOCK_RGBA, 1, "Color",  0.0f, 0.0f, 0.0f, 1.0f, -1.0f, 1.0f},
81         {       -1, 0, ""       }
82 };
83
84 static bNodeSocketType rgb_outputs[]= {
85         {       SOCK_RGBA, 0, "Color",  0.0f, 0.0f, 1.0f, 1.0f, -1.0f, 1.0f},
86         {       -1, 0, ""       }
87 };
88
89 static void rgb_colorfn(float *out, TexParams *p, bNode *node, bNodeStack **in, short thread)
90 {
91         float cin[4];
92         tex_input_rgba(cin, in[0], p, thread);
93         
94         curvemapping_evaluateRGBF(node->storage, out, cin);
95         out[3] = cin[3];
96 }
97
98 static void rgb_exec(void *data, bNode *node, bNodeStack **in, bNodeStack **out)
99 {
100         tex_output(node, in, out[0], &rgb_colorfn, data);
101 }
102
103 static void rgb_init(bNode *node)
104 {
105         node->storage= curvemapping_add(4, 0.0f, 0.0f, 1.0f, 1.0f);
106 }
107
108 void register_node_type_tex_curve_rgb(ListBase *lb)
109 {
110         static bNodeType ntype;
111         
112         node_type_base(&ntype, TEX_NODE_CURVE_RGB, "RGB Curves", NODE_CLASS_OP_COLOR, NODE_OPTIONS,
113                                    rgb_inputs, rgb_outputs);
114         node_type_size(&ntype, 200, 140, 320);
115         node_type_init(&ntype, rgb_init);
116         node_type_storage(&ntype, "CurveMapping", node_free_curves, node_copy_curves);
117         node_type_exec(&ntype, rgb_exec);
118         
119         nodeRegisterType(lb, &ntype);
120 }
121