Blender  V2.93
MOD_lattice.c
Go to the documentation of this file.
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  *
16  * The Original Code is Copyright (C) 2005 by the Blender Foundation.
17  * All rights reserved.
18  */
19 
24 #include <string.h>
25 
26 #include "BLI_utildefines.h"
27 
28 #include "BLT_translation.h"
29 
30 #include "DNA_defaults.h"
31 #include "DNA_object_types.h"
32 #include "DNA_screen_types.h"
33 
34 #include "BKE_context.h"
35 #include "BKE_editmesh.h"
36 #include "BKE_lattice.h"
37 #include "BKE_lib_id.h"
38 #include "BKE_lib_query.h"
39 #include "BKE_mesh.h"
40 #include "BKE_mesh_wrapper.h"
41 #include "BKE_modifier.h"
42 #include "BKE_screen.h"
43 
44 #include "UI_interface.h"
45 #include "UI_resources.h"
46 
47 #include "RNA_access.h"
48 
49 #include "DEG_depsgraph_query.h"
50 
51 #include "MEM_guardedalloc.h"
52 
53 #include "MOD_ui_common.h"
54 #include "MOD_util.h"
55 
56 static void initData(ModifierData *md)
57 {
59 
61 
63 }
64 
65 static void requiredDataMask(Object *UNUSED(ob),
66  ModifierData *md,
67  CustomData_MeshMasks *r_cddata_masks)
68 {
70 
71  /* ask for vertexgroups if we need them */
72  if (lmd->name[0] != '\0') {
73  r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
74  }
75 }
76 
77 static bool isDisabled(const struct Scene *UNUSED(scene),
78  ModifierData *md,
79  bool UNUSED(userRenderParams))
80 {
82 
83  /* The object type check is only needed here in case we have a placeholder
84  * object assigned (because the library containing the lattice is missing).
85  *
86  * In other cases it should be impossible to have a type mismatch.
87  */
88  return !lmd->object || lmd->object->type != OB_LATTICE;
89 }
90 
91 static void foreachIDLink(ModifierData *md, Object *ob, IDWalkFunc walk, void *userData)
92 {
94 
95  walk(userData, ob, (ID **)&lmd->object, IDWALK_CB_NOP);
96 }
97 
99 {
101  if (lmd->object != NULL) {
102  DEG_add_object_relation(ctx->node, lmd->object, DEG_OB_COMP_GEOMETRY, "Lattice Modifier");
103  DEG_add_object_relation(ctx->node, lmd->object, DEG_OB_COMP_TRANSFORM, "Lattice Modifier");
104  }
105  DEG_add_modifier_to_transform_relation(ctx->node, "Lattice Modifier");
106 }
107 
108 static void deformVerts(ModifierData *md,
109  const ModifierEvalContext *ctx,
110  struct Mesh *mesh,
111  float (*vertexCos)[3],
112  int numVerts)
113 {
115  struct Mesh *mesh_src = MOD_deform_mesh_eval_get(
116  ctx->object, NULL, mesh, NULL, numVerts, false, false);
117 
118  MOD_previous_vcos_store(md, vertexCos); /* if next modifier needs original vertices */
119 
121  ctx->object,
122  vertexCos,
123  numVerts,
124  lmd->flag,
125  lmd->name,
126  lmd->strength,
127  mesh_src);
128 
129  if (!ELEM(mesh_src, NULL, mesh)) {
130  BKE_id_free(NULL, mesh_src);
131  }
132 }
133 
134 static void deformVertsEM(ModifierData *md,
135  const ModifierEvalContext *ctx,
136  struct BMEditMesh *em,
137  struct Mesh *mesh,
138  float (*vertexCos)[3],
139  int numVerts)
140 {
141  if (mesh != NULL) {
142  deformVerts(md, ctx, mesh, vertexCos, numVerts);
143  return;
144  }
145 
147 
148  MOD_previous_vcos_store(md, vertexCos); /* if next modifier needs original vertices */
149 
151  lmd->object, ctx->object, vertexCos, numVerts, lmd->flag, lmd->name, lmd->strength, em);
152 }
153 
154 static void panel_draw(const bContext *UNUSED(C), Panel *panel)
155 {
156  uiLayout *layout = panel->layout;
157 
158  PointerRNA ob_ptr;
160 
161  uiLayoutSetPropSep(layout, true);
162 
163  uiItemR(layout, ptr, "object", 0, NULL, ICON_NONE);
164 
165  modifier_vgroup_ui(layout, ptr, &ob_ptr, "vertex_group", "invert_vertex_group", NULL);
166 
167  uiItemR(layout, ptr, "strength", UI_ITEM_R_SLIDER, NULL, ICON_NONE);
168 
169  modifier_panel_end(layout, ptr);
170 }
171 
172 static void panelRegister(ARegionType *region_type)
173 {
175 }
176 
178  /* name */ "Lattice",
179  /* structName */ "LatticeModifierData",
180  /* structSize */ sizeof(LatticeModifierData),
181  /* srna */ &RNA_LatticeModifier,
182  /* type */ eModifierTypeType_OnlyDeform,
185  /* icon */ ICON_MOD_LATTICE,
186 
187  /* copyData */ BKE_modifier_copydata_generic,
188 
189  /* deformVerts */ deformVerts,
190  /* deformMatrices */ NULL,
191  /* deformVertsEM */ deformVertsEM,
192  /* deformMatricesEM */ NULL,
193  /* modifyMesh */ NULL,
194  /* modifyHair */ NULL,
195  /* modifyGeometrySet */ NULL,
196  /* modifyVolume */ NULL,
197 
198  /* initData */ initData,
199  /* requiredDataMask */ requiredDataMask,
200  /* freeData */ NULL,
201  /* isDisabled */ isDisabled,
202  /* updateDepsgraph */ updateDepsgraph,
203  /* dependsOnTime */ NULL,
204  /* dependsOnNormals */ NULL,
205  /* foreachIDLink */ foreachIDLink,
206  /* foreachTexLink */ NULL,
207  /* freeRuntimeData */ NULL,
208  /* panelRegister */ panelRegister,
209  /* blendWrite */ NULL,
210  /* blendRead */ NULL,
211 };
void BKE_lattice_deform_coords_with_mesh(const struct Object *ob_lattice, const struct Object *ob_target, float(*vert_coords)[3], const int vert_coords_len, const short flag, const char *defgrp_name, const float fac, const struct Mesh *me_target)
void BKE_lattice_deform_coords_with_editmesh(const struct Object *ob_lattice, const struct Object *ob_target, float(*vert_coords)[3], const int vert_coords_len, const short flag, const char *defgrp_name, const float fac, struct BMEditMesh *em_target)
void BKE_id_free(struct Main *bmain, void *idv)
@ IDWALK_CB_NOP
Definition: BKE_lib_query.h:47
void(* IDWalkFunc)(void *userData, struct Object *ob, struct ID **idpoin, int cb_flag)
Definition: BKE_modifier.h:120
@ eModifierTypeFlag_AcceptsCVs
Definition: BKE_modifier.h:81
@ eModifierTypeFlag_SupportsEditmode
Definition: BKE_modifier.h:83
@ eModifierTypeFlag_AcceptsVertexCosOnly
Definition: BKE_modifier.h:114
void BKE_modifier_copydata_generic(const struct ModifierData *md, struct ModifierData *md_dst, const int flag)
@ eModifierTypeType_OnlyDeform
Definition: BKE_modifier.h:58
#define BLI_assert(a)
Definition: BLI_assert.h:58
#define UNUSED(x)
#define ELEM(...)
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
void DEG_add_object_relation(struct DepsNodeHandle *node_handle, struct Object *object, eDepsObjectComponentType component, const char *description)
void DEG_add_modifier_to_transform_relation(struct DepsNodeHandle *node_handle, const char *description)
@ DEG_OB_COMP_GEOMETRY
@ DEG_OB_COMP_TRANSFORM
#define CD_MASK_MDEFORMVERT
#define DNA_struct_default_get(struct_name)
Definition: DNA_defaults.h:44
@ eModifierType_Lattice
struct LatticeModifierData LatticeModifierData
Object is a sort of wrapper for general info.
@ OB_LATTICE
Read Guarded memory(de)allocation.
static bool isDisabled(const struct Scene *UNUSED(scene), ModifierData *md, bool UNUSED(userRenderParams))
Definition: MOD_lattice.c:77
static void deformVertsEM(ModifierData *md, const ModifierEvalContext *ctx, struct BMEditMesh *em, struct Mesh *mesh, float(*vertexCos)[3], int numVerts)
Definition: MOD_lattice.c:134
static void updateDepsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
Definition: MOD_lattice.c:98
static void foreachIDLink(ModifierData *md, Object *ob, IDWalkFunc walk, void *userData)
Definition: MOD_lattice.c:91
ModifierTypeInfo modifierType_Lattice
Definition: MOD_lattice.c:177
static void panel_draw(const bContext *UNUSED(C), Panel *panel)
Definition: MOD_lattice.c:154
static void initData(ModifierData *md)
Definition: MOD_lattice.c:56
static void panelRegister(ARegionType *region_type)
Definition: MOD_lattice.c:172
static void deformVerts(ModifierData *md, const ModifierEvalContext *ctx, struct Mesh *mesh, float(*vertexCos)[3], int numVerts)
Definition: MOD_lattice.c:108
static void requiredDataMask(Object *UNUSED(ob), ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
Definition: MOD_lattice.c:65
PointerRNA * modifier_panel_get_property_pointers(Panel *panel, PointerRNA *r_ob_ptr)
void modifier_panel_end(uiLayout *layout, PointerRNA *ptr)
PanelType * modifier_panel_register(ARegionType *region_type, ModifierType type, PanelDrawFn draw)
void modifier_vgroup_ui(uiLayout *layout, PointerRNA *ptr, PointerRNA *ob_ptr, const char *vgroup_prop, const char *invert_vgroup_prop, const char *text)
Mesh * MOD_deform_mesh_eval_get(Object *ob, struct BMEditMesh *em, Mesh *mesh, const float(*vertexCos)[3], const int num_verts, const bool use_normals, const bool use_orco)
Definition: MOD_util.c:186
void MOD_previous_vcos_store(ModifierData *md, const float(*vert_coords)[3])
Definition: MOD_util.c:171
StructRNA RNA_LatticeModifier
#define C
Definition: RandGen.cpp:39
@ UI_ITEM_R_SLIDER
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
void uiItemR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int flag, const char *name, int icon)
Scene scene
Definition: DNA_ID.h:273
struct Object * object
struct Object * object
Definition: BKE_modifier.h:154
struct DepsNodeHandle * node
Definition: BKE_modifier.h:147
struct uiLayout * layout
PointerRNA * ptr
Definition: wm_files.c:3157