37 #include "RNA_prototypes.h"
65 bool UNUSED(useRenderParams))
77 float (*vertexCos_Real)[3],
80 const bool use_factor = mcmd->
factor < 1.0f;
81 int influence_group_index;
85 float(*vertexCos_Store)[3] = (use_factor || influence_group_index != -1 ||
88 verts_num,
sizeof(*vertexCos_Store), __func__) :
90 float(*vertexCos)[3] = vertexCos_Store ? vertexCos_Store : vertexCos_Real;
92 const float fps =
FPS;
95 const char *err_str =
NULL;
149 switch (mcmd->
type) {
183 verts_num,
sizeof(*vertexCos_Source), __func__);
187 for (i = 0; i < verts_num; i++,
mv++) {
197 (
const float(*)[3])vertexCos_Source,
198 (
const float(*)[3])vertexCos_Real,
200 (
const float(*)[3])vertexCos,
205 memcpy(vertexCos, vertexCos_New,
sizeof(*vertexCos) * verts_num);
218 bool use_matrix =
false;
245 for (i = 0; i < verts_num; i++) {
251 if (vertexCos_Store) {
253 if (influence_group_index != -1) {
261 for (
int i = 0; i < verts_num; i++) {
265 const float local_vertex_fac = global_offset +
267 influence_group_index) *
270 vertexCos_Real[i], vertexCos_Real[i], vertexCos_Store[i], local_vertex_fac);
274 else if (use_factor) {
279 memcpy(vertexCos_Real, vertexCos_Store,
sizeof(*vertexCos_Store) * verts_num);
290 float (*vertexCos)[3],
313 float (*vertexCos)[3],
326 if (mesh_src !=
NULL) {
420 "MeshCacheModifierData",
422 &RNA_MeshCacheModifier,
typedef float(TangentPoint)[2]
void BKE_id_free(struct Main *bmain, void *idv)
void BKE_mesh_calc_relative_deform(const struct MPoly *mpoly, int totpoly, const struct MLoop *mloop, int totvert, const float(*vert_cos_src)[3], const float(*vert_cos_dst)[3], const float(*vert_cos_org)[3], float(*vert_cos_new)[3])
void BKE_mesh_wrapper_ensure_mdata(struct Mesh *me)
@ eModifierTypeFlag_AcceptsCVs
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsVertexCosOnly
void BKE_modifier_copydata_generic(const struct ModifierData *md, struct ModifierData *md_dst, int flag)
@ eModifierTypeType_OnlyDeform
void BKE_modifier_set_error(const struct Object *ob, struct ModifierData *md, const char *format,...) ATTR_PRINTF_FORMAT(3
float BKE_scene_ctime_get(const struct Scene *scene)
void mul_m3_v3(const float M[3][3], float r[3])
void unit_m3(float m[3][3])
void mul_m3_m3m3(float R[3][3], const float A[3][3], const float B[3][3])
bool mat3_from_axis_conversion(int src_forward, int src_up, int dst_forward, int dst_up, float r_mat[3][3])
MINLINE void copy_v3_v3(float r[3], const float a[3])
void interp_v3_v3v3(float r[3], const float a[3], const float b[3], float t)
void interp_vn_vn(float *array_tar, const float *array_src, float t, int size)
bool BLI_path_abs(char *path, const char *basepath) ATTR_NONNULL()
char * BLI_strncpy(char *__restrict dst, const char *__restrict src, size_t maxncpy) ATTR_NONNULL()
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
struct Scene * DEG_get_evaluated_scene(const struct Depsgraph *graph)
#define ID_BLEND_PATH_FROM_GLOBAL(_id)
#define DNA_struct_default_get(struct_name)
struct MeshCacheModifierData MeshCacheModifierData
@ MOD_MESHCACHE_DEFORM_INTEGRATE
@ eModifierType_MeshCache
@ MOD_MESHCACHE_INVERT_VERTEX_GROUP
@ MOD_MESHCACHE_TIME_FRAME
@ MOD_MESHCACHE_TIME_FACTOR
@ MOD_MESHCACHE_TIME_SECONDS
@ MOD_MESHCACHE_PLAY_CFEA
Object is a sort of wrapper for general info.
Read Guarded memory(de)allocation.
static void deformVerts(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh, float(*vertexCos)[3], int verts_num)
static void time_remapping_panel_draw(const bContext *UNUSED(C), Panel *panel)
static void deformVertsEM(ModifierData *md, const ModifierEvalContext *ctx, struct BMEditMesh *editData, Mesh *mesh, float(*vertexCos)[3], int verts_num)
static void meshcache_do(MeshCacheModifierData *mcmd, Scene *scene, Object *ob, Mesh *mesh, float(*vertexCos_Real)[3], int verts_num)
ModifierTypeInfo modifierType_MeshCache
static bool dependsOnTime(struct Scene *UNUSED(scene), ModifierData *md)
static bool isDisabled(const struct Scene *UNUSED(scene), ModifierData *md, bool UNUSED(useRenderParams))
static void axis_mapping_panel_draw(const bContext *UNUSED(C), Panel *panel)
static void panel_draw(const bContext *UNUSED(C), Panel *panel)
static void initData(ModifierData *md)
static void panelRegister(ARegionType *region_type)
bool MOD_meshcache_read_mdd_times(const char *filepath, float(*vertexCos)[3], const int verts_tot, const char interp, const float time, const float fps, const char time_mode, const char **err_str)
bool MOD_meshcache_read_pc2_times(const char *filepath, float(*vertexCos)[3], const int verts_tot, const char interp, const float time, const float fps, const char time_mode, const char **err_str)
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)
PanelType * modifier_subpanel_register(ARegionType *region_type, const char *name, const char *label, PanelDrawFn draw_header, PanelDrawFn draw, PanelType *parent)
Mesh * MOD_deform_mesh_eval_get(Object *ob, struct BMEditMesh *em, Mesh *mesh, const float(*vertexCos)[3], const int verts_num, const bool use_normals, const bool use_orco)
void MOD_get_vgroup(Object *ob, struct Mesh *mesh, const char *name, MDeformVert **dvert, int *defgrp_index)
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiLayoutSetRedAlert(uiLayout *layout, bool redalert)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
void uiItemR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, int flag, const char *name, int icon)
void *(* MEM_malloc_arrayN)(size_t len, size_t size, const char *str)
void(* MEM_freeN)(void *vmemh)
int RNA_enum_get(PointerRNA *ptr, const char *name)
struct MDeformVert * dvert
struct Depsgraph * depsgraph