Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2013-04-07 09:13:00 +0400
committerCampbell Barton <ideasman42@gmail.com>2013-04-07 09:13:00 +0400
commit36cc2fd6da09c75a28b8c9d4871d513caaf2ac69 (patch)
tree170068ded2194ada00d0b86d4ac3cf5edfe92ac6 /source/blender/editors/mesh/editmesh_inset.c
parent6f1f897d342a632c959e3507a9de3c0df4f71eef (diff)
mesh inset tool - option to interpolate UV's vcols etc, on by default since this is almost always what you'd want.
currently only working for inset-individual, inset-region coming next.
Diffstat (limited to 'source/blender/editors/mesh/editmesh_inset.c')
-rw-r--r--source/blender/editors/mesh/editmesh_inset.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/source/blender/editors/mesh/editmesh_inset.c b/source/blender/editors/mesh/editmesh_inset.c
index a9093824a9d..c9a96018e2a 100644
--- a/source/blender/editors/mesh/editmesh_inset.c
+++ b/source/blender/editors/mesh/editmesh_inset.c
@@ -99,7 +99,7 @@ static void edbm_inset_update_header(wmOperator *op, bContext *C)
opdata->modify_depth ? IFACE_("On") : IFACE_("Off"),
RNA_boolean_get(op->ptr, "use_outset") ? IFACE_("On") : IFACE_("Off"),
RNA_boolean_get(op->ptr, "use_boundary") ? IFACE_("On") : IFACE_("Off"),
- RNA_boolean_get(op->ptr, "individual") ? IFACE_("On") : IFACE_("Off")
+ RNA_boolean_get(op->ptr, "use_individual") ? IFACE_("On") : IFACE_("Off")
);
ED_area_headerprint(sa, msg);
@@ -192,7 +192,8 @@ static int edbm_inset_calc(wmOperator *op)
const float depth = RNA_float_get(op->ptr, "depth");
const bool use_outset = RNA_boolean_get(op->ptr, "use_outset");
const bool use_select_inset = RNA_boolean_get(op->ptr, "use_select_inset"); /* not passed onto the BMO */
- const bool individual = RNA_boolean_get(op->ptr, "individual");
+ const bool use_individual = RNA_boolean_get(op->ptr, "use_individual");
+ const bool use_interpolate = RNA_boolean_get(op->ptr, "use_interpolate");
opdata = op->customdata;
em = opdata->em;
@@ -201,10 +202,10 @@ static int edbm_inset_calc(wmOperator *op)
EDBM_redo_state_restore(opdata->mesh_backup, em, false);
}
- if (individual) {
+ if (use_individual) {
EDBM_op_init(em, &bmop, op,
- "inset_individual faces=%hf thickness=%f depth=%f use_even_offset=%b",
- BM_ELEM_SELECT, thickness, depth, use_even_offset);
+ "inset_individual faces=%hf thickness=%f depth=%f use_even_offset=%b use_interpolate=%b",
+ BM_ELEM_SELECT, thickness, depth, use_even_offset, use_interpolate);
}
else {
EDBM_op_init(em, &bmop, op,
@@ -420,8 +421,8 @@ static int edbm_inset_modal(bContext *C, wmOperator *op, const wmEvent *event)
break;
case IKEY:
if (event->val == KM_PRESS) {
- int individual = RNA_boolean_get(op->ptr, "individual");
- RNA_boolean_set(op->ptr, "individual", !individual);
+ const bool use_individual = RNA_boolean_get(op->ptr, "use_individual");
+ RNA_boolean_set(op->ptr, "use_individual", !use_individual);
if (edbm_inset_calc(op)) {
edbm_inset_update_header(op, C);
}
@@ -470,5 +471,6 @@ void MESH_OT_inset(wmOperatorType *ot)
RNA_def_boolean(ot->srna, "use_outset", false, "Outset", "Outset rather than inset");
RNA_def_boolean(ot->srna, "use_select_inset", true, "Select Outer", "Select the new inset faces");
- RNA_def_boolean(ot->srna, "individual", false, "Individual", "Individual Face Inset");
+ RNA_def_boolean(ot->srna, "use_individual", false, "Individual", "Individual Face Inset");
+ RNA_def_boolean(ot->srna, "use_interpolate", true, "Interpolate", "Blend face data across the inset");
}