37#include "RNA_prototypes.hh"
75 float (*vertexCos_Real)[3],
78 const bool use_factor = mcmd->
factor < 1.0f;
79 int influence_group_index;
83 float(*vertexCos_Store)[3] = (use_factor || influence_group_index != -1 ||
86 verts_num,
sizeof(*vertexCos_Store), __func__)) :
88 float(*vertexCos)[3] = vertexCos_Store ? vertexCos_Store : vertexCos_Real;
90 const float fps =
FPS;
93 const char *err_str =
nullptr;
147 switch (mcmd->
type) {
150 filepath, vertexCos, verts_num, mcmd->
interp, time, fps, mcmd->
time_mode, &err_str);
154 filepath, vertexCos, verts_num, mcmd->
interp, time, fps, mcmd->
time_mode, &err_str);
164 Mesh *mesh =
static_cast<Mesh *
>(ob->data);
170 else if (
UNLIKELY(mesh->verts_num != verts_num)) {
173 else if (
UNLIKELY(mesh->faces_num == 0)) {
177 float(*vertexCos_New)[3] =
static_cast<float(*)[3]
>(
181 mesh->face_offsets().data(),
183 mesh->corner_verts().data(),
186 reinterpret_cast<const float(*)[3]
>(mesh->vert_positions().data()),
188 const_cast<const float(*)[3]
>(vertexCos_Real),
190 const_cast<const float(*)[3]
>(vertexCos),
195 memcpy(vertexCos, vertexCos_New,
sizeof(*vertexCos) * verts_num);
207 bool use_matrix =
false;
234 for (i = 0; i < verts_num; i++) {
240 if (vertexCos_Store) {
242 if (influence_group_index != -1) {
249 if (!mesh->deform_verts().is_empty()) {
250 for (
int i = 0; i < verts_num; i++) {
254 const float local_vertex_fac = global_offset +
256 influence_group_index) *
259 vertexCos_Real[i], vertexCos_Real[i], vertexCos_Store[i], local_vertex_fac);
263 else if (use_factor) {
268 memcpy(vertexCos_Real, vertexCos_Store,
sizeof(*vertexCos_Store) * verts_num);
288 reinterpret_cast<float(*)[3]
>(positions.data()),
376 "MeshCacheModifierData",
378 &RNA_MeshCacheModifier,
void BKE_mesh_calc_relative_deform(const int *face_offsets, int faces_num, const int *corner_verts, 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_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_AcceptsCVs
@ eModifierTypeFlag_SupportsEditmode
@ eModifierTypeFlag_AcceptsVertexCosOnly
void BKE_modifier_set_error(const Object *ob, ModifierData *md, const char *format,...) ATTR_PRINTF_FORMAT(3
float BKE_scene_ctime_get(const 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])
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[FILE_MAX], const char *basepath) ATTR_NONNULL(1
#define STRNCPY(dst, src)
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
Scene * DEG_get_evaluated_scene(const Depsgraph *graph)
#define ID_BLEND_PATH_FROM_GLOBAL(_id)
#define DNA_struct_default_get(struct_name)
struct MeshCacheModifierData MeshCacheModifierData
@ MOD_MESHCACHE_INVERT_VERTEX_GROUP
@ eModifierType_MeshCache
@ MOD_MESHCACHE_DEFORM_INTEGRATE
@ MOD_MESHCACHE_PLAY_CFEA
@ MOD_MESHCACHE_TIME_FRAME
@ MOD_MESHCACHE_TIME_FACTOR
@ MOD_MESHCACHE_TIME_SECONDS
Object is a sort of wrapper for general info.
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 time_remapping_panel_draw(const bContext *, Panel *panel)
static void meshcache_do(MeshCacheModifierData *mcmd, Scene *scene, Object *ob, Mesh *mesh, float(*vertexCos_Real)[3], int verts_num)
ModifierTypeInfo modifierType_MeshCache
static bool depends_on_time(Scene *, ModifierData *md)
static void axis_mapping_panel_draw(const bContext *, Panel *panel)
static void panel_draw(const bContext *, Panel *panel)
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 **r_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 **r_err_str)
PanelType * modifier_subpanel_register(ARegionType *region_type, const char *name, const char *label, PanelDrawFn draw_header, PanelDrawFn draw, PanelType *parent)
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_get_vgroup(const Object *ob, const Mesh *mesh, const char *name, const MDeformVert **dvert, int *defgrp_index)
void uiLayoutSetRedAlert(uiLayout *layout, bool redalert)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
draw_view in_light_buf[] float
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)