2008-07-23 07:56:08 +00:00
|
|
|
#include "BPy_Freestyle.h"
|
|
|
|
|
|
2008-07-24 08:29:48 +00:00
|
|
|
#include "BPy_BBox.h"
|
2008-07-23 07:56:08 +00:00
|
|
|
#include "BPy_BinaryPredicate0D.h"
|
|
|
|
|
#include "BPy_BinaryPredicate1D.h"
|
2009-07-26 11:19:37 +00:00
|
|
|
#include "BPy_ContextFunctions.h"
|
2010-07-28 00:43:45 +00:00
|
|
|
#include "BPy_Convert.h"
|
2008-08-01 02:25:21 +00:00
|
|
|
#include "BPy_FrsMaterial.h"
|
2008-08-01 02:15:25 +00:00
|
|
|
#include "BPy_FrsNoise.h"
|
2008-07-23 07:56:08 +00:00
|
|
|
#include "BPy_Id.h"
|
|
|
|
|
#include "BPy_IntegrationType.h"
|
|
|
|
|
#include "BPy_Interface0D.h"
|
|
|
|
|
#include "BPy_Interface1D.h"
|
2008-07-26 21:47:39 +00:00
|
|
|
#include "BPy_Iterator.h"
|
2008-07-23 07:56:08 +00:00
|
|
|
#include "BPy_MediumType.h"
|
|
|
|
|
#include "BPy_Nature.h"
|
2008-07-29 05:45:16 +00:00
|
|
|
#include "BPy_Operators.h"
|
2008-07-24 08:29:48 +00:00
|
|
|
#include "BPy_SShape.h"
|
2008-07-23 07:56:08 +00:00
|
|
|
#include "BPy_StrokeAttribute.h"
|
|
|
|
|
#include "BPy_StrokeShader.h"
|
|
|
|
|
#include "BPy_UnaryFunction0D.h"
|
|
|
|
|
#include "BPy_UnaryFunction1D.h"
|
|
|
|
|
#include "BPy_UnaryPredicate0D.h"
|
|
|
|
|
#include "BPy_UnaryPredicate1D.h"
|
2008-07-26 21:47:39 +00:00
|
|
|
#include "BPy_ViewMap.h"
|
2008-07-24 08:29:48 +00:00
|
|
|
#include "BPy_ViewShape.h"
|
|
|
|
|
|
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
|
|
|
|
2008-07-12 04:02:08 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
2010-04-17 23:47:47 +00:00
|
|
|
//------------------------ MODULE FUNCTIONS ----------------------------------
|
2008-07-12 04:02:08 +00:00
|
|
|
|
2010-04-17 23:47:47 +00:00
|
|
|
#include "FRS_freestyle.h"
|
|
|
|
|
#include "bpy_rna.h" /* pyrna_struct_CreatePyObject() */
|
|
|
|
|
|
|
|
|
|
static char Freestyle_getCurrentScene___doc__[] =
|
|
|
|
|
".. function:: getCurrentScene()\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" Returns the current scene.\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" :return: The current scene.\n"
|
|
|
|
|
" :rtype: :class:`bpy.types.Scene`\n";
|
|
|
|
|
|
|
|
|
|
static PyObject *Freestyle_getCurrentScene( PyObject *self )
|
|
|
|
|
{
|
|
|
|
|
if (!freestyle_scene) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "current scene not available");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
PointerRNA ptr_scene;
|
|
|
|
|
RNA_pointer_create(NULL, &RNA_Scene, freestyle_scene, &ptr_scene);
|
|
|
|
|
return pyrna_struct_CreatePyObject(&ptr_scene);
|
|
|
|
|
}
|
2009-09-27 00:32:20 +00:00
|
|
|
|
2010-07-28 00:43:45 +00:00
|
|
|
#include "DNA_material_types.h"
|
|
|
|
|
|
|
|
|
|
static int ramp_blend_type(const char *type)
|
|
|
|
|
{
|
|
|
|
|
if (!strcmp(type, "MIX")) return MA_RAMP_BLEND;
|
|
|
|
|
if (!strcmp(type, "ADD")) return MA_RAMP_ADD;
|
|
|
|
|
if (!strcmp(type, "MULTIPLY")) return MA_RAMP_MULT;
|
|
|
|
|
if (!strcmp(type, "SUBTRACT")) return MA_RAMP_SUB;
|
|
|
|
|
if (!strcmp(type, "SCREEN")) return MA_RAMP_SCREEN;
|
|
|
|
|
if (!strcmp(type, "DIVIDE")) return MA_RAMP_DIV;
|
|
|
|
|
if (!strcmp(type, "DIFFERENCE")) return MA_RAMP_DIFF;
|
|
|
|
|
if (!strcmp(type, "DARKEN")) return MA_RAMP_DARK;
|
|
|
|
|
if (!strcmp(type, "LIGHTEN")) return MA_RAMP_LIGHT;
|
|
|
|
|
if (!strcmp(type, "OVERLAY")) return MA_RAMP_OVERLAY;
|
|
|
|
|
if (!strcmp(type, "DODGE")) return MA_RAMP_DODGE;
|
|
|
|
|
if (!strcmp(type, "BURN")) return MA_RAMP_BURN;
|
|
|
|
|
if (!strcmp(type, "HUE")) return MA_RAMP_HUE;
|
|
|
|
|
if (!strcmp(type, "SATURATION")) return MA_RAMP_SAT;
|
|
|
|
|
if (!strcmp(type, "VALUE")) return MA_RAMP_VAL;
|
|
|
|
|
if (!strcmp(type, "COLOR")) return MA_RAMP_COLOR;
|
|
|
|
|
if (!strcmp(type, "SOFT LIGHT")) return MA_RAMP_SOFT;
|
|
|
|
|
if (!strcmp(type, "LINEAR LIGHT")) return MA_RAMP_LINEAR;
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#include "BKE_material.h" /* ramp_blend() */
|
|
|
|
|
|
|
|
|
|
static char Freestyle_blendRamp___doc__[] =
|
|
|
|
|
".. function:: blendRamp(type, color1, fac, color2)\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" Blend two colors according to a ramp blend type.\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" :arg type: Ramp blend type.\n"
|
|
|
|
|
" :type type: int\n"
|
|
|
|
|
" :arg color1: 1st color.\n"
|
|
|
|
|
" :type color1: :class:`mathutils.Vector`, list or tuple of 3 real numbers\n"
|
|
|
|
|
" :arg fac: Blend factor.\n"
|
|
|
|
|
" :type fac: float\n"
|
|
|
|
|
" :arg color2: 1st color.\n"
|
|
|
|
|
" :type color2: :class:`mathutils.Vector`, list or tuple of 3 real numbers\n"
|
|
|
|
|
" :return: Blended color in RGB format.\n"
|
|
|
|
|
" :rtype: :class:`mathutils.Vector`\n";
|
|
|
|
|
|
|
|
|
|
static PyObject *Freestyle_blendRamp( PyObject *self, PyObject *args )
|
|
|
|
|
{
|
|
|
|
|
PyObject *obj1, *obj2;
|
|
|
|
|
char *s;
|
|
|
|
|
int type;
|
|
|
|
|
Vec3f *v1 = NULL, *v2 = NULL;
|
|
|
|
|
float a[3], fac, b[3];
|
|
|
|
|
|
|
|
|
|
if (!PyArg_ParseTuple(args, "sOfO", &s, &obj1, &fac, &obj2))
|
|
|
|
|
return NULL;
|
|
|
|
|
type = ramp_blend_type(s);
|
|
|
|
|
if (type < 0) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "argument 1 is an unknown ramp blend type");
|
|
|
|
|
goto error;
|
|
|
|
|
}
|
|
|
|
|
v1 = Vec3f_ptr_from_PyObject(obj1);
|
|
|
|
|
if (!v1) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "argument 2 must be a 3D vector (either a tuple/list of 3 elements or Vector)");
|
|
|
|
|
goto error;
|
|
|
|
|
}
|
|
|
|
|
v2 = Vec3f_ptr_from_PyObject(obj2);
|
|
|
|
|
if (!v2) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "argument 4 must be a 3D vector (either a tuple/list of 3 elements or Vector)");
|
|
|
|
|
goto error;
|
|
|
|
|
}
|
|
|
|
|
a[0] = v1->x(); b[0] = v2->x();
|
|
|
|
|
a[1] = v1->y(); b[1] = v2->y();
|
|
|
|
|
a[2] = v1->z(); b[2] = v2->z();
|
|
|
|
|
ramp_blend(type, &a[0], &a[1], &a[2], fac, b);
|
|
|
|
|
delete v1;
|
|
|
|
|
delete v2;
|
|
|
|
|
return newVectorObject( a, 3, Py_NEW, NULL);
|
|
|
|
|
|
|
|
|
|
error:
|
|
|
|
|
if (v1) delete v1;
|
|
|
|
|
if (v2) delete v2;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-26 23:50:32 +00:00
|
|
|
#include "BKE_texture.h" /* do_colorband() */
|
|
|
|
|
|
|
|
|
|
static char Freestyle_evaluateColorRamp___doc__[] =
|
|
|
|
|
".. function:: evaluateColorRamp(ramp, in)\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" Evaluate a color ramp at a point in the interval 0 to 1.\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" :arg ramp: Color ramp object.\n"
|
|
|
|
|
" :type ramp: :class:`bpy.types.ColorRamp`\n"
|
|
|
|
|
" :arg in: Value in the interval 0 to 1.\n"
|
|
|
|
|
" :type in: float\n"
|
|
|
|
|
" :return: color in RGBA format.\n"
|
2010-07-28 00:43:45 +00:00
|
|
|
" :rtype: :class:`mathutils.Vector`\n";
|
2010-07-26 23:50:32 +00:00
|
|
|
|
|
|
|
|
static PyObject *Freestyle_evaluateColorRamp( PyObject *self, PyObject *args )
|
|
|
|
|
{
|
|
|
|
|
BPy_StructRNA *py_srna;
|
|
|
|
|
ColorBand *coba;
|
|
|
|
|
float in, out[4];
|
|
|
|
|
|
|
|
|
|
if(!( PyArg_ParseTuple(args, "O!f", &pyrna_struct_Type, &py_srna, &in) ))
|
|
|
|
|
return NULL;
|
|
|
|
|
if(!RNA_struct_is_a(py_srna->ptr.type, &RNA_ColorRamp)) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "1st argument is not a ColorRamp object");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
coba = (ColorBand *)py_srna->ptr.data;
|
|
|
|
|
if (!do_colorband(coba, in, out)) {
|
|
|
|
|
PyErr_SetString(PyExc_ValueError, "failed to evaluate the color ramp");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
2010-07-28 00:43:45 +00:00
|
|
|
return newVectorObject( out, 4, Py_NEW, NULL);
|
2010-07-26 23:50:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#include "BKE_colortools.h" /* curvemapping_evaluateF() */
|
|
|
|
|
|
|
|
|
|
static char Freestyle_evaluateCurveMappingF___doc__[] =
|
|
|
|
|
".. function:: evaluateCurveMappingF(cumap, cur, value)\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" Evaluate a curve mapping at a point in the interval 0 to 1.\n"
|
|
|
|
|
"\n"
|
|
|
|
|
" :arg cumap: Curve mapping object.\n"
|
|
|
|
|
" :type cumap: :class:`bpy.types.CurveMapping`\n"
|
|
|
|
|
" :arg cur: Index of the curve to be used (0 <= cur <= 3).\n"
|
|
|
|
|
" :type cur: int\n"
|
|
|
|
|
" :arg value: Input value in the interval 0 to 1.\n"
|
|
|
|
|
" :type value: float\n"
|
|
|
|
|
" :return: Mapped output value.\n"
|
|
|
|
|
" :rtype: float\n";
|
|
|
|
|
|
|
|
|
|
static PyObject *Freestyle_evaluateCurveMappingF( PyObject *self, PyObject *args )
|
|
|
|
|
{
|
|
|
|
|
BPy_StructRNA *py_srna;
|
|
|
|
|
CurveMapping *cumap;
|
|
|
|
|
int cur;
|
|
|
|
|
float value;
|
|
|
|
|
|
|
|
|
|
if(!( PyArg_ParseTuple(args, "O!if", &pyrna_struct_Type, &py_srna, &cur, &value) ))
|
|
|
|
|
return NULL;
|
|
|
|
|
if(!RNA_struct_is_a(py_srna->ptr.type, &RNA_CurveMapping)) {
|
|
|
|
|
PyErr_SetString(PyExc_TypeError, "1st argument is not a CurveMapping object");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
if (cur < 0 || cur > 3) {
|
|
|
|
|
PyErr_SetString(PyExc_ValueError, "2nd argument is out of range");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
cumap = (CurveMapping *)py_srna->ptr.data;
|
|
|
|
|
return PyFloat_FromDouble(curvemapping_evaluateF(cumap, cur, value));
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-17 23:47:47 +00:00
|
|
|
/*-----------------------Freestyle module docstring----------------------------*/
|
2009-09-27 00:32:20 +00:00
|
|
|
|
|
|
|
|
static char module_docstring[] = "The Blender Freestyle module\n\n";
|
|
|
|
|
|
|
|
|
|
/*-----------------------Freestyle module method def---------------------------*/
|
|
|
|
|
|
|
|
|
|
static PyMethodDef module_functions[] = {
|
2010-04-17 23:47:47 +00:00
|
|
|
{"getCurrentScene", ( PyCFunction ) Freestyle_getCurrentScene, METH_NOARGS, Freestyle_getCurrentScene___doc__},
|
2010-07-28 00:43:45 +00:00
|
|
|
{"blendRamp", ( PyCFunction ) Freestyle_blendRamp, METH_VARARGS, Freestyle_blendRamp___doc__},
|
2010-07-26 23:50:32 +00:00
|
|
|
{"evaluateColorRamp", ( PyCFunction ) Freestyle_evaluateColorRamp, METH_VARARGS, Freestyle_evaluateColorRamp___doc__},
|
|
|
|
|
{"evaluateCurveMappingF", ( PyCFunction ) Freestyle_evaluateCurveMappingF, METH_VARARGS, Freestyle_evaluateCurveMappingF___doc__},
|
2008-07-12 04:02:08 +00:00
|
|
|
{NULL, NULL, 0, NULL}
|
|
|
|
|
};
|
|
|
|
|
|
2009-09-27 00:32:20 +00:00
|
|
|
/*-----------------------Freestyle module definition---------------------------*/
|
2008-07-12 04:02:08 +00:00
|
|
|
|
2009-09-27 00:32:20 +00:00
|
|
|
static PyModuleDef module_definition = {
|
|
|
|
|
PyModuleDef_HEAD_INIT,
|
|
|
|
|
"Freestyle",
|
|
|
|
|
module_docstring,
|
|
|
|
|
-1,
|
|
|
|
|
module_functions
|
2008-07-12 04:02:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//-------------------MODULE INITIALIZATION--------------------------------
|
|
|
|
|
PyObject *Freestyle_Init( void )
|
|
|
|
|
{
|
2008-07-15 01:07:19 +00:00
|
|
|
PyObject *module;
|
2008-07-12 04:02:08 +00:00
|
|
|
|
2008-07-15 01:07:19 +00:00
|
|
|
// initialize modules
|
2009-09-27 00:32:20 +00:00
|
|
|
module = PyModule_Create(&module_definition);
|
|
|
|
|
if (!module)
|
|
|
|
|
return NULL;
|
|
|
|
|
PyDict_SetItemString(PySys_GetObject("modules"), module_definition.m_name, module);
|
2008-07-23 07:56:08 +00:00
|
|
|
|
2008-07-15 01:07:19 +00:00
|
|
|
// attach its classes (adding the object types to the module)
|
2008-07-23 07:56:08 +00:00
|
|
|
|
|
|
|
|
// those classes have to be initialized before the others
|
|
|
|
|
MediumType_Init( module );
|
|
|
|
|
Nature_Init( module );
|
|
|
|
|
|
2008-07-24 08:29:48 +00:00
|
|
|
BBox_Init( module );
|
2008-07-15 01:07:19 +00:00
|
|
|
BinaryPredicate0D_Init( module );
|
|
|
|
|
BinaryPredicate1D_Init( module );
|
2009-07-26 11:19:37 +00:00
|
|
|
ContextFunctions_Init( module );
|
2008-08-01 02:25:21 +00:00
|
|
|
FrsMaterial_Init( module );
|
2008-08-01 02:15:25 +00:00
|
|
|
FrsNoise_Init( module );
|
2008-07-15 01:07:19 +00:00
|
|
|
Id_Init( module );
|
2008-07-18 20:31:40 +00:00
|
|
|
IntegrationType_Init( module );
|
2008-07-15 01:07:19 +00:00
|
|
|
Interface0D_Init( module );
|
|
|
|
|
Interface1D_Init( module );
|
2008-07-23 10:19:08 +00:00
|
|
|
Iterator_Init( module );
|
2008-07-29 05:45:16 +00:00
|
|
|
Operators_Init( module );
|
2008-07-24 08:29:48 +00:00
|
|
|
SShape_Init( module );
|
2008-07-21 21:24:37 +00:00
|
|
|
StrokeAttribute_Init( module );
|
2008-07-23 05:54:34 +00:00
|
|
|
StrokeShader_Init( module );
|
2008-07-18 04:59:07 +00:00
|
|
|
UnaryFunction0D_Init( module );
|
|
|
|
|
UnaryFunction1D_Init( module );
|
|
|
|
|
UnaryPredicate0D_Init( module );
|
|
|
|
|
UnaryPredicate1D_Init( module );
|
2008-07-26 21:47:39 +00:00
|
|
|
ViewMap_Init( module );
|
2008-07-24 08:29:48 +00:00
|
|
|
ViewShape_Init( module );
|
2008-07-26 21:47:39 +00:00
|
|
|
|
2008-07-15 01:07:19 +00:00
|
|
|
return module;
|
2008-07-12 04:02:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
2009-10-15 19:38:45 +00:00
|
|
|
#endif
|