[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [47037] trunk/blender: solidify option to flip normals
Campbell Barton
ideasman42 at gmail.com
Sat May 26 11:18:48 CEST 2012
Revision: 47037
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=47037
Author: campbellbarton
Date: 2012-05-26 09:18:47 +0000 (Sat, 26 May 2012)
Log Message:
-----------
solidify option to flip normals
Modified Paths:
--------------
trunk/blender/release/scripts/startup/bl_ui/properties_data_modifier.py
trunk/blender/source/blender/makesdna/DNA_modifier_types.h
trunk/blender/source/blender/makesrna/intern/rna_modifier.c
trunk/blender/source/blender/modifiers/intern/MOD_solidify.c
Modified: trunk/blender/release/scripts/startup/bl_ui/properties_data_modifier.py
===================================================================
--- trunk/blender/release/scripts/startup/bl_ui/properties_data_modifier.py 2012-05-26 08:31:34 UTC (rev 47036)
+++ trunk/blender/release/scripts/startup/bl_ui/properties_data_modifier.py 2012-05-26 09:18:47 UTC (rev 47037)
@@ -682,6 +682,7 @@
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)
Modified: trunk/blender/source/blender/makesdna/DNA_modifier_types.h
===================================================================
--- trunk/blender/source/blender/makesdna/DNA_modifier_types.h 2012-05-26 08:31:34 UTC (rev 47036)
+++ trunk/blender/source/blender/makesdna/DNA_modifier_types.h 2012-05-26 09:18:47 UTC (rev 47037)
@@ -728,11 +728,12 @@
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;
Modified: trunk/blender/source/blender/makesrna/intern/rna_modifier.c
===================================================================
--- trunk/blender/source/blender/makesrna/intern/rna_modifier.c 2012-05-26 08:31:34 UTC (rev 47036)
+++ trunk/blender/source/blender/makesrna/intern/rna_modifier.c 2012-05-26 09:18:47 UTC (rev 47037)
@@ -2553,8 +2553,11 @@
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)
Modified: trunk/blender/source/blender/modifiers/intern/MOD_solidify.c
===================================================================
--- trunk/blender/source/blender/modifiers/intern/MOD_solidify.c 2012-05-26 08:31:34 UTC (rev 47036)
+++ trunk/blender/source/blender/modifiers/intern/MOD_solidify.c 2012-05-26 09:18:47 UTC (rev 47037)
@@ -50,19 +50,14 @@
#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 @@
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 @@
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 @@
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 @@
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) {
More information about the Bf-blender-cvs
mailing list