Blender V2.61 - r43446

node_texture_image.c

Go to the documentation of this file.
00001 /*
00002  * ***** BEGIN GPL LICENSE BLOCK *****
00003  *
00004  * This program is free software; you can redistribute it and/or
00005  * modify it under the terms of the GNU General Public License
00006  * as published by the Free Software Foundation; either version 2
00007  * of the License, or (at your option) any later version. 
00008  *
00009  * This program is distributed in the hope that it will be useful,
00010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012  * GNU General Public License for more details.
00013  *
00014  * You should have received a copy of the GNU General Public License
00015  * along with this program; if not, write to the Free Software Foundation,
00016  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
00017  *
00018  * The Original Code is Copyright (C) 2006 Blender Foundation.
00019  * All rights reserved.
00020  *
00021  * The Original Code is: all of this file.
00022  *
00023  * Contributor(s): Robin Allen
00024  *
00025  * ***** END GPL LICENSE BLOCK *****
00026  */
00027 
00033 #include "node_texture_util.h"
00034 #include "NOD_texture.h"
00035 
00036 static bNodeSocketTemplate outputs[]= {
00037     { SOCK_RGBA, 0, "Image"},
00038     { -1, 0, "" }
00039 };
00040 
00041 static void colorfn(float *out, TexParams *p, bNode *node, bNodeStack **UNUSED(in), short UNUSED(thread))
00042 {
00043     float x = p->co[0];
00044     float y = p->co[1];
00045     Image *ima= (Image *)node->id;
00046     ImageUser *iuser= (ImageUser *)node->storage;
00047     
00048     if( ima ) {
00049         ImBuf *ibuf = BKE_image_get_ibuf(ima, iuser);
00050         if( ibuf ) {
00051             float xsize, ysize;
00052             float xoff, yoff;
00053             int px, py;
00054             
00055             float *result;
00056 
00057             xsize = ibuf->x / 2;
00058             ysize = ibuf->y / 2;
00059             xoff = yoff = -1;
00060                     
00061             px = (int)( (x-xoff) * xsize );
00062             py = (int)( (y-yoff) * ysize );
00063         
00064             if( (!xsize) || (!ysize) ) return;
00065             
00066             if( !ibuf->rect_float ) {
00067                 BLI_lock_thread(LOCK_IMAGE);
00068                 if( !ibuf->rect_float )
00069                     IMB_float_from_rect(ibuf);
00070                 BLI_unlock_thread(LOCK_IMAGE);
00071             }
00072             
00073             while( px < 0 ) px += ibuf->x;
00074             while( py < 0 ) py += ibuf->y;
00075             while( px >= ibuf->x ) px -= ibuf->x;
00076             while( py >= ibuf->y ) py -= ibuf->y;
00077             
00078             result = ibuf->rect_float + py*ibuf->x*4 + px*4;
00079             copy_v4_v4( out, result );
00080         }
00081     }
00082 }
00083 
00084 static void exec(void *data, bNode *node, bNodeStack **in, bNodeStack **out)
00085 {
00086     tex_output(node, in, out[0], &colorfn, data);
00087 }
00088 
00089 static void init(bNodeTree *UNUSED(ntree), bNode* node, bNodeTemplate *UNUSED(ntemp))
00090 {
00091     ImageUser *iuser= MEM_callocN(sizeof(ImageUser), "node image user");
00092     node->storage= iuser;
00093     iuser->sfra= 1;
00094     iuser->fie_ima= 2;
00095     iuser->ok= 1;
00096 }
00097 
00098 void register_node_type_tex_image(bNodeTreeType *ttype)
00099 {
00100     static bNodeType ntype;
00101     
00102     node_type_base(ttype, &ntype, TEX_NODE_IMAGE, "Image", NODE_CLASS_INPUT, NODE_PREVIEW|NODE_OPTIONS);
00103     node_type_socket_templates(&ntype, NULL, outputs);
00104     node_type_size(&ntype, 120, 80, 300);
00105     node_type_init(&ntype, init);
00106     node_type_storage(&ntype, "ImageUser", node_free_standard_storage, node_copy_standard_storage);
00107     node_type_exec(&ntype, exec);
00108     
00109     nodeRegisterType(ttype, &ntype);
00110 }