Blender V4.3
MOD_lattice.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_object_types.h"
17#include "DNA_screen_types.h"
18
19#include "BKE_lattice.hh"
20#include "BKE_lib_query.hh"
21#include "BKE_mesh.hh"
22#include "BKE_modifier.hh"
23
24#include "UI_interface.hh"
25#include "UI_resources.hh"
26
27#include "RNA_prototypes.hh"
28
29#include "MEM_guardedalloc.h"
30
31#include "MOD_ui_common.hh"
32#include "MOD_util.hh"
33
42
43static void required_data_mask(ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
44{
46
47 /* Ask for vertex-groups if we need them. */
48 if (lmd->name[0] != '\0') {
49 r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
50 }
51}
52
59{
60 return !lmd->object || lmd->object->type != OB_LATTICE;
61}
62
63static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
64{
66 return is_disabled(lmd);
67}
68
69static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
70{
72
73 walk(user_data, ob, (ID **)&lmd->object, IDWALK_CB_NOP);
74}
75
77{
79 if (is_disabled(lmd)) {
80 return;
81 }
82
83 DEG_add_object_relation(ctx->node, lmd->object, DEG_OB_COMP_GEOMETRY, "Lattice Modifier");
84 DEG_add_object_relation(ctx->node, lmd->object, DEG_OB_COMP_TRANSFORM, "Lattice Modifier");
85 DEG_add_depends_on_transform_relation(ctx->node, "Lattice Modifier");
86}
87
88static void deform_verts(ModifierData *md,
89 const ModifierEvalContext *ctx,
90 Mesh *mesh,
92{
94
95 /* if next modifier needs original vertices */
96 MOD_previous_vcos_store(md, reinterpret_cast<const float(*)[3]>(positions.data()));
97
99 ctx->object,
100 reinterpret_cast<float(*)[3]>(positions.data()),
101 positions.size(),
102 lmd->flag,
103 lmd->name,
104 lmd->strength,
105 mesh);
106}
107
109 const ModifierEvalContext *ctx,
110 const BMEditMesh *em,
111 Mesh *mesh,
113{
114 if (mesh->runtime->wrapper_type == ME_WRAPPER_TYPE_MDATA) {
115 deform_verts(md, ctx, mesh, positions);
116 return;
117 }
118
120
121 /* if next modifier needs original vertices */
122 MOD_previous_vcos_store(md, reinterpret_cast<const float(*)[3]>(positions.data()));
123
125 ctx->object,
126 reinterpret_cast<float(*)[3]>(positions.data()),
127 positions.size(),
128 lmd->flag,
129 lmd->name,
130 lmd->strength,
131 em);
132}
133
134static void panel_draw(const bContext * /*C*/, Panel *panel)
135{
136 uiLayout *layout = panel->layout;
137
138 PointerRNA ob_ptr;
140
141 uiLayoutSetPropSep(layout, true);
142
143 uiItemR(layout, ptr, "object", UI_ITEM_NONE, nullptr, ICON_NONE);
144
145 modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", nullptr);
146
147 uiItemR(layout, ptr, "strength", UI_ITEM_R_SLIDER, nullptr, ICON_NONE);
148
149 modifier_panel_end(layout, ptr);
150}
151
152static void panel_register(ARegionType *region_type)
153{
155}
156
158 /*idname*/ "Lattice",
159 /*name*/ N_("Lattice"),
160 /*struct_name*/ "LatticeModifierData",
161 /*struct_size*/ sizeof(LatticeModifierData),
162 /*srna*/ &RNA_LatticeModifier,
166 /*icon*/ ICON_MOD_LATTICE,
167
168 /*copy_data*/ BKE_modifier_copydata_generic,
169
170 /*deform_verts*/ deform_verts,
171 /*deform_matrices*/ nullptr,
172 /*deform_verts_EM*/ deform_verts_EM,
173 /*deform_matrices_EM*/ nullptr,
174 /*modify_mesh*/ nullptr,
175 /*modify_geometry_set*/ nullptr,
176
177 /*init_data*/ init_data,
178 /*required_data_mask*/ required_data_mask,
179 /*free_data*/ nullptr,
180 /*is_disabled*/ is_disabled,
181 /*update_depsgraph*/ update_depsgraph,
182 /*depends_on_time*/ nullptr,
183 /*depends_on_normals*/ nullptr,
184 /*foreach_ID_link*/ foreach_ID_link,
185 /*foreach_tex_link*/ nullptr,
186 /*free_runtime_data*/ nullptr,
187 /*panel_register*/ panel_register,
188 /*blend_write*/ nullptr,
189 /*blend_read*/ nullptr,
190 /*foreach_cache*/ nullptr,
191};
void BKE_lattice_deform_coords_with_mesh(const Object *ob_lattice, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, short flag, const char *defgrp_name, float fac, const Mesh *me_target)
void BKE_lattice_deform_coords_with_editmesh(const Object *ob_lattice, const Object *ob_target, float(*vert_coords)[3], int vert_coords_len, short flag, const char *defgrp_name, float fac, const BMEditMesh *em_target)
@ 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)
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)
@ DEG_OB_COMP_GEOMETRY
@ DEG_OB_COMP_TRANSFORM
#define CD_MASK_MDEFORMVERT
#define DNA_struct_default_get(struct_name)
@ eModifierType_Lattice
struct LatticeModifierData LatticeModifierData
Object is a sort of wrapper for general info.
@ OB_LATTICE
static bool is_disabled
Read Guarded memory(de)allocation.
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 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 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_Lattice
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
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_previous_vcos_store(ModifierData *md, const float(*vert_coords)[3])
Definition MOD_util.cc:145
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)
@ UI_ITEM_R_SLIDER
Definition DNA_ID.h:413
struct uiLayout * layout
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4126