Commit: fcff61a1bd9dc925df69425a4b73d8e4f0ad66a0
Author: Martin Felke
Date:   Thu Jun 8 15:40:20 2017 +0200
Branches: fracture_modifier
https://developer.blender.org/rBfcff61a1bd9dc925df69425a4b73d8e4f0ad66a0

made do_merge and keep_distort optional

===================================================================

M       release/scripts/startup/bl_operators/presets.py
M       release/scripts/startup/bl_ui/properties_physics_fracture.py
M       source/blender/makesdna/DNA_modifier_types.h
M       source/blender/makesrna/intern/rna_fracture.c
M       source/blender/modifiers/intern/MOD_fracture.c

===================================================================

diff --git a/release/scripts/startup/bl_operators/presets.py 
b/release/scripts/startup/bl_operators/presets.py
index f521cb0b761..1f045e2e92b 100644
--- a/release/scripts/startup/bl_operators/presets.py
+++ b/release/scripts/startup/bl_operators/presets.py
@@ -686,7 +686,10 @@ class AddPresetFracture(AddPresetBase, Operator):
         "fracture.use_constraint_collision",
         "fracture.inner_crease",
         "fracture.material_offset_difference",
-        "fracture.material_offset_intersect"
+        "fracture.material_offset_intersect",
+        "fracture.orthogonality_factor",
+        "fracture.keep_distort",
+        "fracture.do_merge"
     ]
 
     preset_subdir = "fracture"
diff --git a/release/scripts/startup/bl_ui/properties_physics_fracture.py 
b/release/scripts/startup/bl_ui/properties_physics_fracture.py
index fd41310dde3..d7140b561b8 100644
--- a/release/scripts/startup/bl_ui/properties_physics_fracture.py
+++ b/release/scripts/startup/bl_ui/properties_physics_fracture.py
@@ -256,6 +256,9 @@ class PHYSICS_PT_fracture_utilities(PhysicButtonsPanel, 
Panel):
         col.prop(md, "autohide_dist")
         col.prop(md, "automerge_dist")
         row = layout.row()
+        row.prop(md, "keep_distort")
+        row.prop(md, "do_merge")
+        row = layout.row()
         row.prop(md, "fix_normals")
         row.prop(md, "nor_range")
 
diff --git a/source/blender/makesdna/DNA_modifier_types.h 
b/source/blender/makesdna/DNA_modifier_types.h
index 8705b1f0746..e838f28f95c 100644
--- a/source/blender/makesdna/DNA_modifier_types.h
+++ b/source/blender/makesdna/DNA_modifier_types.h
@@ -1770,6 +1770,8 @@ typedef struct FractureModifierData {
        int fracture_all;
        int dynamic_new_constraints;
        int is_dynamic_external;
+       int keep_distort;
+       int do_merge;
 
        /* internal flags */
        int use_experimental;
diff --git a/source/blender/makesrna/intern/rna_fracture.c 
b/source/blender/makesrna/intern/rna_fracture.c
index 336e56e3427..0f342e0333d 100644
--- a/source/blender/makesrna/intern/rna_fracture.c
+++ b/source/blender/makesrna/intern/rna_fracture.c
@@ -595,7 +595,7 @@ static void rna_Modifier_update_and_keep(Main 
*UNUSED(bmain), Scene *UNUSED(scen
        if (md && md->type == eModifierType_Fracture)
        {
                FractureModifierData *fmd = (FractureModifierData*)md;
-               if (fmd->fracture_mode == MOD_FRACTURE_PREFRACTURED)
+               if (fmd->fracture_mode == MOD_FRACTURE_PREFRACTURED || 
fmd->fracture_mode == MOD_FRACTURE_EXTERNAL)
                {
                        FractureSetting* fs = 
BLI_findlink(&fmd->fracture_settings, fmd->active_setting);
                        BKE_fracture_store_settings(fmd, fs);
@@ -605,10 +605,10 @@ static void rna_Modifier_update_and_keep(Main 
*UNUSED(bmain), Scene *UNUSED(scen
                                return;
                        }
                }
-       }
 
-       DAG_id_tag_update(ptr->id.data, OB_RECALC_DATA);
-       WM_main_add_notifier(NC_OBJECT | ND_MODIFIER, ptr->id.data);
+               DAG_id_tag_update(ptr->id.data, OB_RECALC_DATA);
+               WM_main_add_notifier(NC_OBJECT | ND_MODIFIER, ptr->id.data);
+       }
 }
 
 #endif
@@ -1247,5 +1247,15 @@ void RNA_def_fracture(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Orthogonality Factor",  "1 means only 
orthogonal cuts, move down to 0 to get more diagonal-ish cuts");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop = RNA_def_property(srna, "keep_distort", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "keep_distort", false);
+       RNA_def_property_ui_text(prop, "Keep Distortion", "Whether or not to 
make the distortion on torn merged shards persistent.");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update_and_keep");
+
+       prop = RNA_def_property(srna, "do_merge", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "do_merge", false);
+       RNA_def_property_ui_text(prop, "Perform Merge", "Whether or not to 
actually weld the prepared automerge geometry.");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update_and_keep");
+
        RNA_api_fracture(brna, srna);
 }
diff --git a/source/blender/modifiers/intern/MOD_fracture.c 
b/source/blender/modifiers/intern/MOD_fracture.c
index a8e99eefe18..bf29e845e85 100644
--- a/source/blender/modifiers/intern/MOD_fracture.c
+++ b/source/blender/modifiers/intern/MOD_fracture.c
@@ -253,6 +253,10 @@ static void initData(ModifierData *md)
 
        fmd->mat_ofs_difference = 0;
        fmd->mat_ofs_intersect = 0;
+
+       fmd->orthogonality_factor = 0.0f;
+       fmd->keep_distort = false;
+       fmd->do_merge = false;
 }
 
 //XXX TODO, freeing functionality should be in BKE too
@@ -1839,6 +1843,9 @@ static void copyData(ModifierData *md, ModifierData 
*target)
 
        trmd->mat_ofs_difference = rmd->mat_ofs_difference;
        trmd->mat_ofs_intersect = rmd->mat_ofs_intersect;
+       trmd->keep_distort = rmd->keep_distort;
+       trmd->do_merge = rmd->do_merge;
+       trmd->orthogonality_factor = rmd->orthogonality_factor;
 }
 
 //XXXX TODO, is BB really useds still ? aint there exact volume calc now ?
@@ -3240,7 +3247,7 @@ static void prepare_automerge(FractureModifierData *fmd, 
BMesh *bm)
 {
        SharedVert *sv;
        SharedVertGroup *vg;
-       bool do_calc_delta = true;
+       bool do_calc_delta = fmd->keep_distort;
 
        int cd_edge_crease_offset = CustomData_get_offset(&bm->edata, 
CD_CREASE);
        if (cd_edge_crease_offset == -1) {
@@ -3346,7 +3353,7 @@ static DerivedMesh *do_autoHide(FractureModifierData 
*fmd, DerivedMesh *dm, Obje
        DerivedMesh *result;
        BMFace **faces = MEM_mallocN(sizeof(BMFace *), "faces");
        int del_faces = 0;
-       bool do_merge = true;
+       bool do_merge = fmd->do_merge;
 
        DM_to_bmesh_ex(dm, bm, true);

_______________________________________________
Bf-blender-cvs mailing list
[email protected]
https://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to