Check skeleton RID when using cached AABB
This commit is contained in:
parent
2d0ee20ff3
commit
d874ead58d
2 changed files with 4 additions and 1 deletions
|
@ -657,7 +657,8 @@ AABB MeshStorage::mesh_get_aabb(RID p_mesh, RID p_skeleton) {
|
||||||
|
|
||||||
Skeleton *skeleton = skeleton_owner.get_or_null(p_skeleton);
|
Skeleton *skeleton = skeleton_owner.get_or_null(p_skeleton);
|
||||||
|
|
||||||
if (!skeleton || skeleton->size == 0 || mesh->skeleton_aabb_version == skeleton->version) {
|
// A mesh can be shared by multiple skeletons and we need to avoid using the AABB from a different skeleton.
|
||||||
|
if (!skeleton || skeleton->size == 0 || (mesh->skeleton_aabb_version == skeleton->version && mesh->skeleton_aabb_rid == p_skeleton)) {
|
||||||
return mesh->aabb;
|
return mesh->aabb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -763,6 +764,7 @@ AABB MeshStorage::mesh_get_aabb(RID p_mesh, RID p_skeleton) {
|
||||||
mesh->aabb = aabb;
|
mesh->aabb = aabb;
|
||||||
|
|
||||||
mesh->skeleton_aabb_version = skeleton->version;
|
mesh->skeleton_aabb_version = skeleton->version;
|
||||||
|
mesh->skeleton_aabb_rid = p_skeleton;
|
||||||
return aabb;
|
return aabb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -153,6 +153,7 @@ private:
|
||||||
AABB aabb;
|
AABB aabb;
|
||||||
AABB custom_aabb;
|
AABB custom_aabb;
|
||||||
uint64_t skeleton_aabb_version = 0;
|
uint64_t skeleton_aabb_version = 0;
|
||||||
|
RID skeleton_aabb_rid;
|
||||||
|
|
||||||
Vector<RID> material_cache;
|
Vector<RID> material_cache;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue