Blender V5.0
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
8
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
27#include "UI_resources.hh"
28
29#include "RNA_prototypes.hh"
30#include "RNA_types.hh"
31
32#include "DEG_depsgraph.hh"
34
35#include "MOD_ui_common.hh"
36#include "MOD_util.hh"
37
46
47static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
48{
50
51 /* Ask for vertex-groups if we need them. */
52 if (cmd->name[0] != '\0') {
53 r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
54 }
55}
56
57static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
58{
60
61 /* The object type check is only needed here in case we have a placeholder
62 * object assigned (because the library containing the curve is missing).
63 *
64 * In other cases it should be impossible to have a type mismatch.
65 */
66 return !cmd->object || cmd->object->type != OB_CURVES_LEGACY;
67}
68
69static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
70{
72
73 walk(user_data, ob, (ID **)&cmd->object, IDWALK_CB_NOP);
74}
75
77{
79 if (cmd->object != nullptr) {
80 /* TODO(sergey): Need to do the same eval_flags trick for path
81 * as happening in legacy depsgraph callback.
82 */
83 /* TODO(sergey): Currently path is evaluated as a part of modifier stack,
84 * might be changed in the future.
85 */
86 DEG_add_object_relation(ctx->node, cmd->object, DEG_OB_COMP_TRANSFORM, "Curve Modifier");
87 DEG_add_object_relation(ctx->node, cmd->object, DEG_OB_COMP_GEOMETRY, "Curve Modifier");
89 }
90
91 DEG_add_depends_on_transform_relation(ctx->node, "Curve Modifier");
92}
93
94static void deform_verts(ModifierData *md,
95 const ModifierEvalContext *ctx,
96 Mesh *mesh,
98{
100
101 const MDeformVert *dvert = nullptr;
102 int defgrp_index = -1;
103 MOD_get_vgroup(ctx->object, mesh, cmd->name, &dvert, &defgrp_index);
104
105 /* Silly that defaxis and BKE_curve_deform_coords are off by 1
106 * but leave for now to save having to call do_versions */
107 const int defaxis = std::clamp(cmd->defaxis - 1, 0, 5);
109 ctx->object,
110 reinterpret_cast<float (*)[3]>(positions.data()),
111 positions.size(),
112 dvert,
113 defgrp_index,
114 cmd->flag,
115 defaxis);
116}
117
119 const ModifierEvalContext *ctx,
120 const BMEditMesh *em,
121 Mesh *mesh,
123{
124 if (mesh->runtime->wrapper_type == ME_WRAPPER_TYPE_MDATA) {
125 deform_verts(md, ctx, mesh, positions);
126 return;
127 }
128
130 bool use_dverts = false;
131 int defgrp_index = -1;
132
133 if (ctx->object->type == OB_MESH && cmd->name[0] != '\0') {
134 defgrp_index = BKE_object_defgroup_name_index(ctx->object, cmd->name);
135 if (defgrp_index != -1) {
136 use_dverts = true;
137 }
138 }
139
140 const int defaxis = std::clamp(cmd->defaxis - 1, 0, 5);
141 if (use_dverts) {
143 ctx->object,
144 reinterpret_cast<float (*)[3]>(positions.data()),
145 positions.size(),
146 defgrp_index,
147 cmd->flag,
148 defaxis,
149 em);
150 }
151 else {
153 ctx->object,
154 reinterpret_cast<float (*)[3]>(positions.data()),
155 positions.size(),
156 nullptr,
157 defgrp_index,
158 cmd->flag,
159 defaxis);
160 }
161}
162
163static void panel_draw(const bContext * /*C*/, Panel *panel)
164{
165 uiLayout *layout = panel->layout;
166
167 PointerRNA ob_ptr;
169
170 layout->use_property_split_set(true);
171
172 layout->prop(ptr, "object", UI_ITEM_NONE, IFACE_("Curve Object"), ICON_NONE);
173 layout->prop(ptr, "deform_axis", UI_ITEM_NONE, std::nullopt, ICON_NONE);
174
175 modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", std::nullopt);
176
178}
179
180static void panel_register(ARegionType *region_type)
181{
183}
184
186 /*idname*/ "Curve",
187 /*name*/ N_("Curve"),
188 /*struct_name*/ "CurveModifierData",
189 /*struct_size*/ sizeof(CurveModifierData),
190 /*srna*/ &RNA_CurveModifier,
194 /*icon*/ ICON_MOD_CURVE,
195
196 /*copy_data*/ BKE_modifier_copydata_generic,
197
198 /*deform_verts*/ deform_verts,
199 /*deform_matrices*/ nullptr,
200 /*deform_verts_EM*/ deform_verts_EM,
201 /*deform_matrices_EM*/ nullptr,
202 /*modify_mesh*/ nullptr,
203 /*modify_geometry_set*/ nullptr,
204
205 /*init_data*/ init_data,
206 /*required_data_mask*/ required_data_mask,
207 /*free_data*/ nullptr,
208 /*is_disabled*/ is_disabled,
209 /*update_depsgraph*/ update_depsgraph,
210 /*depends_on_time*/ nullptr,
211 /*depends_on_normals*/ nullptr,
212 /*foreach_ID_link*/ foreach_ID_link,
213 /*foreach_tex_link*/ nullptr,
214 /*free_runtime_data*/ nullptr,
215 /*panel_register*/ panel_register,
216 /*blend_write*/ nullptr,
217 /*blend_read*/ nullptr,
218 /*foreach_cache*/ nullptr,
219 /*foreach_working_space_color*/ nullptr,
220};
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:591
@ IDWALK_CB_NOP
@ ME_WRAPPER_TYPE_MDATA
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
#define BLI_assert(a)
Definition BLI_assert.h:46
#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)
@ 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)
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 deform_verts_EM(ModifierData *md, const ModifierEvalContext *ctx, const BMEditMesh *em, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
static void panel_draw(const bContext *, Panel *panel)
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
static void init_data(ModifierData *md)
Definition MOD_curve.cc:38
static void deform_verts(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
Definition MOD_curve.cc:94
ModifierTypeInfo modifierType_Curve
Definition MOD_curve.cc:185
static void panel_register(ARegionType *region_type)
Definition MOD_curve.cc:180
static void deform_verts_EM(ModifierData *md, const ModifierEvalContext *ctx, const BMEditMesh *em, Mesh *mesh, blender::MutableSpan< blender::float3 > positions)
Definition MOD_curve.cc:118
static void panel_draw(const bContext *, Panel *panel)
Definition MOD_curve.cc:163
static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
Definition MOD_curve.cc:47
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
Definition MOD_curve.cc:69
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
Definition MOD_curve.cc:76
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_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_get_vgroup(const Object *ob, const Mesh *mesh, const char *name, const MDeformVert **dvert, int *defgrp_index)
Definition MOD_util.cc:156
#define UI_ITEM_NONE
constexpr int64_t size() const
Definition BLI_span.hh:493
constexpr T * data() const
Definition BLI_span.hh:539
static void update_depsgraph(tGraphSliderOp *gso)
struct Object * object
Definition DNA_ID.h:414
MeshRuntimeHandle * runtime
struct uiLayout * layout
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)
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4238