37#include "RNA_prototypes.hh"
72 return (mmd->target_vgname[0] ==
'\0' || mmd->object ==
nullptr);
88 if (mmd->object !=
nullptr) {
114 const float dist_min,
115 const float dist_max)
120 if (dist > dist_max) {
123 if (dist <= dist_max && dist > dist_min) {
124 return 1.0f - ((dist_max - dist) /
math::max((dist_max - dist_min), 0.0001f));
133 bDeformGroup *defgroup = MEM_cnew<bDeformGroup>(__func__);
158 if (curves.points_num() == 0) {
163 &ob, curves, mmd.influence, memory);
178 curves, mmd.influence);
181 const float4x4 &obmat = ob.object_to_world();
182 const float3 target_pos = mmd.object->object_to_world().location();
187 for (const int point_i : range) {
188 const float weight = vgroup_weights[point_i];
193 float dist_fac = get_distance_factor(
194 target_pos, obmat, positions[point_i], mmd.dist_start, mmd.dist_end);
197 dist_fac = 1.0f - dist_fac;
200 dst_weights.span[point_i] = do_multiply ? dst_weights.span[point_i] * dist_fac : dist_fac;
202 dst_weights.span[point_i] = math::clamp(
203 dst_weights.span[point_i],
207 math::max(mmd.min_weight, 1e-5f),
212 dst_weights.finish();
232 const int current_frame = grease_pencil.
runtime->eval_frame;
235 const IndexMask layer_mask = modifier::greasepencil::get_filtered_layer_mask(
236 grease_pencil, mmd->
influence, mask_memory);
238 modifier::greasepencil::get_drawings_for_write(grease_pencil, layer_mask, current_frame);
255 uiItemPointerR(row,
ptr,
"target_vertex_group", &ob_ptr,
"vertex_groups",
nullptr, ICON_NONE);
272 C, layout,
ptr,
"open_influence_panel",
IFACE_(
"Influence")))
274 modifier::greasepencil::draw_layer_filter_settings(C, influence_panel,
ptr);
275 modifier::greasepencil::draw_material_filter_settings(C, influence_panel,
ptr);
276 modifier::greasepencil::draw_vertex_group_settings(C, influence_panel,
ptr);
290 "GreasePencilWeightProximityModifier",
291 N_(
"Weight Proximity"),
292 "GreasePencilWeightProximityModifierData",
294 &RNA_GreasePencilWeightProximityModifier,
299 ICON_MOD_VERTEX_WEIGHT,
Low-level operations for curves.
Low-level operations for grease pencil.
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_SupportsMapping
@ eModifierTypeFlag_AcceptsGreasePencil
@ eModifierTypeFlag_EnableInEditmode
@ eModifierTypeFlag_SupportsEditmode
void(*)(void *user_data, Object *ob, ID **idpoin, int cb_flag) IDWalkFunc
void BLI_addtail(struct ListBase *listbase, void *vlink) ATTR_NONNULL(1)
int BLI_listbase_count(const struct ListBase *listbase) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1)
#define STRNCPY(dst, src)
#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)
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)
#define DNA_struct_default_get(struct_name)
@ eModifierType_GreasePencilWeightProximity
@ MOD_GREASE_PENCIL_WEIGHT_PROXIMITY_INVERT_OUTPUT
@ MOD_GREASE_PENCIL_WEIGHT_PROXIMITY_MULTIPLY_DATA
struct GreasePencilWeightProximityModifierData GreasePencilWeightProximityModifierData
static void panel_register(ARegionType *region_type)
static void panel_draw(const bContext *, Panel *panel)
ModifierTypeInfo modifierType_GreasePencilWeightProximity
static void modify_geometry_set(ModifierData *md, const ModifierEvalContext *ctx, blender::bke::GeometrySet *geometry_set)
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 uiLayoutSetActive(uiLayout *layout, bool active)
uiLayout * uiLayoutRow(uiLayout *layout, bool align)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
void uiItemPointerR(uiLayout *layout, PointerRNA *ptr, const char *propname, PointerRNA *searchptr, const char *searchpropname, const char *name, int icon)
PanelLayout uiLayoutPanelProp(const bContext *C, uiLayout *layout, PointerRNA *open_prop_owner, const char *open_prop_name)
void uiLayoutSetPropDecorate(uiLayout *layout, bool is_sep)
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
bke::CurvesGeometry & strokes_for_write()
CCL_NAMESPACE_BEGIN ccl_device float invert(float color, float factor)
T distance(const T &a, const T &b)
T max(const T &a, const T &b)
VecBase< T, 3 > transform_point(const CartesianBasis &basis, const VecBase< T, 3 > &v)
void read_influence_data(BlendDataReader *reader, GreasePencilModifierInfluenceData *influence_data)
void init_influence_data(GreasePencilModifierInfluenceData *influence_data, const bool has_custom_curve)
static IndexMask get_filtered_stroke_mask(const Object *ob, const bke::CurvesGeometry &curves, const Material *material_filter, const std::optional< int > material_pass_filter, const bool material_filter_invert, const bool material_pass_filter_invert, IndexMaskMemory &memory)
void write_influence_data(BlendWriter *writer, const GreasePencilModifierInfluenceData *influence_data)
VArray< float > get_influence_vertex_weights(const bke::CurvesGeometry &curves, const GreasePencilModifierInfluenceData &influence_data)
void free_influence_data(GreasePencilModifierInfluenceData *influence_data)
void foreach_influence_ID_link(GreasePencilModifierInfluenceData *influence_data, Object *ob, IDWalkFunc walk, void *user_data)
void copy_influence_data(const GreasePencilModifierInfluenceData *influence_data_src, GreasePencilModifierInfluenceData *influence_data_dst, const int)
void parallel_for(const IndexRange range, const int64_t grain_size, const Function &function, const TaskSizeHints &size_hints=detail::TaskSizeHints_Static(1))
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
static void write_weights_for_drawing(const ModifierData &md, const Object &ob, bke::greasepencil::Drawing &drawing)
static void init_data(ModifierData *md)
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
static float get_distance_factor(float3 target_pos, const float4x4 &obmat, float3 pos, const float dist_min, const float dist_max)
static void modify_geometry_set(ModifierData *md, const ModifierEvalContext *ctx, bke::GeometrySet *geometry_set)
static void free_data(ModifierData *md)
static void panel_register(ARegionType *region_type)
static int ensure_vertex_group(const StringRefNull name, ListBase &vertex_group_names)
static bool target_vertex_group_available(const StringRefNull name, const ListBase &vertex_group_names)
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
static bool is_disabled(const Scene *, ModifierData *md, bool)
static void blend_read(BlendDataReader *reader, ModifierData *md)
int RNA_string_length(PointerRNA *ptr, const char *name)
GreasePencilModifierInfluenceData influence
ListBase vertex_group_names
GreasePencilRuntimeHandle * runtime
bool has_grease_pencil() const
GreasePencil * get_grease_pencil_for_write()
MutableVArraySpan< T > span