Blender V4.3
MOD_curve.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_mesh_types.h"
17#include "DNA_object_types.h"
18#include "DNA_screen_types.h"
19
20#include "BKE_curve.hh"
21#include "BKE_deform.hh"
22#include "BKE_lib_query.hh"
23#include "BKE_mesh.hh"
24#include "BKE_modifier.hh"
25
26#include "UI_interface.hh"
27#include "UI_resources.hh"
28
29#include "RNA_prototypes.hh"
30
31#include "DEG_depsgraph.hh"
33
34#include "MOD_ui_common.hh"
35#include "MOD_util.hh"
36
45
46static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
47{
49
50 /* Ask for vertex-groups if we need them. */
51 if (cmd->name[0] != '\0') {
52 r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
53 }
54}
55
56static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
57{
59
60 /* The object type check is only needed here in case we have a placeholder
61 * object assigned (because the library containing the curve is missing).
62 *
63 * In other cases it should be impossible to have a type mismatch.
64 */
65 return !cmd->object || cmd->object->type != OB_CURVES_LEGACY;
66}
67
68static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
69{
71
72 walk(user_data, ob, (ID **)&cmd->object, IDWALK_CB_NOP);
73}
74
76{
78 if (cmd->object != nullptr) {
79 /* TODO(sergey): Need to do the same eval_flags trick for path
80 * as happening in legacy depsgraph callback.
81 */
82 /* TODO(sergey): Currently path is evaluated as a part of modifier stack,
83 * might be changed in the future.
84 */
85 DEG_add_object_relation(ctx->node, cmd->object, DEG_OB_COMP_TRANSFORM, "Curve Modifier");
86 DEG_add_object_relation(ctx->node, cmd->object, DEG_OB_COMP_GEOMETRY, "Curve Modifier");
88 }
89
90 DEG_add_depends_on_transform_relation(ctx->node, "Curve Modifier");
91}
92
93static void deform_verts(ModifierData *md,
94 const ModifierEvalContext *ctx,
95 Mesh *mesh,
97{
99
100 const MDeformVert *dvert = nullptr;
101 int defgrp_index = -1;
102 MOD_get_vgroup(ctx->object, mesh, cmd->name, &dvert, &defgrp_index);
103
104 /* Silly that defaxis and BKE_curve_deform_coords are off by 1
105 * but leave for now to save having to call do_versions */
106 const int defaxis = std::clamp(cmd->defaxis - 1, 0, 5);
108 ctx->object,
109 reinterpret_cast<float(*)[3]>(positions.data()),
110 positions.size(),
111 dvert,
112 defgrp_index,
113 cmd->flag,
114 defaxis);
115}
116
118 const ModifierEvalContext *ctx,
119 const BMEditMesh *em,
120 Mesh *mesh,
122{
123 if (mesh->runtime->wrapper_type == ME_WRAPPER_TYPE_MDATA) {
124 deform_verts(md, ctx, mesh, positions);
125 return;
126 }
127
129 bool use_dverts = false;
130 int defgrp_index = -1;
131
132 if (ctx->object->type == OB_MESH && cmd->name[0] != '\0') {
133 defgrp_index = BKE_object_defgroup_name_index(ctx->object, cmd->name);
134 if (defgrp_index != -1) {
135 use_dverts = true;
136 }
137 }
138
139 const int defaxis = std::clamp(cmd->defaxis - 1, 0, 5);
140 if (use_dverts) {
142 ctx->object,
143 reinterpret_cast<float(*)[3]>(positions.data()),
144 positions.size(),
145 defgrp_index,
146 cmd->flag,
147 defaxis,
148 em);
149 }
150 else {
152 ctx->object,
153 reinterpret_cast<float(*)[3]>(positions.data()),
154 positions.size(),
155 nullptr,
156 defgrp_index,
157 cmd->flag,
158 defaxis);
159 }
160}
161
162static void panel_draw(const bContext * /*C*/, Panel *panel)
163{
164 uiLayout *layout = panel->layout;
165
166 PointerRNA ob_ptr;
168
169 uiLayoutSetPropSep(layout, true);
170
171 uiItemR(layout, ptr, "object", UI_ITEM_NONE, IFACE_("Curve Object"), ICON_NONE);
172 uiItemR(layout, ptr, "deform_axis", UI_ITEM_NONE, nullptr, ICON_NONE);
173
174 modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", nullptr);
175
176 modifier_panel_end(layout, ptr);
177}
178
179static void panel_register(ARegionType *region_type)
180{
182}
183
185 /*idname*/ "Curve",
186 /*name*/ N_("Curve"),
187 /*struct_name*/ "CurveModifierData",
188 /*struct_size*/ sizeof(CurveModifierData),
189 /*srna*/ &RNA_CurveModifier,
193 /*icon*/ ICON_MOD_CURVE,
194
195 /*copy_data*/ BKE_modifier_copydata_generic,
196
197 /*deform_verts*/ deform_verts,
198 /*deform_matrices*/ nullptr,
199 /*deform_verts_EM*/ deform_verts_EM,
200 /*deform_matrices_EM*/ nullptr,
201 /*modify_mesh*/ nullptr,
202 /*modify_geometry_set*/ nullptr,
203
204 /*init_data*/ init_data,
205 /*required_data_mask*/ required_data_mask,
206 /*free_data*/ nullptr,
207 /*is_disabled*/ is_disabled,
208 /*update_depsgraph*/ update_depsgraph,
209 /*depends_on_time*/ nullptr,
210 /*depends_on_normals*/ nullptr,
211 /*foreach_ID_link*/ foreach_ID_link,
212 /*foreach_tex_link*/ nullptr,
213 /*free_runtime_data*/ nullptr,
214 /*panel_register*/ panel_register,
215 /*blend_write*/ nullptr,
216 /*blend_read*/ nullptr,
217 /*foreach_cache*/ nullptr,
218};
void BKE_curve_deform_coords(const Object *ob_curve, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, const MDeformVert *dvert, int defgrp_index, short flag, short defaxis)
void BKE_curve_deform_coords_with_editmesh(const Object *ob_curve, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, int defgrp_index, short flag, short defaxis, const BMEditMesh *em_target)
support for deformation groups and hooks.
int BKE_object_defgroup_name_index(const Object *ob, blender::StringRef name)
Definition deform.cc:585
@ IDWALK_CB_NOP
@ ME_WRAPPER_TYPE_MDATA
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, ID **idpoin, int cb_flag) IDWalkFunc
#define BLI_assert(a)
Definition BLI_assert.h:50
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
#define IFACE_(msgid)
@ DAG_EVAL_NEED_CURVE_PATH
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)
void DEG_add_special_eval_flag(DepsNodeHandle *handle, ID *id, uint32_t flag)
@ DEG_OB_COMP_GEOMETRY
@ DEG_OB_COMP_TRANSFORM
#define CD_MASK_MDEFORMVERT
#define DNA_struct_default_get(struct_name)
struct CurveModifierData CurveModifierData
@ eModifierType_Curve
Object is a sort of wrapper for general info.
@ OB_MESH
@ OB_CURVES_LEGACY
static bool is_disabled
static void init_data(ModifierData *md)
Definition MOD_curve.cc:37
static void deform_verts(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
Definition MOD_curve.cc:93
ModifierTypeInfo modifierType_Curve
Definition MOD_curve.cc:184
static void panel_register(ARegionType *region_type)
Definition MOD_curve.cc:179
static void deform_verts_EM(ModifierData *md, const ModifierEvalContext *ctx, const BMEditMesh *em, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
Definition MOD_curve.cc:117
static void panel_draw(const bContext *, Panel *panel)
Definition MOD_curve.cc:162
static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
Definition MOD_curve.cc:46
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
Definition MOD_curve.cc:68
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
Definition MOD_curve.cc:75
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 uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
#define UI_ITEM_NONE
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
struct Object * object
Definition DNA_ID.h:413
struct uiLayout * layout
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4126