Blender V4.5
MOD_warp.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2023 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
8
9#include <cstring>
10
11#include "MEM_guardedalloc.h"
12
13#include "BLI_math_matrix.h"
14#include "BLI_math_vector.h"
15#include "BLI_utildefines.h"
16
17#include "BLT_translation.hh"
18
19#include "DNA_defaults.h"
20#include "DNA_meshdata_types.h"
21#include "DNA_object_types.h"
22#include "DNA_screen_types.h"
23#include "DNA_texture_types.h"
24
25#include "BKE_action.hh" /* BKE_pose_channel_find_name */
26#include "BKE_colortools.hh"
27#include "BKE_deform.hh"
28#include "BKE_lib_query.hh"
29#include "BKE_modifier.hh"
30#include "BKE_texture.h"
31
32#include "UI_interface.hh"
33#include "UI_resources.hh"
34
35#include "BLO_read_write.hh"
36
37#include "RNA_access.hh"
38#include "RNA_prototypes.hh"
39
40#include "RE_texture.h"
41
42#include "MOD_ui_common.hh"
43#include "MOD_util.hh"
44
45static void init_data(ModifierData *md)
46{
48
50
52
53 wmd->curfalloff = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
54}
55
56static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
57{
58 const WarpModifierData *wmd = (const WarpModifierData *)md;
59 WarpModifierData *twmd = (WarpModifierData *)target;
60
62
64}
65
66static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
67{
69
70 /* Ask for vertex-groups if we need them. */
71 if (wmd->defgrp_name[0] != '\0') {
72 r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
73 }
74
75 /* ask for UV coordinates if we need them */
76 if (wmd->texmapping == MOD_DISP_MAP_UV) {
77 r_cddata_masks->fmask |= CD_MASK_MTFACE;
78 }
79}
80
81static void matrix_from_obj_pchan(float mat[4][4],
82 const float obinv[4][4],
83 Object *ob,
84 const char *bonename)
85{
86 bPoseChannel *pchan = BKE_pose_channel_find_name(ob->pose, bonename);
87 if (pchan) {
88 float mat_bone_world[4][4];
89 mul_m4_m4m4(mat_bone_world, ob->object_to_world().ptr(), pchan->pose_mat);
90 mul_m4_m4m4(mat, obinv, mat_bone_world);
91 }
92 else {
93 mul_m4_m4m4(mat, obinv, ob->object_to_world().ptr());
94 }
95}
96
97static bool depends_on_time(Scene * /*scene*/, ModifierData *md)
98{
100
101 if (wmd->texture) {
103 }
104
105 return false;
106}
107
108static void free_data(ModifierData *md)
109{
112}
113
114static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
115{
117
118 return !(wmd->object_from && wmd->object_to);
119}
120
121static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
122{
124
125 walk(user_data, ob, (ID **)&wmd->texture, IDWALK_CB_USER);
126 walk(user_data, ob, (ID **)&wmd->object_from, IDWALK_CB_NOP);
127 walk(user_data, ob, (ID **)&wmd->object_to, IDWALK_CB_NOP);
128 walk(user_data, ob, (ID **)&wmd->map_object, IDWALK_CB_NOP);
129}
130
131static void foreach_tex_link(ModifierData *md, Object *ob, TexWalkFunc walk, void *user_data)
132{
133 PointerRNA ptr = RNA_pointer_create_discrete(&ob->id, &RNA_Modifier, md);
134 PropertyRNA *prop = RNA_struct_find_property(&ptr, "texture");
135 walk(user_data, ob, md, &ptr, prop);
136}
137
139{
141 bool need_transform_relation = false;
142
143 if (wmd->object_from != nullptr && wmd->object_to != nullptr) {
145 ctx->node, wmd->object_from, wmd->bone_from, "Warp Modifier");
147 ctx->node, wmd->object_to, wmd->bone_to, "Warp Modifier");
148 need_transform_relation = true;
149 }
150
151 if (wmd->texture != nullptr) {
152 DEG_add_generic_id_relation(ctx->node, &wmd->texture->id, "Warp Modifier");
153
154 if ((wmd->texmapping == MOD_DISP_MAP_OBJECT) && wmd->map_object != nullptr) {
156 ctx->node, wmd->map_object, wmd->map_bone, "Warp Modifier");
157 need_transform_relation = true;
158 }
159 else if (wmd->texmapping == MOD_DISP_MAP_GLOBAL) {
160 need_transform_relation = true;
161 }
162 }
163
164 if (need_transform_relation) {
165 DEG_add_depends_on_transform_relation(ctx->node, "Warp Modifier");
166 }
167}
168
170 const ModifierEvalContext *ctx,
171 Mesh *mesh,
172 float (*vertexCos)[3],
173 int verts_num)
174{
175 Object *ob = ctx->object;
176 float obinv[4][4];
177 float mat_from[4][4];
178 float mat_from_inv[4][4];
179 float mat_to[4][4];
180 float mat_unit[4][4];
181 float mat_final[4][4];
182
183 float tmat[4][4];
184
185 const float falloff_radius_sq = square_f(wmd->falloff_radius);
186 float strength = wmd->strength;
187 float fac = 1.0f, weight;
188 int i;
189 int defgrp_index;
190 const MDeformVert *dvert, *dv = nullptr;
191 const bool invert_vgroup = (wmd->flag & MOD_WARP_INVERT_VGROUP) != 0;
192 float(*tex_co)[3] = nullptr;
193
194 if (!(wmd->object_from && wmd->object_to)) {
195 return;
196 }
197
198 MOD_get_vgroup(ob, mesh, wmd->defgrp_name, &dvert, &defgrp_index);
199 if (dvert == nullptr) {
200 defgrp_index = -1;
201 }
202
203 if (wmd->curfalloff == nullptr) { /* should never happen, but bad lib linking could cause it */
204 wmd->curfalloff = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
205 }
206
207 if (wmd->curfalloff) {
209 }
210
211 invert_m4_m4(obinv, ob->object_to_world().ptr());
212
213 /* Checks that the objects/bones are available. */
214 matrix_from_obj_pchan(mat_from, obinv, wmd->object_from, wmd->bone_from);
215 matrix_from_obj_pchan(mat_to, obinv, wmd->object_to, wmd->bone_to);
216
217 invert_m4_m4(tmat, mat_from); // swap?
218 mul_m4_m4m4(mat_final, tmat, mat_to);
219
220 invert_m4_m4(mat_from_inv, mat_from);
221
222 unit_m4(mat_unit);
223
224 if (strength < 0.0f) {
225 float loc[3];
226 strength = -strength;
227
228 /* inverted location is not useful, just use the negative */
229 copy_v3_v3(loc, mat_final[3]);
230 invert_m4(mat_final);
231 negate_v3_v3(mat_final[3], loc);
232 }
233 weight = strength;
234
235 Tex *tex_target = wmd->texture;
236 if (mesh != nullptr && tex_target != nullptr) {
237 tex_co = MEM_malloc_arrayN<float[3]>(size_t(verts_num), __func__);
238 MOD_get_texture_coords((MappingInfoModifierData *)wmd, ctx, ob, mesh, vertexCos, tex_co);
239
241 }
242
243 for (i = 0; i < verts_num; i++) {
244 float *co = vertexCos[i];
245
246 if (wmd->falloff_type == eWarp_Falloff_None ||
247 ((fac = len_squared_v3v3(co, mat_from[3])) < falloff_radius_sq &&
248 (fac = (wmd->falloff_radius - sqrtf(fac)) / wmd->falloff_radius)))
249 {
250 /* skip if no vert group found */
251 if (defgrp_index != -1) {
252 dv = &dvert[i];
253 weight = (invert_vgroup ? (1.0f - BKE_defvert_find_weight(dv, defgrp_index)) :
254 BKE_defvert_find_weight(dv, defgrp_index)) *
255 strength;
256 if (weight <= 0.0f) {
257 continue;
258 }
259 }
260
261 /* closely match PROP_SMOOTH and similar */
262 switch (wmd->falloff_type) {
264 fac = 1.0f;
265 break;
267 fac = BKE_curvemapping_evaluateF(wmd->curfalloff, 0, fac);
268 break;
270 fac = fac * fac;
271 break;
273 fac = 3.0f * fac * fac - 2.0f * fac * fac * fac;
274 break;
276 fac = sqrtf(fac);
277 break;
279 /* pass */
280 break;
282 fac = 1.0f;
283 break;
285 fac = sqrtf(2 * fac - fac * fac);
286 break;
288 fac = fac * (2.0f - fac);
289 break;
290 }
291
292 fac *= weight;
293
294 if (tex_co) {
295 TexResult texres;
296 BKE_texture_get_value(tex_target, tex_co[i], &texres, false);
297 fac *= texres.tin;
298 }
299
300 if (fac != 0.0f) {
301 /* into the 'from' objects space */
302 mul_m4_v3(mat_from_inv, co);
303
304 if (fac == 1.0f) {
305 mul_m4_v3(mat_final, co);
306 }
307 else {
308 if (wmd->flag & MOD_WARP_VOLUME_PRESERVE) {
309 /* interpolate the matrix for nicer locations */
310 blend_m4_m4m4(tmat, mat_unit, mat_final, fac);
311 mul_m4_v3(tmat, co);
312 }
313 else {
314 float tvec[3];
315 mul_v3_m4v3(tvec, mat_final, co);
316 interp_v3_v3v3(co, co, tvec, fac);
317 }
318 }
319
320 /* out of the 'from' objects space */
321 mul_m4_v3(mat_from, co);
322 }
323 }
324 }
325
326 if (tex_co) {
327 MEM_freeN(tex_co);
328 }
329}
330
332 const ModifierEvalContext *ctx,
333 Mesh *mesh,
335{
338 wmd, ctx, mesh, reinterpret_cast<float(*)[3]>(positions.data()), positions.size());
339}
340
341static void panel_draw(const bContext * /*C*/, Panel *panel)
342{
343 uiLayout *col;
344 uiLayout *layout = panel->layout;
345
346 PointerRNA ob_ptr;
348
349 uiLayoutSetPropSep(layout, true);
350
351 col = &layout->column(true);
352 col->prop(ptr, "object_from", UI_ITEM_NONE, std::nullopt, ICON_NONE);
353 PointerRNA from_obj_ptr = RNA_pointer_get(ptr, "object_from");
354 if (!RNA_pointer_is_null(&from_obj_ptr) && RNA_enum_get(&from_obj_ptr, "type") == OB_ARMATURE) {
355
356 PointerRNA from_obj_data_ptr = RNA_pointer_get(&from_obj_ptr, "data");
358 col, ptr, "bone_from", &from_obj_data_ptr, "bones", IFACE_("Bone"), ICON_BONE_DATA);
359 }
360
361 col = &layout->column(true);
362 col->prop(ptr, "object_to", UI_ITEM_NONE, std::nullopt, ICON_NONE);
363 PointerRNA to_obj_ptr = RNA_pointer_get(ptr, "object_to");
364 if (!RNA_pointer_is_null(&to_obj_ptr) && RNA_enum_get(&to_obj_ptr, "type") == OB_ARMATURE) {
365 PointerRNA to_obj_data_ptr = RNA_pointer_get(&to_obj_ptr, "data");
366 uiItemPointerR(col, ptr, "bone_to", &to_obj_data_ptr, "bones", IFACE_("Bone"), ICON_BONE_DATA);
367 }
368
369 layout->prop(ptr, "use_volume_preserve", UI_ITEM_NONE, std::nullopt, ICON_NONE);
370
371 layout->prop(ptr, "strength", UI_ITEM_NONE, std::nullopt, ICON_NONE);
372
373 modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", std::nullopt);
374
376}
377
378static void falloff_panel_draw(const bContext * /*C*/, Panel *panel)
379{
380 uiLayout *layout = panel->layout;
381
383
384 bool use_falloff = (RNA_enum_get(ptr, "falloff_type") != eWarp_Falloff_None);
385
386 uiLayoutSetPropSep(layout, true);
387
388 layout->prop(ptr, "falloff_type", UI_ITEM_NONE, std::nullopt, ICON_NONE);
389
390 if (use_falloff) {
391 layout->prop(ptr, "falloff_radius", UI_ITEM_NONE, std::nullopt, ICON_NONE);
392 }
393
394 if (use_falloff && RNA_enum_get(ptr, "falloff_type") == eWarp_Falloff_Curve) {
395 uiTemplateCurveMapping(layout, ptr, "falloff_curve", 0, false, false, false, false);
396 }
397}
398
399static void texture_panel_draw(const bContext *C, Panel *panel)
400{
401 uiLayout *col;
402 uiLayout *layout = panel->layout;
403
404 PointerRNA ob_ptr;
406
407 int texture_coords = RNA_enum_get(ptr, "texture_coords");
408
409 uiTemplateID(layout, C, ptr, "texture", "texture.new", nullptr, nullptr);
410
411 uiLayoutSetPropSep(layout, true);
412
413 col = &layout->column(false);
414 col->prop(ptr, "texture_coords", UI_ITEM_NONE, IFACE_("Coordinates"), ICON_NONE);
415 if (texture_coords == MOD_DISP_MAP_OBJECT) {
416 col->prop(ptr, "texture_coords_object", UI_ITEM_NONE, IFACE_("Object"), ICON_NONE);
417 PointerRNA texture_coords_obj_ptr = RNA_pointer_get(ptr, "texture_coords_object");
418 if (!RNA_pointer_is_null(&texture_coords_obj_ptr) &&
419 (RNA_enum_get(&texture_coords_obj_ptr, "type") == OB_ARMATURE))
420 {
421 PointerRNA texture_coords_obj_data_ptr = RNA_pointer_get(&texture_coords_obj_ptr, "data");
423 ptr,
424 "texture_coords_bone",
425 &texture_coords_obj_data_ptr,
426 "bones",
427 IFACE_("Bone"),
428 ICON_NONE);
429 }
430 }
431 else if (texture_coords == MOD_DISP_MAP_UV && RNA_enum_get(&ob_ptr, "type") == OB_MESH) {
432 PointerRNA obj_data_ptr = RNA_pointer_get(&ob_ptr, "data");
433 uiItemPointerR(col, ptr, "uv_layer", &obj_data_ptr, "uv_layers", std::nullopt, ICON_GROUP_UVS);
434 }
435}
436
437static void panel_register(ARegionType *region_type)
438{
441 region_type, "falloff", "Falloff", nullptr, falloff_panel_draw, panel_type);
443 region_type, "texture", "Texture", nullptr, texture_panel_draw, panel_type);
444}
445
446static void blend_write(BlendWriter *writer, const ID * /*id_owner*/, const ModifierData *md)
447{
448 const WarpModifierData *wmd = (const WarpModifierData *)md;
449
451
452 if (wmd->curfalloff) {
454 }
455}
456
457static void blend_read(BlendDataReader *reader, ModifierData *md)
458{
460
462 if (wmd->curfalloff) {
464 }
465}
466
468 /*idname*/ "Warp",
469 /*name*/ N_("Warp"),
470 /*struct_name*/ "WarpModifierData",
471 /*struct_size*/ sizeof(WarpModifierData),
472 /*srna*/ &RNA_WarpModifier,
476 /*icon*/ ICON_MOD_WARP,
477 /*copy_data*/ copy_data,
478
479 /*deform_verts*/ deform_verts,
480 /*deform_matrices*/ nullptr,
481 /*deform_verts_EM*/ nullptr,
482 /*deform_matrices_EM*/ nullptr,
483 /*modify_mesh*/ nullptr,
484 /*modify_geometry_set*/ nullptr,
485
486 /*init_data*/ init_data,
487 /*required_data_mask*/ required_data_mask,
488 /*free_data*/ free_data,
489 /*is_disabled*/ is_disabled,
490 /*update_depsgraph*/ update_depsgraph,
491 /*depends_on_time*/ depends_on_time,
492 /*depends_on_normals*/ nullptr,
493 /*foreach_ID_link*/ foreach_ID_link,
494 /*foreach_tex_link*/ foreach_tex_link,
495 /*free_runtime_data*/ nullptr,
496 /*panel_register*/ panel_register,
497 /*blend_write*/ blend_write,
498 /*blend_read*/ blend_read,
499 /*foreach_cache*/ nullptr,
500};
Blender kernel action and pose functionality.
bPoseChannel * BKE_pose_channel_find_name(const bPose *pose, const char *name)
float BKE_curvemapping_evaluateF(const CurveMapping *cumap, int cur, float value)
void BKE_curvemapping_blend_read(BlendDataReader *reader, CurveMapping *cumap)
CurveMapping * BKE_curvemapping_copy(const CurveMapping *cumap)
void BKE_curvemapping_init(CurveMapping *cumap)
CurveMapping * BKE_curvemapping_add(int tot, float minx, float miny, float maxx, float maxy)
Definition colortools.cc:89
void BKE_curvemapping_free(CurveMapping *cumap)
void BKE_curvemapping_blend_write(BlendWriter *writer, const CurveMapping *cumap)
support for deformation groups and hooks.
float BKE_defvert_find_weight(const MDeformVert *dvert, int defgroup)
Definition deform.cc:763
@ IDWALK_CB_USER
@ IDWALK_CB_NOP
void(*)(void *user_data, Object *ob, ID **idpoin, LibraryForeachIDCallbackFlag cb_flag) IDWalkFunc
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_AcceptsCVs
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsVertexCosOnly
void(*)(void *user_data, Object *ob, ModifierData *md, const PointerRNA *ptr, PropertyRNA *texture_prop) TexWalkFunc
void BKE_texture_get_value(struct Tex *texture, const float *tex_co, struct TexResult *texres, bool use_color_management)
Definition texture.cc:712
bool BKE_texture_dependsOnTime(const struct Tex *texture)
#define BLI_assert(a)
Definition BLI_assert.h:46
MINLINE float square_f(float a)
void mul_m4_m4m4(float R[4][4], const float A[4][4], const float B[4][4])
void blend_m4_m4m4(float out[4][4], const float dst[4][4], const float src[4][4], float srcweight)
void mul_m4_v3(const float M[4][4], float r[3])
void mul_v3_m4v3(float r[3], const float mat[4][4], const float vec[3])
bool invert_m4_m4(float inverse[4][4], const float mat[4][4])
bool invert_m4(float mat[4][4])
void unit_m4(float m[4][4])
MINLINE float len_squared_v3v3(const float a[3], const float b[3]) ATTR_WARN_UNUSED_RESULT
MINLINE void copy_v3_v3(float r[3], const float a[3])
MINLINE void negate_v3_v3(float r[3], const float a[3])
void interp_v3_v3v3(float r[3], const float a[3], const float b[3], float t)
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
#define BLO_write_struct(writer, struct_name, data_ptr)
#define BLO_read_struct(reader, struct_name, ptr_p)
#define IFACE_(msgid)
void DEG_add_generic_id_relation(DepsNodeHandle *node_handle, ID *id, const char *description)
void DEG_add_depends_on_transform_relation(DepsNodeHandle *node_handle, const char *description)
#define DNA_struct_default_get(struct_name)
@ eWarp_Falloff_Linear
@ eWarp_Falloff_Curve
@ eWarp_Falloff_Sharp
@ eWarp_Falloff_Const
@ eWarp_Falloff_InvSquare
@ eWarp_Falloff_Smooth
@ eWarp_Falloff_None
@ eWarp_Falloff_Sphere
@ eWarp_Falloff_Root
@ eModifierType_Warp
@ MOD_DISP_MAP_OBJECT
@ MOD_DISP_MAP_GLOBAL
@ MOD_DISP_MAP_UV
@ MOD_WARP_VOLUME_PRESERVE
@ MOD_WARP_INVERT_VGROUP
Object is a sort of wrapper for general info.
@ OB_ARMATURE
@ OB_MESH
static bool is_disabled
Read Guarded memory(de)allocation.
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)
static void required_data_mask(ModifierData *, CustomData_MeshMasks *r_cddata_masks)
static void blend_read(BlendDataReader *, ModifierData *md)
static void panel_draw(const bContext *, Panel *panel)
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
static void free_data(ModifierData *md)
Definition MOD_bevel.cc:271
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
Definition MOD_bevel.cc:433
static bool depends_on_time(Scene *, ModifierData *)
Definition MOD_build.cc:47
static void foreach_tex_link(ModifierData *md, Object *ob, TexWalkFunc walk, void *user_data)
static void falloff_panel_draw(const bContext *, Panel *panel)
Definition MOD_hook.cc:484
void modifier_vgroup_ui(uiLayout *layout, PointerRNA *ptr, PointerRNA *ob_ptr, const StringRefNull vgroup_prop, const std::optional< StringRefNull > invert_vgroup_prop, const std::optional< StringRefNull > text)
PanelType * modifier_subpanel_register(ARegionType *region_type, const char *name, const char *label, PanelDrawFn draw_header, PanelDrawFn draw, PanelType *parent)
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_error_message_draw(uiLayout *layout, PointerRNA *ptr)
void MOD_init_texture(MappingInfoModifierData *dmd, const ModifierEvalContext *ctx)
Definition MOD_util.cc:36
void MOD_depsgraph_update_object_bone_relation(DepsNodeHandle *node, Object *object, const char *bonename, const char *description)
Definition MOD_util.cc:186
void MOD_get_vgroup(const Object *ob, const Mesh *mesh, const char *name, const MDeformVert **dvert, int *defgrp_index)
Definition MOD_util.cc:156
void MOD_get_texture_coords(MappingInfoModifierData *dmd, const ModifierEvalContext *, Object *ob, Mesh *mesh, float(*cos)[3], float(*r_texco)[3])
Definition MOD_util.cc:49
static void init_data(ModifierData *md)
Definition MOD_warp.cc:45
static void deform_verts(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
Definition MOD_warp.cc:331
static void falloff_panel_draw(const bContext *, Panel *panel)
Definition MOD_warp.cc:378
static void warpModifier_do(WarpModifierData *wmd, const ModifierEvalContext *ctx, Mesh *mesh, float(*vertexCos)[3], int verts_num)
Definition MOD_warp.cc:169
static void panel_register(ARegionType *region_type)
Definition MOD_warp.cc:437
ModifierTypeInfo modifierType_Warp
Definition MOD_warp.cc:467
static void texture_panel_draw(const bContext *C, Panel *panel)
Definition MOD_warp.cc:399
static void free_data(ModifierData *md)
Definition MOD_warp.cc:108
static void blend_read(BlendDataReader *reader, ModifierData *md)
Definition MOD_warp.cc:457
static bool depends_on_time(Scene *, ModifierData *md)
Definition MOD_warp.cc:97
static void matrix_from_obj_pchan(float mat[4][4], const float obinv[4][4], Object *ob, const char *bonename)
Definition MOD_warp.cc:81
static void panel_draw(const bContext *, Panel *panel)
Definition MOD_warp.cc:341
static void foreach_tex_link(ModifierData *md, Object *ob, TexWalkFunc walk, void *user_data)
Definition MOD_warp.cc:131
static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
Definition MOD_warp.cc:66
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
Definition MOD_warp.cc:121
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
Definition MOD_warp.cc:446
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
Definition MOD_warp.cc:138
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
Definition MOD_warp.cc:56
#define C
Definition RandGen.cpp:29
void uiTemplateID(uiLayout *layout, const bContext *C, PointerRNA *ptr, blender::StringRefNull propname, const char *newop, const char *openop, const char *unlinkop, int filter=UI_TEMPLATE_ID_FILTER_ALL, bool live_icon=false, std::optional< blender::StringRef > text=std::nullopt)
void uiTemplateCurveMapping(uiLayout *layout, PointerRNA *ptr, blender::StringRefNull propname, int type, bool levels, bool brush, bool neg_slope, bool tone)
void uiItemPointerR(uiLayout *layout, PointerRNA *ptr, blender::StringRefNull propname, PointerRNA *searchptr, blender::StringRefNull searchpropname, std::optional< blender::StringRefNull > name, int icon)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
#define UI_ITEM_NONE
constexpr int64_t size() const
Definition BLI_span.hh:493
constexpr T * data() const
Definition BLI_span.hh:539
#define sqrtf(x)
uint col
#define CD_MASK_MDEFORMVERT
#define CD_MASK_MTFACE
static void update_depsgraph(tGraphSliderOp *gso)
void * MEM_malloc_arrayN(size_t len, size_t size, const char *str)
Definition mallocn.cc:133
void MEM_freeN(void *vmemh)
Definition mallocn.cc:113
PointerRNA RNA_pointer_get(PointerRNA *ptr, const char *name)
PropertyRNA * RNA_struct_find_property(PointerRNA *ptr, const char *identifier)
bool RNA_pointer_is_null(const PointerRNA *ptr)
PointerRNA RNA_pointer_create_discrete(ID *id, StructRNA *type, void *data)
int RNA_enum_get(PointerRNA *ptr, const char *name)
Definition DNA_ID.h:404
struct bPose * pose
struct uiLayout * layout
float tin
Definition RE_texture.h:83
struct Object * map_object
struct CurveMapping * curfalloff
struct Object * object_to
struct Object * object_from
float pose_mat[4][4]
uiLayout & column(bool align)
void prop(PointerRNA *ptr, PropertyRNA *prop, int index, int value, eUI_Item_Flag flag, std::optional< blender::StringRef > name_opt, int icon, std::optional< blender::StringRef > placeholder=std::nullopt)
i
Definition text_draw.cc:230
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4227
uint8_t flag
Definition wm_window.cc:139