33#include "RNA_prototypes.hh"
47static float mix_weight(
float weight,
float weight2,
char mix_mode)
56 return (weight + weight2);
58 return (weight - weight2);
60 return (weight * weight2);
69 return (weight / weight2);
71 return (weight < weight2 ? weight2 - weight : weight - weight2);
73 return (weight + weight2) / 2.0;
83 return (weight + weight2);
86 return (weight - weight2);
89 return (weight * weight2);
99 return (weight / weight2);
102 return (weight < weight2 ? weight2 - weight : weight - weight2);
105 return (weight + weight2) * 0.5f;
108 return (weight < weight2 ? weight : weight2);
111 return (weight > weight2 ? weight : weight2);
164 walk(user_data, ob, md, &
ptr, prop);
170 bool need_transform_relation =
false;
178 need_transform_relation =
true;
181 need_transform_relation =
true;
185 if (need_transform_relation) {
206 int *tidx, *indices =
nullptr;
223 const bool do_prev = (wmd->
modifier.
mode & eModifierMode_DoWeightPreview) != 0;
227 const int verts_num = mesh->verts_num;
238 if (defgrp_index == -1) {
242 int defgrp_index_other = -1;
245 if (defgrp_index_other == -1) {
259 MDeformVert *dvert = mesh->deform_verts_for_write().data();
275 for (i = 0; i < verts_num; i++) {
278 tdw1[index_num] = dw;
279 tdw2[index_num] = (defgrp_index_other >= 0) ?
282 tidx[index_num++] = i;
288 for (i = 0; i < verts_num; i++) {
294 tdw2[index_num] = dw;
295 tidx[index_num++] = i;
301 for (i = 0; i < verts_num; i++) {
307 tdw1[index_num] = adw;
308 tdw2[index_num] = bdw;
309 tidx[index_num++] = i;
315 for (i = 0; i < verts_num; i++) {
321 tdw1[index_num] = adw;
322 tdw2[index_num] = bdw;
323 tidx[index_num++] = i;
330 for (i = 0; i < verts_num; i++) {
332 tdw2[i] = (defgrp_index_other >= 0) ?
339 if (index_num == 0) {
346 if (index_num != -1) {
347 indices =
static_cast<int *
>(
MEM_malloc_arrayN(index_num,
sizeof(
int), __func__));
348 memcpy(indices, tidx,
sizeof(
int) * index_num);
360 index_num = verts_num;
367 org_w =
static_cast<float *
>(
MEM_malloc_arrayN(index_num,
sizeof(
float), __func__));
368 new_w =
static_cast<float *
>(
MEM_malloc_arrayN(index_num,
sizeof(
float), __func__));
371 for (i = 0; i < index_num; i++) {
373 if (invert_vgroup_a) {
379 if (invert_vgroup_b) {
427 DM_update_weight_mcol(ob, dm, 0, org_w, index_num, indices);
438 mesh->runtime->is_original_bmesh =
false;
491 N_(
"VertexWeightMix"),
492 "WeightVGMixModifierData",
494 &RNA_VertexWeightMixModifier,
498 ICON_MOD_VERTEX_WEIGHT,
CustomData interface, see also DNA_customdata_types.h.
bool CustomData_has_layer(const CustomData *data, eCustomDataType type)
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
void(*)(void *user_data, Object *ob, ModifierData *md, const PointerRNA *ptr, PropertyRNA *texture_prop) TexWalkFunc
@ eModifierTypeFlag_SupportsMapping
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsMesh
void(*)(void *user_data, Object *ob, ID **idpoin, int cb_flag) IDWalkFunc
bool BKE_texture_dependsOnTime(const struct Tex *texture)
BLI_INLINE bool BLI_listbase_is_empty(const struct ListBase *lb)
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
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)
Scene * DEG_get_evaluated_scene(const Depsgraph *graph)
#define CD_MASK_MDEFORMVERT
#define DNA_struct_default_get(struct_name)
@ MOD_WVG_MIX_INVERT_VGROUP_MASK
@ MOD_WVG_MIX_INVERT_VGROUP_B
@ MOD_WVG_MIX_WEIGHTS_NORMALIZE
@ MOD_WVG_MIX_INVERT_VGROUP_A
@ eModifierType_WeightVGMix
struct WeightVGMixModifierData WeightVGMixModifierData
Object is a sort of wrapper for general info.
Read Guarded memory(de)allocation.
PanelType * modifier_subpanel_register(ARegionType *region_type, const char *name, const char *label, PanelDrawFn draw_header, PanelDrawFn draw, PanelType *parent)
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_depsgraph_update_object_bone_relation(DepsNodeHandle *node, Object *object, const char *bonename, const char *description)
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)
#define MOD_WVG_ZEROFLOOR
static void influence_panel_draw(const bContext *C, Panel *panel)
static void init_data(ModifierData *md)
static void panel_register(ARegionType *region_type)
static Mesh * modify_mesh(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh)
static float mix_weight(float weight, float weight2, char mix_mode)
static bool depends_on_time(Scene *, ModifierData *md)
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)
ModifierTypeInfo modifierType_WeightVGMix
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
void uiItemS(uiLayout *layout)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
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(ID *id, StructRNA *type, void *data)
char mask_tex_map_bone[64]
struct Tex * mask_texture
char mask_tex_uvlayer_name[68]
char mask_defgrp_name[64]
struct Object * mask_tex_map_obj