Blender V4.3
MOD_shrinkwrap.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2005 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
9#include <cstring>
10
11#include "BLI_utildefines.h"
12
13#include "BLT_translation.hh"
14
15#include "DNA_defaults.h"
16#include "DNA_object_types.h"
17#include "DNA_screen_types.h"
18
19#include "BKE_lib_query.hh"
20#include "BKE_modifier.hh"
21#include "BKE_shrinkwrap.hh"
22
23#include "UI_interface.hh"
24#include "UI_resources.hh"
25
26#include "RNA_access.hh"
27#include "RNA_prototypes.hh"
28
30
31#include "MOD_ui_common.hh"
32#include "MOD_util.hh"
33
42
43static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
44{
46
47 /* Ask for vertex-groups if we need them. */
48 if (smd->vgroup_name[0] != '\0') {
49 r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
50 }
51}
52
53static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
54{
56
57 /* The object type check is only needed here in case we have a placeholder
58 * object assigned (because the library containing the mesh is missing).
59 *
60 * In other cases it should be impossible to have a type mismatch.
61 */
62 if (!smd->target || smd->target->type != OB_MESH) {
63 return true;
64 }
65 if (smd->auxTarget && smd->auxTarget->type != OB_MESH) {
66 return true;
67 }
68 return false;
69}
70
71static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
72{
74
75 walk(user_data, ob, (ID **)&smd->target, IDWALK_CB_NOP);
76 walk(user_data, ob, (ID **)&smd->auxTarget, IDWALK_CB_NOP);
77}
78
79static void deform_verts(ModifierData *md,
80 const ModifierEvalContext *ctx,
81 Mesh *mesh,
83{
86
87 const MDeformVert *dvert = nullptr;
88 int defgrp_index = -1;
89 MOD_get_vgroup(ctx->object, mesh, swmd->vgroup_name, &dvert, &defgrp_index);
90
92 ctx,
93 scene,
94 ctx->object,
95 mesh,
96 dvert,
97 defgrp_index,
98 reinterpret_cast<float(*)[3]>(positions.data()),
99 positions.size());
100}
101
103{
105 CustomData_MeshMasks mask = {0};
106
109 }
110
111 if (smd->target != nullptr) {
112 DEG_add_object_relation(ctx->node, smd->target, DEG_OB_COMP_TRANSFORM, "Shrinkwrap Modifier");
113 DEG_add_object_relation(ctx->node, smd->target, DEG_OB_COMP_GEOMETRY, "Shrinkwrap Modifier");
114 DEG_add_customdata_mask(ctx->node, smd->target, &mask);
117 }
118 }
119 if (smd->auxTarget != nullptr) {
121 ctx->node, smd->auxTarget, DEG_OB_COMP_TRANSFORM, "Shrinkwrap Modifier");
123 ctx->node, smd->auxTarget, DEG_OB_COMP_GEOMETRY, "Shrinkwrap Modifier");
124 DEG_add_customdata_mask(ctx->node, smd->auxTarget, &mask);
127 }
128 }
129 DEG_add_depends_on_transform_relation(ctx->node, "Shrinkwrap Modifier");
130}
131
132static void panel_draw(const bContext * /*C*/, Panel *panel)
133{
134 uiLayout *row, *col;
135 uiLayout *layout = panel->layout;
137
138 PointerRNA ob_ptr;
140
141 uiLayoutSetPropSep(layout, true);
142
143 int wrap_method = RNA_enum_get(ptr, "wrap_method");
144
145 uiItemR(layout, ptr, "wrap_method", UI_ITEM_NONE, nullptr, ICON_NONE);
146
147 if (ELEM(wrap_method,
151 {
152 uiItemR(layout, ptr, "wrap_mode", UI_ITEM_NONE, nullptr, ICON_NONE);
153 }
154
155 if (wrap_method == MOD_SHRINKWRAP_PROJECT) {
156 uiItemR(layout, ptr, "project_limit", UI_ITEM_NONE, IFACE_("Limit"), ICON_NONE);
157 uiItemR(layout, ptr, "subsurf_levels", UI_ITEM_NONE, nullptr, ICON_NONE);
158
159 col = uiLayoutColumn(layout, false);
160 row = uiLayoutRowWithHeading(col, true, IFACE_("Axis"));
161 uiItemR(row, ptr, "use_project_x", toggles_flag, nullptr, ICON_NONE);
162 uiItemR(row, ptr, "use_project_y", toggles_flag, nullptr, ICON_NONE);
163 uiItemR(row, ptr, "use_project_z", toggles_flag, nullptr, ICON_NONE);
164
165 uiItemR(col, ptr, "use_negative_direction", UI_ITEM_NONE, nullptr, ICON_NONE);
166 uiItemR(col, ptr, "use_positive_direction", UI_ITEM_NONE, nullptr, ICON_NONE);
167
168 uiItemR(layout, ptr, "cull_face", UI_ITEM_R_EXPAND, nullptr, ICON_NONE);
169 col = uiLayoutColumn(layout, false);
171 RNA_boolean_get(ptr, "use_negative_direction") &&
172 RNA_enum_get(ptr, "cull_face") != 0);
173 uiItemR(col, ptr, "use_invert_cull", UI_ITEM_NONE, nullptr, ICON_NONE);
174 }
175
176 uiItemR(layout, ptr, "target", UI_ITEM_NONE, nullptr, ICON_NONE);
177 if (wrap_method == MOD_SHRINKWRAP_PROJECT) {
178 uiItemR(layout, ptr, "auxiliary_target", UI_ITEM_NONE, nullptr, ICON_NONE);
179 }
180 uiItemR(layout, ptr, "offset", UI_ITEM_NONE, nullptr, ICON_NONE);
181
182 modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", nullptr);
183
184 modifier_panel_end(layout, ptr);
185}
186
187static void panel_register(ARegionType *region_type)
188{
190}
191
193 /*idname*/ "Shrinkwrap",
194 /*name*/ N_("Shrinkwrap"),
195 /*struct_name*/ "ShrinkwrapModifierData",
196 /*struct_size*/ sizeof(ShrinkwrapModifierData),
197 /*srna*/ &RNA_ShrinkwrapModifier,
202 /*icon*/ ICON_MOD_SHRINKWRAP,
203
204 /*copy_data*/ BKE_modifier_copydata_generic,
205
206 /*deform_verts*/ deform_verts,
207 /*deform_matrices*/ nullptr,
208 /*deform_verts_EM*/ nullptr,
209 /*deform_matrices_EM*/ nullptr,
210 /*modify_mesh*/ nullptr,
211 /*modify_geometry_set*/ nullptr,
212
213 /*init_data*/ init_data,
214 /*required_data_mask*/ required_data_mask,
215 /*free_data*/ nullptr,
216 /*is_disabled*/ is_disabled,
217 /*update_depsgraph*/ update_depsgraph,
218 /*depends_on_time*/ nullptr,
219 /*depends_on_normals*/ nullptr,
220 /*foreach_ID_link*/ foreach_ID_link,
221 /*foreach_tex_link*/ nullptr,
222 /*free_runtime_data*/ nullptr,
223 /*panel_register*/ panel_register,
224 /*blend_write*/ nullptr,
225 /*blend_read*/ nullptr,
226 /*foreach_cache*/ nullptr,
227};
@ IDWALK_CB_NOP
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_AcceptsCVs
@ eModifierTypeFlag_EnableInEditmode
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsVertexCosOnly
@ eModifierTypeFlag_AcceptsMesh
void(*)(void *user_data, Object *ob, ID **idpoin, int cb_flag) IDWalkFunc
void shrinkwrapModifier_deform(ShrinkwrapModifierData *smd, const ModifierEvalContext *ctx, Scene *scene, Object *ob, Mesh *mesh, const MDeformVert *dvert, int defgrp_index, float(*vertexCos)[3], int numVerts)
bool BKE_shrinkwrap_needs_normals(int shrinkType, int shrinkMode)
Definition shrinkwrap.cc:89
#define BLI_assert(a)
Definition BLI_assert.h:50
#define ELEM(...)
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
#define IFACE_(msgid)
@ DAG_EVAL_NEED_SHRINKWRAP_BOUNDARY
void DEG_add_depends_on_transform_relation(DepsNodeHandle *node_handle, const char *description)
void DEG_add_customdata_mask(DepsNodeHandle *handle, Object *object, const CustomData_MeshMasks *masks)
void DEG_add_object_relation(DepsNodeHandle *node_handle, Object *object, eDepsObjectComponentType component, const char *description)
void DEG_add_special_eval_flag(DepsNodeHandle *handle, ID *id, uint32_t flag)
@ DEG_OB_COMP_GEOMETRY
@ DEG_OB_COMP_TRANSFORM
Scene * DEG_get_evaluated_scene(const Depsgraph *graph)
#define CD_MASK_MDEFORMVERT
#define CD_MASK_CUSTOMLOOPNORMAL
#define DNA_struct_default_get(struct_name)
@ MOD_SHRINKWRAP_TARGET_PROJECT
@ MOD_SHRINKWRAP_PROJECT
@ MOD_SHRINKWRAP_NEAREST_SURFACE
struct ShrinkwrapModifierData ShrinkwrapModifierData
@ eModifierType_Shrinkwrap
Object is a sort of wrapper for general info.
@ OB_MESH
static bool is_disabled
static void init_data(ModifierData *md)
static void deform_verts(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
static void panel_register(ARegionType *region_type)
ModifierTypeInfo modifierType_Shrinkwrap
static void panel_draw(const bContext *, Panel *panel)
static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
void modifier_panel_end(uiLayout *layout, PointerRNA *ptr)
PanelType * modifier_panel_register(ARegionType *region_type, ModifierType type, PanelDrawFn draw)
PointerRNA * modifier_panel_get_property_pointers(Panel *panel, PointerRNA *r_ob_ptr)
void modifier_vgroup_ui(uiLayout *layout, PointerRNA *ptr, PointerRNA *ob_ptr, const char *vgroup_prop, const char *invert_vgroup_prop, const char *text)
void MOD_get_vgroup(const Object *ob, const Mesh *mesh, const char *name, const MDeformVert **dvert, int *defgrp_index)
Definition MOD_util.cc:159
void uiLayoutSetActive(uiLayout *layout, bool active)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
uiLayout * uiLayoutRowWithHeading(uiLayout *layout, bool align, const char *heading)
#define UI_ITEM_NONE
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
eUI_Item_Flag
@ UI_ITEM_R_TOGGLE
@ UI_ITEM_R_FORCE_BLANK_DECORATE
@ UI_ITEM_R_EXPAND
uint col
bool RNA_boolean_get(PointerRNA *ptr, const char *name)
int RNA_enum_get(PointerRNA *ptr, const char *name)
Definition DNA_ID.h:413
struct uiLayout * layout
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4126