diff options
Diffstat (limited to 'source/blender/modifiers/intern/MOD_shrinkwrap.c')
-rw-r--r-- | source/blender/modifiers/intern/MOD_shrinkwrap.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/source/blender/modifiers/intern/MOD_shrinkwrap.c b/source/blender/modifiers/intern/MOD_shrinkwrap.c index 11dc0a92769..c0f7a0a7db0 100644 --- a/source/blender/modifiers/intern/MOD_shrinkwrap.c +++ b/source/blender/modifiers/intern/MOD_shrinkwrap.c @@ -25,18 +25,29 @@ #include "BLI_utildefines.h" +#include "BLT_translation.h" + #include "DNA_mesh_types.h" #include "DNA_object_types.h" +#include "DNA_screen_types.h" +#include "BKE_context.h" #include "BKE_editmesh.h" #include "BKE_lib_id.h" #include "BKE_lib_query.h" #include "BKE_mesh.h" #include "BKE_modifier.h" +#include "BKE_screen.h" #include "BKE_shrinkwrap.h" +#include "UI_interface.h" +#include "UI_resources.h" + +#include "RNA_access.h" + #include "DEG_depsgraph_query.h" +#include "MOD_ui_common.h" #include "MOD_util.h" static bool dependsOnNormals(ModifierData *md); @@ -203,6 +214,65 @@ static bool dependsOnNormals(ModifierData *md) return false; } +static void panel_draw(const bContext *C, Panel *panel) +{ + uiLayout *row, *col; + uiLayout *layout = panel->layout; + int toggles_flag = UI_ITEM_R_TOGGLE | UI_ITEM_R_FORCE_BLANK_DECORATE; + + PointerRNA ptr; + PointerRNA ob_ptr; + modifier_panel_get_property_pointers(C, panel, &ob_ptr, &ptr); + + uiLayoutSetPropSep(layout, true); + + int wrap_method = RNA_enum_get(&ptr, "wrap_method"); + + uiItemR(layout, &ptr, "wrap_method", 0, NULL, ICON_NONE); + + if (ELEM(wrap_method, + MOD_SHRINKWRAP_PROJECT, + MOD_SHRINKWRAP_NEAREST_SURFACE, + MOD_SHRINKWRAP_TARGET_PROJECT)) { + uiItemR(layout, &ptr, "wrap_mode", 0, NULL, ICON_NONE); + } + + if (wrap_method == MOD_SHRINKWRAP_PROJECT) { + uiItemR(layout, &ptr, "project_limit", 0, IFACE_("Limit"), ICON_NONE); + uiItemR(layout, &ptr, "subsurf_levels", 0, NULL, ICON_NONE); + + row = uiLayoutRowWithHeading(layout, true, IFACE_("Axis")); + uiItemR(row, &ptr, "use_project_x", toggles_flag, NULL, ICON_NONE); + uiItemR(row, &ptr, "use_project_y", toggles_flag, NULL, ICON_NONE); + uiItemR(row, &ptr, "use_project_z", toggles_flag, NULL, ICON_NONE); + + uiItemR(layout, &ptr, "use_negative_direction", 0, NULL, ICON_NONE); + uiItemR(layout, &ptr, "use_positive_direction", 0, NULL, ICON_NONE); + + uiItemR(layout, &ptr, "cull_face", UI_ITEM_R_EXPAND, NULL, ICON_NONE); + col = uiLayoutColumn(layout, false); + uiLayoutSetActive(col, + RNA_boolean_get(&ptr, "use_negative_direction") && + RNA_enum_get(&ptr, "cull_face") != 0); + uiItemR(col, &ptr, "use_invert_cull", 0, NULL, ICON_NONE); + } + + uiItemR(layout, &ptr, "target", 0, NULL, ICON_NONE); + if (wrap_method == MOD_SHRINKWRAP_PROJECT) { + uiItemR(layout, &ptr, "auxiliary_target", 0, NULL, ICON_NONE); + } + uiItemR(layout, &ptr, "offset", 0, NULL, ICON_NONE); + + modifier_vgroup_ui(layout, &ptr, &ob_ptr, "vertex_group", "invert_vertex_group", NULL); + + modifier_panel_end(layout, &ptr); +} + +static void panelRegister(ARegionType *region_type) +{ + modifier_panel_register(region_type, eModifierType_Shrinkwrap, panel_draw); +} + ModifierTypeInfo modifierType_Shrinkwrap = { /* name */ "Shrinkwrap", /* structName */ "ShrinkwrapModifierData", @@ -234,4 +304,5 @@ ModifierTypeInfo modifierType_Shrinkwrap = { /* foreachIDLink */ NULL, /* foreachTexLink */ NULL, /* freeRuntimeData */ NULL, + /* panelRegister */ panelRegister, }; |