46#include "RNA_prototypes.hh"
69#define OUT_OF_MEMORY() (void)printf("WeightVGProximity: Out of memory.\n")
132 data->treeData[
i]->nearest_callback,
136 if (nearest.
index != -1) {
165 treeData_v = target->bvh_verts();
166 if (treeData_v.
tree ==
nullptr) {
173 treeData_e = target->bvh_edges();
174 if (treeData_e.
tree ==
nullptr) {
181 treeData_f = target->bvh_corner_tris();
182 if (treeData_f.
tree ==
nullptr) {
188 data.positions = positions;
190 data.loc2trgt = loc2trgt;
191 data.treeData[0] = &treeData_v;
192 data.treeData[1] = &treeData_e;
193 data.treeData[2] = &treeData_f;
194 data.dist[0] = dist_v;
195 data.dist[1] = dist_e;
196 data.dist[2] = dist_f;
225 dist[
i] =
len_v3v3(v_wco, obr->object_to_world().location());
235 return len_v3v3(ob->object_to_world().location(), obr->object_to_world().location());
247 const bool do_invert_mapping,
250 const float range_inv = 1.0f / (max_d - min_d);
252 if (max_d == min_d) {
254 weights[
i] = (weights[
i] >= max_d) ? 1.0f : 0.0f;
257 else if (max_d > min_d) {
259 if (weights[
i] >= max_d) {
262 else if (weights[
i] <= min_d) {
266 weights[
i] = (weights[
i] - min_d) * range_inv;
272 if (weights[
i] <= max_d) {
275 else if (weights[
i] >= min_d) {
279 weights[
i] = (weights[
i] - min_d) * range_inv;
366 walk(user_data, ob, md, &
ptr, prop);
372 bool need_transform_relation =
false;
383 need_transform_relation =
true;
392 need_transform_relation =
true;
395 need_transform_relation =
true;
399 if (need_transform_relation) {
425 float *org_w =
nullptr;
426 float *new_w =
nullptr;
435 const bool do_prev = (wmd->
modifier.
mode & eModifierMode_DoWeightPreview) != 0;
454 if (obr ==
nullptr) {
460 if (defgrp_index == -1) {
463 const bool has_mdef = !mesh->deform_verts().is_empty();
470 MDeformVert *dvert = mesh->deform_verts_for_write().data();
480 for (
i = 0;
i < verts_num;
i++) {
484 tw[index_num] = _dw->
weight;
485 tdw[index_num++] = _dw;
489 if (index_num == 0) {
495 if (index_num != verts_num) {
497 memcpy(
indices, tidx,
sizeof(
int) * index_num);
499 memcpy(org_w, tw,
sizeof(
float) * index_num);
517 for (
i = 0;
i < index_num;
i++) {
526 if (use_trgt_verts || use_trgt_edges || use_trgt_faces) {
530 if (target_mesh !=
nullptr) {
546 index_num, positions,
indices, dists_v, dists_e, dists_f, target_mesh, &loc2trgt);
547 for (
i = 0;
i < index_num;
i++) {
548 new_w[
i] = dists_v ? dists_v[
i] :
FLT_MAX;
603 dvert, defgrp_index, dw, index_num,
indices, org_w,
false, 0.0f,
false, 0.0f, do_normalize);
608 DM_update_weight_mcol(ob, dm, 0, org_w, index_num,
indices);
622 mesh->
runtime->is_original_bmesh =
false;
639 ptr,
"vertex_group", &ob_ptr,
"vertex_groups", std::nullopt, ICON_GROUP_VERTEX);
667 row = &layout->
row(
true);
669 sub = &row->
row(
true);
720 "VertexWeightProximity",
721 N_(
"VertexWeightProximity"),
722 "WeightVGProximityModifierData",
724 &RNA_VertexWeightProximityModifier,
728 ICON_MOD_VERTEX_WEIGHT,
CustomData interface, see also DNA_customdata_types.h.
void BKE_mesh_wrapper_ensure_mdata(Mesh *mesh)
void(*)(void *user_data, Object *ob, ID **idpoin, LibraryForeachIDCallbackFlag cb_flag) IDWalkFunc
Mesh * BKE_modifier_get_evaluated_mesh_from_evaluated_object(Object *ob_eval)
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_SupportsMapping
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsMesh
void(*)(void *user_data, Object *ob, ModifierData *md, const PointerRNA *ptr, PropertyRNA *texture_prop) TexWalkFunc
bool BKE_texture_dependsOnTime(const struct Tex *texture)
#define BLI_ghashutil_strhash(key)
int BLI_bvhtree_find_nearest(const BVHTree *tree, const float co[3], BVHTreeNearest *nearest, BVHTree_NearestPointCallback callback, void *userdata)
BLI_INLINE bool BLI_listbase_is_empty(const ListBase *lb)
MINLINE float min_ff(float a, float b)
void BLI_space_transform_apply(const struct SpaceTransform *data, float co[3])
void mul_v3_m4v3(float r[3], const float mat[4][4], const float vec[3])
#define BLI_SPACE_TRANSFORM_SETUP(data, local, target)
MINLINE float len_v3v3(const float a[3], const float b[3]) ATTR_WARN_UNUSED_RESULT
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])
void BLI_rng_free(struct RNG *rng) ATTR_NONNULL(1)
struct RNG * BLI_rng_new_srandom(unsigned int seed)
void BLI_task_parallel_range(int start, int stop, void *userdata, TaskParallelRangeFunc func, const TaskParallelSettings *settings)
BLI_INLINE void BLI_parallel_range_settings_defaults(TaskParallelSettings *settings)
Platform independent time functions.
Utility defines for timing/benchmarks.
#define TIMEIT_START(var)
#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)
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)
void DEG_add_object_relation(DepsNodeHandle *node_handle, Object *object, eDepsObjectComponentType component, const char *description)
Scene * DEG_get_evaluated_scene(const Depsgraph *graph)
#define CD_MASK_MDEFORMVERT
#define DNA_struct_default_get(struct_name)
@ MOD_WVG_PROXIMITY_WEIGHTS_NORMALIZE
@ MOD_WVG_PROXIMITY_INVERT_VGROUP_MASK
@ MOD_WVG_PROXIMITY_GEOM_VERTS
@ MOD_WVG_PROXIMITY_INVERT_FALLOFF
@ MOD_WVG_PROXIMITY_GEOM_EDGES
@ MOD_WVG_PROXIMITY_GEOM_FACES
@ eModifierType_WeightVGProximity
@ MOD_WVG_PROXIMITY_OBJECT
@ MOD_WVG_PROXIMITY_GEOMETRY
Object is a sort of wrapper for general info.
Read Guarded memory(de)allocation.
static void init_data(ModifierData *md)
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 Mesh * modify_mesh(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh)
static void free_data(ModifierData *md)
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
static bool depends_on_time(Scene *, ModifierData *)
static void foreach_tex_link(ModifierData *md, Object *ob, TexWalkFunc walk, void *user_data)
static void falloff_panel_draw(const bContext *, Panel *panel)
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_depsgraph_update_object_bone_relation(DepsNodeHandle *node, Object *object, const char *bonename, const char *description)
void weightvg_do_map(int num, float *new_w, short falloff_type, const bool do_invert, CurveMapping *cmap, RNG *rng)
void weightvg_update_vg(MDeformVert *dvert, int defgrp_idx, MDeformWeight **dws, int num, const int *indices, const float *weights, const bool do_add, const float add_thresh, const bool do_rem, const float rem_thresh, const bool do_normalize)
void weightvg_ui_common(const bContext *C, PointerRNA *ob_ptr, PointerRNA *ptr, uiLayout *layout)
void weightvg_do_mask(const ModifierEvalContext *ctx, const int num, const int *indices, float *org_w, const float *new_w, Object *ob, Mesh *mesh, const float fact, const char defgrp_name[MAX_VGROUP_NAME], Scene *, Tex *texture, const int tex_use_channel, const int tex_mapping, Object *tex_map_object, const char *text_map_bone, const char *tex_uvlayer_name, const bool invert_vgroup_mask)
static void influence_panel_draw(const bContext *C, Panel *panel)
static void influence_panel_draw(const bContext *C, Panel *panel)
static void init_data(ModifierData *md)
static void falloff_panel_draw(const bContext *, Panel *panel)
static void vert2geom_task_cb_ex(void *__restrict userdata, const int iter, const TaskParallelTLS *__restrict tls)
static void panel_register(ARegionType *region_type)
ModifierTypeInfo modifierType_WeightVGProximity
static Mesh * modify_mesh(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh)
static void free_data(ModifierData *md)
static void blend_read(BlendDataReader *reader, ModifierData *md)
static bool depends_on_time(Scene *, ModifierData *md)
static float get_ob2ob_distance(const Object *ob, const Object *obr)
static void panel_draw(const bContext *, Panel *panel)
static void foreach_tex_link(ModifierData *md, Object *ob, TexWalkFunc walk, void *user_data)
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 blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
static void get_vert2geom_distance(int verts_num, const blender::Span< blender::float3 > positions, const int *indices, float *dist_v, float *dist_e, float *dist_f, Mesh *target, const SpaceTransform *loc2trgt)
static void get_vert2ob_distance(int verts_num, const blender::Span< blender::float3 > positions, const int *indices, float *dist, Object *ob, Object *obr)
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
static void do_map(Object *ob, float *weights, const int nidx, const float min_d, const float max_d, short mode, const bool do_invert_mapping, CurveMapping *cmap)
void uiTemplateCurveMapping(uiLayout *layout, PointerRNA *ptr, blender::StringRefNull propname, int type, bool levels, bool brush, bool neg_slope, bool tone, bool presets)
BMesh const char void * data
static void update_depsgraph(tGraphSliderOp *gso)
void * MEM_malloc_arrayN(size_t len, size_t size, const char *str)
void MEM_freeN(void *vmemh)
PropertyRNA * RNA_struct_find_property(PointerRNA *ptr, const char *identifier)
PointerRNA RNA_pointer_create_discrete(ID *id, StructRNA *type, void *data)
int RNA_enum_get(PointerRNA *ptr, const char *name)
MeshRuntimeHandle * runtime
ListBase vertex_group_names
size_t userdata_chunk_size
blender::bke::BVHTreeFromMesh * treeData[3]
const SpaceTransform * loc2trgt
blender::Span< blender::float3 > positions
char mask_defgrp_name[64]
char mask_tex_uvlayer_name[68]
struct Object * mask_tex_map_obj
struct Object * proximity_ob_target
struct Tex * mask_texture
char mask_tex_map_bone[64]
struct CurveMapping * cmap_curve
uiLayout & column(bool align)
void prop_search(PointerRNA *ptr, PropertyRNA *prop, PointerRNA *searchptr, PropertyRNA *searchprop, PropertyRNA *item_searchpropname, std::optional< blender::StringRefNull > name, int icon, bool results_are_suggestions)
void separator(float factor=1.0f, LayoutSeparatorType type=LayoutSeparatorType::Auto)
uiLayout & row(bool align)
void use_property_split_set(bool value)
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)