Merge with trunk/2.5 at r25563
[blender-staging.git] / source / blender / makesdna / DNA_modifier_types.h
index be7452c4ae1451cd61152b780db89d4822b3a4a9..2491e58f176a823470b727771521ffc81039a292 100644 (file)
@@ -1,7 +1,28 @@
 /**
+ *
  * $Id$ 
+ *
+ * ***** 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.
+ *
+ * ***** END GPL LICENSE BLOCK *****
  */
 
+#include "DNA_listBase.h"
+
 #ifndef DNA_MODIFIER_TYPES_H
 #define DNA_MODIFIER_TYPES_H
 
@@ -42,6 +63,8 @@ typedef enum ModifierType {
        eModifierType_Multires,
        eModifierType_Surface,
        eModifierType_Smoke,
+       eModifierType_ShapeKey,
+       eModifierType_Solidify,
        NUM_MODIFIER_TYPES
 } ModifierType;
 
@@ -438,9 +461,7 @@ typedef struct CollisionModifierData {
        
        unsigned int numverts;
        unsigned int numfaces;
-       short absorption; /* used for forces, in % */
-       short pad;
-       float time;             /* cfra time of modifier */
+       float time, pad;                /* cfra time of modifier */
        struct BVHTree *bvhtree; /* bounding volume hierarchy for this cloth object */
 } CollisionModifierData;
 
@@ -469,8 +490,11 @@ typedef struct BooleanModifierData {
        int operation, pad;
 } BooleanModifierData;
 
-#define MOD_MDEF_INVERT_VGROUP (1<<0)
-#define MOD_MDEF_DYNAMIC_BIND  (1<<1)
+#define MOD_MDEF_INVERT_VGROUP (1<<0)
+#define MOD_MDEF_DYNAMIC_BIND  (1<<1)
+
+#define MOD_MDEF_VOLUME                        0
+#define MOD_MDEF_SURFACE               1
 
 typedef struct MDefInfluence {
        int vertex;
@@ -488,8 +512,7 @@ typedef struct MeshDeformModifierData {
        struct Object *object;                  /* mesh object */
        char defgrp_name[32];                   /* optional vertexgroup name */
 
-       short gridsize, needbind;
-       short flag, pad;
+       short gridsize, flag, mode, pad;
 
        /* variables filled in when bound */
        float *bindweights, *bindcos;   /* computed binding weights */
@@ -502,6 +525,11 @@ typedef struct MeshDeformModifierData {
        float dyncellmin[3];                    /* offset of the dynamic bind grid */
        float dyncellwidth;                             /* width of dynamic bind cell */
        float bindmat[4][4];                    /* matrix of cage at binding time */
+
+       /* runtime */
+       void (*bindfunc)(struct Scene *scene, struct DerivedMesh *dm,
+               struct MeshDeformModifierData *mmd,
+               float *vertexcos, int totvert, float cagemat[][4]);
 } MeshDeformModifierData;
 
 typedef enum {
@@ -558,14 +586,14 @@ typedef struct ExplodeModifierData {
 typedef struct MultiresModifierData {
        ModifierData modifier;
 
-       struct MVert *undo_verts; /* Store DerivedMesh vertices for multires undo */
-       int undo_verts_tot; /* Length of undo_verts array */
-       char undo_signal; /* If true, signals to replace verts with undo verts */
-
-       char lvl, totlvl;
-       char simple;
+       char lvl, sculptlvl, renderlvl, totlvl;
+       char simple, flags, pad[2];
 } MultiresModifierData;
 
+typedef enum {
+       eMultiresModifierFlag_ControlEdges = (1<<0),
+} MultiresModifierFlag;
+
 typedef struct FluidsimModifierData {
        ModifierData modifier;
        
@@ -644,4 +672,24 @@ typedef struct SimpleDeformModifierData {
 
 #define MOD_UVPROJECT_MAX                              10
 
+typedef struct ShapeKeyModifierData {
+       ModifierData modifier;
+} ShapeKeyModifierData;
+
+typedef struct SolidifyModifierData {
+       ModifierData modifier;
+
+       char vgroup[32];                /* name of vertex group to use */
+       float offset;                   /* new surface offset level*/
+       float crease_inner;
+       float crease_outer;
+       float crease_rim;
+       int flag;
+       char pad[4];
+} SolidifyModifierData;
+
+#define MOD_SOLIDIFY_RIM                       (1<<0)
+#define MOD_SOLIDIFY_EVEN                      (1<<1)
+#define MOD_SOLIDIFY_NORMAL_CALC       (1<<2)
+
 #endif