Omission of a texture node to specify coordinates was regarded as a bug by some users...
authorRobin Allen <roblovski@gmail.com>
Sat, 13 Jun 2009 14:22:40 +0000 (14:22 +0000)
committerRobin Allen <roblovski@gmail.com>
Sat, 13 Jun 2009 14:22:40 +0000 (14:22 +0000)
source/blender/blenkernel/BKE_node.h
source/blender/blenkernel/intern/node.c
source/blender/nodes/TEX_node.h
source/blender/nodes/intern/TEX_nodes/TEX_at.c [new file with mode: 0644]

index 184b28b2cd231bbb99eb63a15ab939db6231f696..66e8492b35786b63adbf6af8e04f0841bcffcfcc 100644 (file)
@@ -407,8 +407,9 @@ struct TexResult;
 #define TEX_NODE_DECOMPOSE  420
 #define TEX_NODE_VALTONOR   421
 #define TEX_NODE_SCALE      422
+#define TEX_NODE_AT         423
 
-/* 201-299 reserved. Use like this: TEX_NODE_PROC + TEX_CLOUDS, etc */
+/* 501-599 reserved. Use like this: TEX_NODE_PROC + TEX_CLOUDS, etc */
 #define TEX_NODE_PROC      500
 #define TEX_NODE_PROC_MAX  600
 
index 413c2fc20f591417dbcc301e69e72733aba1f0a4..62064799acaef56d43f868195f21610a02516763 100644 (file)
@@ -2921,6 +2921,7 @@ static void registerTextureNodes(ListBase *ntypelist)
        nodeRegisterType(ntypelist, &tex_node_rotate);
        nodeRegisterType(ntypelist, &tex_node_translate);
        nodeRegisterType(ntypelist, &tex_node_scale);
+       nodeRegisterType(ntypelist, &tex_node_at);
        
        nodeRegisterType(ntypelist, &tex_node_proc_voronoi);
        nodeRegisterType(ntypelist, &tex_node_proc_blend);
index d298f062143d7c639ebc503cc4b44b8e744f4e0c..f58d0312961d475f195b0267a0acb77c1eb47941 100644 (file)
@@ -59,6 +59,7 @@ extern bNodeType tex_node_distance;
 extern bNodeType tex_node_rotate;
 extern bNodeType tex_node_translate;
 extern bNodeType tex_node_scale;
+extern bNodeType tex_node_at;
 
 extern bNodeType tex_node_compose;
 extern bNodeType tex_node_decompose;
diff --git a/source/blender/nodes/intern/TEX_nodes/TEX_at.c b/source/blender/nodes/intern/TEX_nodes/TEX_at.c
new file mode 100644 (file)
index 0000000..80f232c
--- /dev/null
@@ -0,0 +1,70 @@
+/**
+ *
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version. 
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+ *
+ * The Original Code is Copyright (C) 2005 Blender Foundation.
+ * All rights reserved.
+ *
+ * The Original Code is: all of this file.
+ *
+ * Contributor(s): R Allen
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include "../TEX_util.h"                                                   
+
+static bNodeSocketType inputs[]= {
+       { SOCK_RGBA,   1, "Texture",     0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 1.0f },
+       { SOCK_VECTOR, 1, "Coordinates", 0.0f, 0.0f, 0.0f, 0.0f, -1.0f, 1.0f },
+       { -1, 0, "" }
+};
+static bNodeSocketType outputs[]= {
+       { SOCK_RGBA,   0, "Texture",     0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 1.0f },
+       { -1, 0, "" }
+};
+
+static void colorfn(float *out, float *coord, bNode *node, bNodeStack **in, short thread)
+{
+       float new_coord[3];
+       
+       tex_input_vec(new_coord, in[1], coord, thread);
+       tex_input_rgba(out, in[0], new_coord, thread);
+}
+
+static void exec(void *data, bNode *node, bNodeStack **in, bNodeStack **out)
+{
+       tex_output(node, in, out[0], &colorfn);
+}
+
+bNodeType tex_node_at = {
+       /* *next,*prev     */  NULL, NULL,
+       /* type code       */  TEX_NODE_AT,
+       /* name            */  "At",
+       /* width+range     */  100, 60, 150,
+       /* class+opts      */  NODE_CLASS_DISTORT, 0,
+       /* input sock      */  inputs,
+       /* output sock     */  outputs,
+       /* storage         */  "", 
+       /* execfunc        */  exec,
+       /* butfunc         */  NULL,
+       /* initfunc        */  NULL,
+       /* freestoragefunc */  NULL,
+       /* copystoragefunc */  NULL,
+       /* id              */  NULL   
+       
+};