[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [20174] trunk/blender/source/blender/ python/api2_2x: [#18728] Particle (newtonian) physics API for Python
Campbell Barton
ideasman42 at gmail.com
Tue May 12 23:13:29 CEST 2009
Revision: 20174
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=20174
Author: campbellbarton
Date: 2009-05-12 23:13:29 +0200 (Tue, 12 May 2009)
Log Message:
-----------
[#18728] Particle (newtonian) physics API for Python
patch from Alberto Santos (dnakhain)
Modified Paths:
--------------
trunk/blender/source/blender/python/api2_2x/Particle.c
trunk/blender/source/blender/python/api2_2x/doc/Particle.py
Modified: trunk/blender/source/blender/python/api2_2x/Particle.c
===================================================================
--- trunk/blender/source/blender/python/api2_2x/Particle.c 2009-05-12 19:48:18 UTC (rev 20173)
+++ trunk/blender/source/blender/python/api2_2x/Particle.c 2009-05-12 21:13:29 UTC (rev 20174)
@@ -133,6 +133,50 @@
static PyObject *Part_getRenderStep( BPy_PartSys * self );
static PyObject *Part_getDupOb( BPy_PartSys * self );
static PyObject *Part_getDrawAs( BPy_PartSys * self );
+static int Part_setPhysType( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getPhysType( BPy_PartSys * self );
+static int Part_setIntegrator( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIntegrator( BPy_PartSys * self );
+static int Part_setIniVelObject( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelObject( BPy_PartSys * self );
+static int Part_setIniVelNormal( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelNormal( BPy_PartSys * self );
+static int Part_setIniVelRandom( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelRandom( BPy_PartSys * self );
+static int Part_setIniVelTan( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelTan( BPy_PartSys * self );
+static int Part_setIniVelRot( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelRot( BPy_PartSys * self );
+static int Part_setIniVelPart( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelPart( BPy_PartSys * self );
+static int Part_setIniVelReact( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getIniVelReact( BPy_PartSys * self );
+static int Part_setRotDynamic( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotDynamic( BPy_PartSys * self );
+static int Part_setRotation( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotation( BPy_PartSys * self );
+static int Part_setRotRandom( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotRandom( BPy_PartSys * self );
+static int Part_setRotPhase( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotPhase( BPy_PartSys * self );
+static int Part_setRotPhaseR( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotPhaseR( BPy_PartSys * self );
+static int Part_setRotAngularV( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotAngularV( BPy_PartSys * self );
+static int Part_setRotAngularVAm( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getRotAngularVAm( BPy_PartSys * self );
+static int Part_setGlobAccX( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobAccX( BPy_PartSys * self );
+static int Part_setGlobAccY( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobAccY( BPy_PartSys * self );
+static int Part_setGlobAccZ( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobAccZ( BPy_PartSys * self );
+static int Part_setGlobDrag( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobDrag( BPy_PartSys * self );
+static int Part_setGlobBrown( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobBrown( BPy_PartSys * self );
+static int Part_setGlobDamp( BPy_PartSys * self, PyObject * args );
+static PyObject *Part_getGlobDamp( BPy_PartSys * self );
static PyObject *Part_GetAge( BPy_PartSys * self, PyObject * args );
static int Part_setChildAmount( BPy_PartSys * self, PyObject * args );
static PyObject *Part_getChildAmount( BPy_PartSys * self );
@@ -366,6 +410,95 @@
(getter)Part_getDrawAs, NULL,
"Get draw type Particle.DRAWAS([ 'NONE' | 'OBJECT' | 'POINT' | ... ] )",
NULL},
+/* Newtonian Physics */
+ {"physics",
+ (getter)Part_getPhysType, (setter)Part_setPhysType,
+ "Select particle physics type Particle.PHYSICS([ 'BOIDS' | 'KEYED' | 'NEWTONIAN' | 'NONE' ])",
+ NULL},
+ {"integration",
+ (getter)Part_getIntegrator, (setter)Part_setIntegrator,
+ "Select physics integrator type Particle.INTEGRATOR([ 'RK4' | 'MIDPOINT' | 'EULER' ])",
+ NULL},
+ {"inVelObj",
+ (getter)Part_getIniVelObject, (setter)Part_setIniVelObject,
+ "Let the object give the particle a starting speed",
+ NULL},
+ {"inVelNor",
+ (getter)Part_getIniVelNormal, (setter)Part_setIniVelNormal,
+ "Let the surface normal give the particle a starting speed",
+ NULL},
+ {"inVelRan",
+ (getter)Part_getIniVelRandom, (setter)Part_setIniVelRandom,
+ "Give the starting speed a random variation",
+ NULL},
+ {"inVelTan",
+ (getter)Part_getIniVelTan, (setter)Part_setIniVelTan,
+ "Let the surface tangent give the particle a starting speed",
+ NULL},
+ {"inVelRot",
+ (getter)Part_getIniVelRot, (setter)Part_setIniVelRot,
+ "Rotate the surface tangent",
+ NULL},
+ {"inVelPart",
+ (getter)Part_getIniVelPart, (setter)Part_setIniVelPart,
+ "Let the target particle give the particle a starting speed",
+ NULL},
+ {"inVelReact",
+ (getter)Part_getIniVelReact, (setter)Part_setIniVelReact,
+ "Let the vector away from the target particles location give the particle a starting speed",
+ NULL},
+ {"rotation",
+ (getter)Part_getRotation, (setter)Part_setRotation,
+ "Particles initial rotation Particle.ROTATION([ 'OBZ' | 'OBY' | 'OBX' | 'GLZ' | 'GLY' | 'GLX' | 'VEL' | 'NOR' | 'NONE' ])",
+ NULL},
+ {"rotDyn",
+ (getter)Part_getRotDynamic, (setter)Part_setRotDynamic,
+ "Sets rotation to dynamic/constant",
+ NULL},
+ {"rotRand",
+ (getter)Part_getRotRandom, (setter)Part_setRotRandom,
+ "Randomize rotation",
+ NULL},
+ {"rotPhase",
+ (getter)Part_getRotPhase, (setter)Part_setRotPhase,
+ "Initial rotation phase",
+ NULL},
+ {"rotPhaseR",
+ (getter)Part_getRotPhaseR, (setter)Part_setRotPhaseR,
+ "Randomize rotation phase",
+ NULL},
+ {"rotAnV",
+ (getter)Part_getRotAngularV, (setter)Part_setRotAngularV,
+ "Select particle angular velocity mode Particle.ANGULARV([ 'RANDOM' | 'SPIN' | 'NONE' ])",
+ NULL},
+ {"rotAnVAm",
+ (getter)Part_getRotAngularVAm, (setter)Part_setRotAngularVAm,
+ "Angular velocity amount",
+ NULL},
+ {"glAccX",
+ (getter)Part_getGlobAccX, (setter)Part_setGlobAccX,
+ "Specify a constant acceleration along the X-axis",
+ NULL},
+ {"glAccY",
+ (getter)Part_getGlobAccY, (setter)Part_setGlobAccY,
+ "Specify a constant acceleration along the Y-axis",
+ NULL},
+ {"glAccZ",
+ (getter)Part_getGlobAccZ, (setter)Part_setGlobAccZ,
+ "Specify a constant acceleration along the Z-axis",
+ NULL},
+ {"glDrag",
+ (getter)Part_getGlobDrag, (setter)Part_setGlobDrag,
+ "Specify the amount of air-drag",
+ NULL},
+ {"glBrown",
+ (getter)Part_getGlobBrown, (setter)Part_setGlobBrown,
+ "Specify the amount of brownian motion",
+ NULL},
+ {"glDamp",
+ (getter)Part_getGlobDamp, (setter)Part_setGlobDamp,
+ "Specify the amount of damping",
+ NULL},
/* Children */
{"childAmount",
(getter)Part_getChildAmount, (setter)Part_setChildAmount,
@@ -859,7 +992,96 @@
return ReactOn;
}
+/* create the Blender.Particle.Physics constant dict */
+static PyObject *Particle_PhysicsDict( void )
+{
+ PyObject *Physics = PyConstant_New( );
+
+ if( Physics ) {
+ BPy_constant *c = ( BPy_constant * ) Physics;
+
+ PyConstant_Insert( c, "BOIDS",
+ PyInt_FromLong( 3 ) );
+ PyConstant_Insert( c, "KEYED",
+ PyInt_FromLong( 2 ) );
+ PyConstant_Insert( c, "NEWTONIAN",
+ PyInt_FromLong( 1 ) );
+ PyConstant_Insert( c, "NONE",
+ PyInt_FromLong( 0 ) );
+ }
+ return Physics;
+}
+
+/* create the Blender.Particle.Integrator constant dict */
+
+static PyObject *Particle_IntegratorDict( void )
+{
+ PyObject *Integrator = PyConstant_New( );
+
+ if( Integrator ) {
+ BPy_constant *c = ( BPy_constant * ) Integrator;
+
+ PyConstant_Insert( c, "EULER",
+ PyInt_FromLong( 2 ) );
+ PyConstant_Insert( c, "MIDPOINT",
+ PyInt_FromLong( 1 ) );
+ PyConstant_Insert( c, "EULER",
+ PyInt_FromLong( 0 ) );
+ }
+ return Integrator;
+}
+
+/* create the Blender.Particle.Rotation constant dict */
+
+static PyObject *Particle_RotationDict( void )
+{
+ PyObject *Rotation = PyConstant_New( );
+
+ if( Rotation ) {
+ BPy_constant *c = ( BPy_constant * ) Rotation;
+
+ PyConstant_Insert( c, "OBZ",
+ PyInt_FromLong( 8 ) );
+ PyConstant_Insert( c, "OBY",
+ PyInt_FromLong( 7 ) );
+ PyConstant_Insert( c, "OBX",
+ PyInt_FromLong( 6 ) );
+ PyConstant_Insert( c, "GLZ",
+ PyInt_FromLong( 5 ) );
+ PyConstant_Insert( c, "GLY",
+ PyInt_FromLong( 4 ) );
+ PyConstant_Insert( c, "GLX",
+ PyInt_FromLong( 3 ) );
+ PyConstant_Insert( c, "VEL",
+ PyInt_FromLong( 2 ) );
+ PyConstant_Insert( c, "NOR",
+ PyInt_FromLong( 1 ) );
+ PyConstant_Insert( c, "NONE",
+ PyInt_FromLong( 0 ) );
+ }
+ return Rotation;
+}
+
+/* create the Blender.Particle.AngularV constant dict */
+
+static PyObject *Particle_AngularVDict( void )
+{
+ PyObject *AngularV = PyConstant_New( );
+
+ if( AngularV ) {
+ BPy_constant *c = ( BPy_constant * ) AngularV;
+
+ PyConstant_Insert( c, "RANDOM",
+ PyInt_FromLong( 2 ) );
+ PyConstant_Insert( c, "SPIN",
+ PyInt_FromLong( 1 ) );
+ PyConstant_Insert( c, "NONE",
+ PyInt_FromLong( 0 ) );
+ }
+ return AngularV;
+}
+
/* create the Blender.Particle.ChildType constant dict */
static PyObject *Particle_ChildTypeDict( void )
@@ -967,6 +1189,10 @@
PyObject *EmitFrom;
PyObject *Dist;
PyObject *DrawAs;
+ PyObject *Physics;
+ PyObject *Integrator;
+ PyObject *Rotation;
+ PyObject *AngularV;
PyObject *ChildTypes;
PyObject *ChildKinks;
PyObject *ChildKinkAxes;
@@ -980,6 +1206,10 @@
EmitFrom = Particle_EmitFrom();
DrawAs = Particle_DrawAs();
Dist = Particle_DistrDict();
+ Physics = Particle_PhysicsDict();
+ Integrator = Particle_IntegratorDict();
+ Rotation = Particle_RotationDict();
+ AngularV = Particle_AngularVDict();
ChildTypes = Particle_ChildTypeDict();
ChildKinks = Particle_ChildKinkDict();
ChildKinkAxes = Particle_ChildKinkAxisDict();
@@ -997,6 +1227,14 @@
PyModule_AddObject( submodule, "DISTRIBUTION", Dist );
if( DrawAs )
PyModule_AddObject( submodule, "DRAWAS", DrawAs );
+ if( Physics )
+ PyModule_AddObject( submodule, "PHYSICS", Physics );
+ if( Integrator )
+ PyModule_AddObject( submodule, "INTEGRATOR", Integrator );
+ if( Rotation )
+ PyModule_AddObject( submodule, "ROTATION", Rotation );
+ if( AngularV )
+ PyModule_AddObject( submodule, "ANGULARV", AngularV );
if( ChildTypes )
PyModule_AddObject( submodule, "CHILDTYPE", ChildTypes );
if( ChildKinks )
@@ Diff output truncated at 10240 characters. @@
More information about the Bf-blender-cvs
mailing list