solidify option to flip normals
authorCampbell Barton <ideasman42@gmail.com>
Sat, 26 May 2012 09:18:47 +0000 (09:18 +0000)
committerCampbell Barton <ideasman42@gmail.com>
Sat, 26 May 2012 09:18:47 +0000 (09:18 +0000)
release/scripts/startup/bl_ui/properties_data_modifier.py
source/blender/makesdna/DNA_modifier_types.h
source/blender/makesrna/intern/rna_modifier.c
source/blender/modifiers/intern/MOD_solidify.c

index 72429743c934866732423aa62b0327de308fe4c1..2e980f776a1f9b08ad89a5ca139b6d395e1ac50f 100644 (file)
@@ -682,6 +682,7 @@ class DATA_PT_modifiers(ModifierButtonsPanel, Panel):
         row = row.row()
         row.active = md.use_rim
         row.prop(md, "material_offset_rim", text="Rim")
+        sub.prop(md, "use_flip_normals")
 
     def SUBSURF(self, layout, ob, md):
         layout.row().prop(md, "subdivision_type", expand=True)
index a5a540ff6b43c01b8fcee30dd8567b1864c385b2..cf8b08549f6981ced7b9cb84aab2026ba898c3f8 100644 (file)
@@ -728,11 +728,12 @@ typedef struct SolidifyModifierData {
        short mat_ofs_rim;
 } SolidifyModifierData;
 
-#define MOD_SOLIDIFY_RIM                       (1<<0)
-#define MOD_SOLIDIFY_EVEN                      (1<<1)
-#define MOD_SOLIDIFY_NORMAL_CALC       (1<<2)
-#define MOD_SOLIDIFY_VGROUP_INV                (1<<3)
-#define MOD_SOLIDIFY_RIM_MATERIAL      (1<<4) /* deprecated, used in do_versions */
+#define MOD_SOLIDIFY_RIM            (1 << 0)
+#define MOD_SOLIDIFY_EVEN           (1 << 1)
+#define MOD_SOLIDIFY_NORMAL_CALC    (1 << 2)
+#define MOD_SOLIDIFY_VGROUP_INV     (1 << 3)
+#define MOD_SOLIDIFY_RIM_MATERIAL   (1 << 4) /* deprecated, used in do_versions */
+#define MOD_SOLIDIFY_FLIP           (1 << 5)
 
 typedef struct ScrewModifierData {
        ModifierData modifier;
index 659c04015df365c7fe66317a5a6f3b71feaa0634..21a01cf43a8152601a7f86a351e5ed7fe43ee553 100644 (file)
@@ -2553,8 +2553,11 @@ static void rna_def_modifier_solidify(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SOLIDIFY_VGROUP_INV);
        RNA_def_property_ui_text(prop, "Vertex Group Invert", "Invert the vertex group influence");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
-       
-       
+
+       prop = RNA_def_property(srna, "use_flip_normals", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SOLIDIFY_FLIP);
+       RNA_def_property_ui_text(prop, "Flip Normals", "Invert the face direction");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
 static void rna_def_modifier_screw(BlenderRNA *brna)
index 5d31420da86ec2d739b114f5ce2ec85ff7e60f74..f29455447bb60a3cf70b584bc84cc72ce5d1e901 100644 (file)
 #include "MOD_modifiertypes.h"
 #include "MOD_util.h"
 
+/* *** derived mesh high quality normal calculation function  *** */
+/* could be exposed for other functions to use */
+
 typedef struct EdgeFaceRef {
        int f1; /* init as -1 */
        int f2;
 } EdgeFaceRef;
 
-/* spesific function for solidify - define locally */
-BLI_INLINE void madd_v3v3short_fl(float r[3], const short a[3], const float f)
-{
-       r[0] += (float)a[0] * f;
-       r[1] += (float)a[1] * f;
-       r[2] += (float)a[2] * f;
-}
-
 static void dm_calc_normal(DerivedMesh *dm, float (*temp_nors)[3])
 {
        int i, numVerts, numEdges, numFaces;
@@ -207,6 +202,13 @@ static CustomDataMask requiredDataMask(Object *UNUSED(ob), ModifierData *md)
        return dataMask;
 }
 
+/* spesific function for solidify - define locally */
+BLI_INLINE void madd_v3v3short_fl(float r[3], const short a[3], const float f)
+{
+       r[0] += (float)a[0] * f;
+       r[1] += (float)a[1] * f;
+       r[2] += (float)a[2] * f;
+}
 
 static DerivedMesh *applyModifier(ModifierData *md, Object *ob, 
                                   DerivedMesh *dm,
@@ -249,6 +251,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob,
        const float ofs_new  = smd->offset + ofs_orig;
        const float offset_fac_vg = smd->offset_fac_vg;
        const float offset_fac_vg_inv = 1.0f - smd->offset_fac_vg;
+       const int   do_flip = (smd->flag & MOD_SOLIDIFY_FLIP) != 0;
 
        /* weights */
        MDeformVert *dvert, *dv = NULL;
@@ -420,7 +423,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob,
 
                if (ofs_new != 0.0f) {
                        scalar_short = scalar_short_vgroup = ofs_new / 32767.0f;
-                       mv = mvert + ((ofs_new >= ofs_orig) ? 0 : numVerts);
+                       mv = mvert + (((ofs_new >= ofs_orig) == do_flip) ? numVerts : 0);
                        dv = dvert;
                        for (i = 0; i < numVerts; i++, mv++) {
                                if (dv) {
@@ -435,7 +438,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob,
 
                if (ofs_orig != 0.0f) {
                        scalar_short = scalar_short_vgroup = ofs_orig / 32767.0f;
-                       mv = mvert + ((ofs_new >= ofs_orig) ? numVerts : 0); /* as above but swapped, intentional use 'ofs_new' */
+                       mv = mvert + (((ofs_new >= ofs_orig) == do_flip) ? 0 : numVerts); /* as above but swapped, intentional use 'ofs_new' */
                        dv = dvert;
                        for (i = 0; i < numVerts; i++, mv++) {
                                if (dv) {
@@ -536,7 +539,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob,
                }
 
                if (ofs_new) {
-                       mv = mvert + ((ofs_new >= ofs_orig) ? 0 : numVerts);
+                       mv = mvert + (((ofs_new >= ofs_orig) == do_flip) ? numVerts : 0);
 
                        for (i = 0; i < numVerts; i++, mv++) {
                                if (vert_accum[i]) { /* zero if unselected */
@@ -547,7 +550,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob,
 
                if (ofs_orig) {
                        /* same as above but swapped, intentional use of 'ofs_new' */
-                       mv = mvert + ((ofs_new >= ofs_orig) ? numVerts : 0);
+                       mv = mvert + (((ofs_new >= ofs_orig) == do_flip) ? 0 : numVerts);
 
                        for (i = 0; i < numVerts; i++, mv++) {
                                if (vert_accum[i]) { /* zero if unselected */