Blender  V2.93
MOD_fluid.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 <stddef.h>
25 
26 #include "MEM_guardedalloc.h"
27 
28 #include "BLI_utildefines.h"
29 
30 #include "BLT_translation.h"
31 
32 #include "DNA_collection_types.h"
33 #include "DNA_fluid_types.h"
34 #include "DNA_mesh_types.h"
35 #include "DNA_object_force_types.h"
36 #include "DNA_object_types.h"
37 #include "DNA_scene_types.h"
38 #include "DNA_screen_types.h"
39 
40 #include "BKE_context.h"
41 #include "BKE_fluid.h"
42 #include "BKE_layer.h"
43 #include "BKE_lib_query.h"
44 #include "BKE_modifier.h"
45 #include "BKE_screen.h"
46 
47 #include "UI_interface.h"
48 #include "UI_resources.h"
49 
50 #include "RNA_access.h"
51 
52 #include "DEG_depsgraph.h"
53 #include "DEG_depsgraph_build.h"
54 #include "DEG_depsgraph_physics.h"
55 #include "DEG_depsgraph_query.h"
56 
57 #include "MOD_modifiertypes.h"
58 #include "MOD_ui_common.h"
59 
60 static void initData(ModifierData *md)
61 {
63 
64  fmd->domain = NULL;
65  fmd->flow = NULL;
66  fmd->effector = NULL;
67  fmd->type = 0;
68  fmd->time = -1;
69 }
70 
71 static void copyData(const ModifierData *md, ModifierData *target, const int flag)
72 {
73 #ifndef WITH_FLUID
74  UNUSED_VARS(md, target, flag);
75 #else
76  const FluidModifierData *fmd = (const FluidModifierData *)md;
77  FluidModifierData *tfmd = (FluidModifierData *)target;
78 
80  BKE_fluid_modifier_copy(fmd, tfmd, flag);
81 #endif /* WITH_FLUID */
82 }
83 
84 static void freeData(ModifierData *md)
85 {
86 #ifndef WITH_FLUID
87  UNUSED_VARS(md);
88 #else
90 
92 #endif /* WITH_FLUID */
93 }
94 
95 static void requiredDataMask(Object *UNUSED(ob),
96  ModifierData *md,
97  CustomData_MeshMasks *r_cddata_masks)
98 {
100 
101  if (fmd && (fmd->type & MOD_FLUID_TYPE_FLOW) && fmd->flow) {
102  if (fmd->flow->source == FLUID_FLOW_SOURCE_MESH) {
103  /* vertex groups */
104  if (fmd->flow->vgroup_density) {
105  r_cddata_masks->vmask |= CD_MASK_MDEFORMVERT;
106  }
107  /* uv layer */
109  r_cddata_masks->fmask |= CD_MASK_MTFACE;
110  }
111  }
112  }
113 }
114 
115 static Mesh *modifyMesh(ModifierData *md, const ModifierEvalContext *ctx, Mesh *me)
116 {
117 #ifndef WITH_FLUID
118  UNUSED_VARS(md, ctx);
119  return me;
120 #else
122  Mesh *result = NULL;
123 
124  if (ctx->flag & MOD_APPLY_ORCO) {
125  return me;
126  }
127 
129 
130  result = BKE_fluid_modifier_do(fmd, ctx->depsgraph, scene, ctx->object, me);
131  return result ? result : me;
132 #endif /* WITH_FLUID */
133 }
134 
136 {
137  return true;
138 }
139 
140 static bool is_flow_cb(Object *UNUSED(ob), ModifierData *md)
141 {
143  return (fmd->type & MOD_FLUID_TYPE_FLOW) && fmd->flow;
144 }
145 
146 static bool is_coll_cb(Object *UNUSED(ob), ModifierData *md)
147 {
149  return (fmd->type & MOD_FLUID_TYPE_EFFEC) && fmd->effector;
150 }
151 
153 {
155 
156  if (fmd && (fmd->type & MOD_FLUID_TYPE_DOMAIN) && fmd->domain) {
158  ctx->object,
159  fmd->domain->fluid_group,
161  is_flow_cb,
162  "Fluid Flow");
164  ctx->object,
165  fmd->domain->effector_group,
167  is_coll_cb,
168  "Fluid Effector");
170  ctx->object,
171  fmd->domain->effector_weights,
172  true,
174  "Fluid Force Field");
175 
176  if (fmd->domain->guide_parent != NULL) {
178  ctx->node, fmd->domain->guide_parent, DEG_OB_COMP_TRANSFORM, "Fluid Guiding Object");
180  ctx->node, fmd->domain->guide_parent, DEG_OB_COMP_GEOMETRY, "Fluid Guiding Object");
181  }
182  }
183 }
184 
185 static void foreachIDLink(ModifierData *md, Object *ob, IDWalkFunc walk, void *userData)
186 {
188 
189  if (fmd->type == MOD_FLUID_TYPE_DOMAIN && fmd->domain) {
190  walk(userData, ob, (ID **)&fmd->domain->effector_group, IDWALK_CB_NOP);
191  walk(userData, ob, (ID **)&fmd->domain->fluid_group, IDWALK_CB_NOP);
192  walk(userData, ob, (ID **)&fmd->domain->force_group, IDWALK_CB_NOP);
193 
194  if (fmd->domain->guide_parent) {
195  walk(userData, ob, (ID **)&fmd->domain->guide_parent, IDWALK_CB_NOP);
196  }
197 
198  if (fmd->domain->effector_weights) {
199  walk(userData, ob, (ID **)&fmd->domain->effector_weights->group, IDWALK_CB_NOP);
200  }
201  }
202 
203  if (fmd->type == MOD_FLUID_TYPE_FLOW && fmd->flow) {
204  walk(userData, ob, (ID **)&fmd->flow->noise_texture, IDWALK_CB_USER);
205  }
206 }
207 
208 static void panel_draw(const bContext *UNUSED(C), Panel *panel)
209 {
210  uiLayout *layout = panel->layout;
211 
213 
214  uiItemL(layout, IFACE_("Settings are inside the Physics tab"), ICON_NONE);
215 
216  modifier_panel_end(layout, ptr);
217 }
218 
219 static void panelRegister(ARegionType *region_type)
220 {
222 }
223 
225  /* name */ "Fluid",
226  /* structName */ "FluidModifierData",
227  /* structSize */ sizeof(FluidModifierData),
228  /* srna */ &RNA_FluidModifier,
231  /* icon */ ICON_MOD_FLUIDSIM,
232 
233  /* copyData */ copyData,
234 
235  /* deformVerts */ NULL,
236  /* deformMatrices */ NULL,
237  /* deformVertsEM */ NULL,
238  /* deformMatricesEM */ NULL,
239  /* modifyMesh */ modifyMesh,
240  /* modifyHair */ NULL,
241  /* modifyGeometrySet */ NULL,
242  /* modifyVolume */ NULL,
243 
244  /* initData */ initData,
245  /* requiredDataMask */ requiredDataMask,
246  /* freeData */ freeData,
247  /* isDisabled */ NULL,
248  /* updateDepsgraph */ updateDepsgraph,
249  /* dependsOnTime */ dependsOnTime,
250  /* dependsOnNormals */ NULL,
251  /* foreachIDLink */ foreachIDLink,
252  /* foreachTexLink */ NULL,
253  /* freeRuntimeData */ NULL,
254  /* panelRegister */ panelRegister,
255  /* blendWrite */ NULL,
256  /* blendRead */ NULL,
257 };
void BKE_fluid_modifier_copy(const struct FluidModifierData *fmd, struct FluidModifierData *tfmd, const int flag)
Definition: fluid.c:4948
struct Mesh * BKE_fluid_modifier_do(struct FluidModifierData *fmd, struct Depsgraph *depsgraph, struct Scene *scene, struct Object *ob, struct Mesh *me)
void BKE_fluid_modifier_free(struct FluidModifierData *fmd)
Definition: fluid.c:4881
@ IDWALK_CB_USER
Definition: BKE_lib_query.h:87
@ 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_Single
Definition: BKE_modifier.h:107
@ eModifierTypeFlag_AcceptsMesh
Definition: BKE_modifier.h:80
@ eModifierTypeType_Constructive
Definition: BKE_modifier.h:61
@ MOD_APPLY_ORCO
Definition: BKE_modifier.h:133
#define UNUSED_VARS(...)
#define UNUSED(x)
#define IFACE_(msgid)
void DEG_add_object_relation(struct DepsNodeHandle *node_handle, struct Object *object, eDepsObjectComponentType component, const char *description)
@ DEG_OB_COMP_GEOMETRY
@ DEG_OB_COMP_TRANSFORM
void DEG_add_collision_relations(struct DepsNodeHandle *handle, struct Object *object, struct Collection *collection, unsigned int modifier_type, DEG_CollobjFilterFunction filter_function, const char *name)
void DEG_add_forcefield_relations(struct DepsNodeHandle *handle, struct Object *object, struct EffectorWeights *eff, bool add_absorption, int skip_forcefield, const char *name)
struct Scene * DEG_get_evaluated_scene(const struct Depsgraph *graph)
Object groups, one object can be in many groups at once.
#define CD_MASK_MDEFORMVERT
#define CD_MASK_MTFACE
@ FLUID_FLOW_SOURCE_MESH
@ FLUID_FLOW_TEXTURE_MAP_UV
struct FluidModifierData FluidModifierData
@ eModifierType_Fluid
@ MOD_FLUID_TYPE_EFFEC
@ MOD_FLUID_TYPE_DOMAIN
@ MOD_FLUID_TYPE_FLOW
@ PFIELD_FLUIDFLOW
Object is a sort of wrapper for general info.
Read Guarded memory(de)allocation.
static void copyData(const ModifierData *md, ModifierData *target, const int flag)
Definition: MOD_fluid.c:71
static void updateDepsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
Definition: MOD_fluid.c:152
static Mesh * modifyMesh(ModifierData *md, const ModifierEvalContext *ctx, Mesh *me)
Definition: MOD_fluid.c:115
static bool is_coll_cb(Object *UNUSED(ob), ModifierData *md)
Definition: MOD_fluid.c:146
static bool is_flow_cb(Object *UNUSED(ob), ModifierData *md)
Definition: MOD_fluid.c:140
static void foreachIDLink(ModifierData *md, Object *ob, IDWalkFunc walk, void *userData)
Definition: MOD_fluid.c:185
ModifierTypeInfo modifierType_Fluid
Definition: MOD_fluid.c:224
static bool dependsOnTime(ModifierData *UNUSED(md))
Definition: MOD_fluid.c:135
static void panel_draw(const bContext *UNUSED(C), Panel *panel)
Definition: MOD_fluid.c:208
static void initData(ModifierData *md)
Definition: MOD_fluid.c:60
static void panelRegister(ARegionType *region_type)
Definition: MOD_fluid.c:219
static void freeData(ModifierData *md)
Definition: MOD_fluid.c:84
static void requiredDataMask(Object *UNUSED(ob), ModifierData *md, CustomData_MeshMasks *r_cddata_masks)
Definition: MOD_fluid.c:95
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)
StructRNA RNA_FluidModifier
#define C
Definition: RandGen.cpp:39
void uiItemL(uiLayout *layout, const char *name, int icon)
Scene scene
struct Collection * group
struct Collection * force_group
struct Collection * effector_group
struct Object * guide_parent
struct Collection * fluid_group
struct EffectorWeights * effector_weights
struct Tex * noise_texture
struct FluidDomainSettings * domain
struct FluidEffectorSettings * effector
struct FluidFlowSettings * flow
Definition: DNA_ID.h:273
struct Depsgraph * depsgraph
Definition: BKE_modifier.h:153
ModifierApplyFlag flag
Definition: BKE_modifier.h:155
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