diff options
author | Campbell Barton <ideasman42@gmail.com> | 2015-06-04 12:49:59 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2015-06-04 19:56:11 +0300 |
commit | 455ca1b28f140482f2834c9bba0adc730aff6637 (patch) | |
tree | 33203edd53c9bbc8b0b8cd8a897487952597c298 /source/blender/modifiers/intern/MOD_decimate.c | |
parent | c64f491f9f45d802bc3a3cb168255dc680ea0d13 (diff) |
BMesh decimate, improve behavior with weights
Add slider to adjust the influence of weights relative to geometry distortion.
This allows subtle influences to be applied - without drastic changes in behavior.
Diffstat (limited to 'source/blender/modifiers/intern/MOD_decimate.c')
-rw-r--r-- | source/blender/modifiers/intern/MOD_decimate.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/source/blender/modifiers/intern/MOD_decimate.c b/source/blender/modifiers/intern/MOD_decimate.c index 7c13774ee99..878015c7a7b 100644 --- a/source/blender/modifiers/intern/MOD_decimate.c +++ b/source/blender/modifiers/intern/MOD_decimate.c @@ -61,6 +61,7 @@ static void initData(ModifierData *md) dmd->percent = 1.0; dmd->angle = DEG2RADF(5.0f); + dmd->defgrp_factor = 1.0; } static void copyData(ModifierData *md, ModifierData *target) @@ -78,7 +79,9 @@ static CustomDataMask requiredDataMask(Object *UNUSED(ob), ModifierData *md) CustomDataMask dataMask = 0; /* ask for vertexgroups if we need them */ - if (dmd->defgrp_name[0]) dataMask |= CD_MASK_MDEFORMVERT; + if (dmd->defgrp_name[0] && (dmd->defgrp_factor > 0.0f)) { + dataMask |= CD_MASK_MDEFORMVERT; + } return dataMask; } @@ -130,7 +133,7 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob, } if (dmd->mode == MOD_DECIM_MODE_COLLAPSE) { - if (dmd->defgrp_name[0]) { + if (dmd->defgrp_name[0] && (dmd->defgrp_factor > 0.0f)) { MDeformVert *dvert; int defgrp_index; @@ -144,14 +147,12 @@ static DerivedMesh *applyModifier(ModifierData *md, Object *ob, if (dmd->flag & MOD_DECIM_FLAG_INVERT_VGROUP) { for (i = 0; i < vert_tot; i++) { - const float f = 1.0f - defvert_find_weight(&dvert[i], defgrp_index); - vweights[i] = f > BM_MESH_DECIM_WEIGHT_EPS ? (1.0f / f) : BM_MESH_DECIM_WEIGHT_MAX; + vweights[i] = (1.0f - defvert_find_weight(&dvert[i], defgrp_index)) * dmd->defgrp_factor; } } else { for (i = 0; i < vert_tot; i++) { - const float f = defvert_find_weight(&dvert[i], defgrp_index); - vweights[i] = f > BM_MESH_DECIM_WEIGHT_EPS ? (1.0f / f) : BM_MESH_DECIM_WEIGHT_MAX; + vweights[i] = (defvert_find_weight(&dvert[i], defgrp_index)) * dmd->defgrp_factor; } } } |