139 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * ***** 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | 
						|
 *
 | 
						|
 * Contributor(s): Lukas Toenne
 | 
						|
 *
 | 
						|
 * ***** END GPL LICENSE BLOCK *****
 | 
						|
 */
 | 
						|
 | 
						|
/** \file blender/python/mathutils/mathutils_interpolate.c
 | 
						|
 *  \ingroup pymathutils
 | 
						|
 */
 | 
						|
 | 
						|
 | 
						|
#include <Python.h>
 | 
						|
 | 
						|
#include "mathutils.h"
 | 
						|
#include "mathutils_interpolate.h"
 | 
						|
 | 
						|
#include "BLI_math.h"
 | 
						|
#include "BLI_utildefines.h"
 | 
						|
 | 
						|
#ifndef MATH_STANDALONE /* define when building outside blender */
 | 
						|
#  include "MEM_guardedalloc.h"
 | 
						|
#endif
 | 
						|
 | 
						|
/*-------------------------DOC STRINGS ---------------------------*/
 | 
						|
PyDoc_STRVAR(M_Interpolate_doc,
 | 
						|
"The Blender interpolate module"
 | 
						|
);
 | 
						|
 | 
						|
/* ---------------------------------WEIGHT CALCULATION ----------------------- */
 | 
						|
 | 
						|
#ifndef MATH_STANDALONE
 | 
						|
 | 
						|
PyDoc_STRVAR(M_Interpolate_poly_3d_calc_doc,
 | 
						|
".. function:: poly_3d_calc(veclist, pt)\n"
 | 
						|
"\n"
 | 
						|
"   Calculate barycentric weights for a point on a polygon.\n"
 | 
						|
"\n"
 | 
						|
"   :arg veclist: list of vectors\n"
 | 
						|
"   :arg pt: point"
 | 
						|
"   :rtype: list of per-vector weights\n"
 | 
						|
);
 | 
						|
static PyObject *M_Interpolate_poly_3d_calc(PyObject *UNUSED(self), PyObject *args)
 | 
						|
{
 | 
						|
	float fp[3];
 | 
						|
	float (*vecs)[3];
 | 
						|
	Py_ssize_t len;
 | 
						|
	
 | 
						|
	PyObject *point, *veclist, *ret;
 | 
						|
	int i;
 | 
						|
	
 | 
						|
	if (!PyArg_ParseTuple(
 | 
						|
	        args, "OO!:poly_3d_calc",
 | 
						|
	        &veclist,
 | 
						|
	        &vector_Type, &point))
 | 
						|
	{
 | 
						|
		return NULL;
 | 
						|
	}
 | 
						|
	
 | 
						|
	if (BaseMath_ReadCallback((VectorObject *)point) == -1)
 | 
						|
		return NULL;
 | 
						|
	
 | 
						|
	fp[0] = ((VectorObject *)point)->vec[0];
 | 
						|
	fp[1] = ((VectorObject *)point)->vec[1];
 | 
						|
	if (((VectorObject *)point)->size > 2)
 | 
						|
		fp[2] = ((VectorObject *)point)->vec[2];
 | 
						|
	else
 | 
						|
		fp[2] = 0.0f;  /* if its a 2d vector then set the z to be zero */
 | 
						|
	
 | 
						|
	len = mathutils_array_parse_alloc_v(((float **)&vecs), 3, veclist, __func__);
 | 
						|
	if (len == -1) {
 | 
						|
		return NULL;
 | 
						|
	}
 | 
						|
	
 | 
						|
	if (len) {
 | 
						|
		float *weights = MEM_mallocN(sizeof(float) * len, __func__);
 | 
						|
		
 | 
						|
		interp_weights_poly_v3(weights, vecs, len, fp);
 | 
						|
		
 | 
						|
		ret = PyList_New(len);
 | 
						|
		for (i = 0; i < len; i++) {
 | 
						|
			PyList_SET_ITEM(ret, i, PyFloat_FromDouble(weights[i]));
 | 
						|
		}
 | 
						|
 | 
						|
		MEM_freeN(weights);
 | 
						|
 | 
						|
		PyMem_Free(vecs);
 | 
						|
	}
 | 
						|
	else {
 | 
						|
		ret = PyList_New(0);
 | 
						|
	}
 | 
						|
 | 
						|
	return ret;
 | 
						|
}
 | 
						|
 | 
						|
#endif /* MATH_STANDALONE */
 | 
						|
 | 
						|
 | 
						|
static PyMethodDef M_Interpolate_methods[] = {
 | 
						|
#ifndef MATH_STANDALONE
 | 
						|
	{"poly_3d_calc", (PyCFunction) M_Interpolate_poly_3d_calc, METH_VARARGS, M_Interpolate_poly_3d_calc_doc},
 | 
						|
#endif
 | 
						|
	{NULL, NULL, 0, NULL}
 | 
						|
};
 | 
						|
 | 
						|
static struct PyModuleDef M_Interpolate_module_def = {
 | 
						|
	PyModuleDef_HEAD_INIT,
 | 
						|
	"mathutils.interpolate",  /* m_name */
 | 
						|
	M_Interpolate_doc,  /* m_doc */
 | 
						|
	0,  /* m_size */
 | 
						|
	M_Interpolate_methods,  /* m_methods */
 | 
						|
	NULL,  /* m_reload */
 | 
						|
	NULL,  /* m_traverse */
 | 
						|
	NULL,  /* m_clear */
 | 
						|
	NULL,  /* m_free */
 | 
						|
};
 | 
						|
 | 
						|
/*----------------------------MODULE INIT-------------------------*/
 | 
						|
PyMODINIT_FUNC PyInit_mathutils_interpolate(void)
 | 
						|
{
 | 
						|
	PyObject *submodule = PyModule_Create(&M_Interpolate_module_def);
 | 
						|
	return submodule;
 | 
						|
}
 |