Skip to content

Commit

Permalink
Merge pull request #90517 from TokageItLab/cache-bones-mod
Browse files Browse the repository at this point in the history
Static allocation bones copy for SkeletonModifier
  • Loading branch information
akien-mga committed May 4, 2024
2 parents a2fc5e2 + a22923d commit a5d4ddc
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 28 deletions.
23 changes: 6 additions & 17 deletions scene/3d/skeleton_3d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,8 @@ void Skeleton3D::_update_process_order() {
}
}

bones_backup.resize(bones.size());

process_order_dirty = false;

emit_signal("bone_list_changed");
Expand Down Expand Up @@ -310,19 +312,10 @@ void Skeleton3D::_notification(int p_what) {

// Process modifiers.
_find_modifiers();
LocalVector<Transform3D> current_bone_poses;
LocalVector<Vector3> current_pose_positions;
LocalVector<Quaternion> current_pose_rotations;
LocalVector<Vector3> current_pose_scales;
LocalVector<Transform3D> current_bone_global_poses;
if (!modifiers.is_empty()) {
// Store unmodified bone poses.
for (int i = 0; i < len; i++) {
current_bone_poses.push_back(bones[i].pose_cache);
current_pose_positions.push_back(bones[i].pose_position);
current_pose_rotations.push_back(bones[i].pose_rotation);
current_pose_scales.push_back(bones[i].pose_scale);
current_bone_global_poses.push_back(bones[i].global_pose);
for (int i = 0; i < bones.size(); i++) {
bones_backup[i].save(bones[i]);
}
_process_modifiers();
}
Expand Down Expand Up @@ -388,12 +381,8 @@ void Skeleton3D::_notification(int p_what) {

if (!modifiers.is_empty()) {
// Restore unmodified bone poses.
for (int i = 0; i < len; i++) {
bonesptr[i].pose_cache = current_bone_poses[i];
bonesptr[i].pose_position = current_pose_positions[i];
bonesptr[i].pose_rotation = current_pose_rotations[i];
bonesptr[i].pose_scale = current_pose_scales[i];
bonesptr[i].global_pose = current_bone_global_poses[i];
for (int i = 0; i < bones.size(); i++) {
bones_backup[i].restore(bones.write[i]);
}
}

Expand Down
37 changes: 26 additions & 11 deletions scene/3d/skeleton_3d.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,15 +88,15 @@ class Skeleton3D : public Node3D {
struct Bone {
String name;

int parent;
int parent = -1;
Vector<int> child_bones;

Transform3D rest;
Transform3D global_rest;

bool enabled;
Transform3D pose_cache;
bool enabled = true;
bool pose_cache_dirty = true;
Transform3D pose_cache;
Vector3 pose_position;
Quaternion pose_rotation;
Vector3 pose_scale = Vector3(1, 1, 1);
Expand All @@ -116,15 +116,29 @@ class Skeleton3D : public Node3D {
bool global_pose_override_reset = false;
Transform3D global_pose_override;
#endif // _DISABLE_DEPRECATED
};

Bone() {
parent = -1;
child_bones = Vector<int>();
enabled = true;
#ifndef DISABLE_DEPRECATED
global_pose_override_amount = 0;
global_pose_override_reset = false;
#endif // _DISABLE_DEPRECATED
struct BonePoseBackup {
Transform3D pose_cache;
Vector3 pose_position;
Quaternion pose_rotation;
Vector3 pose_scale = Vector3(1, 1, 1);
Transform3D global_pose;

void save(const Bone &p_bone) {
pose_cache = p_bone.pose_cache;
pose_position = p_bone.pose_position;
pose_rotation = p_bone.pose_rotation;
pose_scale = p_bone.pose_scale;
global_pose = p_bone.global_pose;
}

void restore(Bone &r_bone) {
r_bone.pose_cache = pose_cache;
r_bone.pose_position = pose_position;
r_bone.pose_rotation = pose_rotation;
r_bone.pose_scale = pose_scale;
r_bone.global_pose = global_pose;
}
};

Expand Down Expand Up @@ -156,6 +170,7 @@ class Skeleton3D : public Node3D {
void _process_modifiers();
void _process_changed();
void _make_modifiers_dirty();
LocalVector<BonePoseBackup> bones_backup;

#ifndef DISABLE_DEPRECATED
void _add_bone_bind_compat_88791(const String &p_name);
Expand Down

0 comments on commit a5d4ddc

Please sign in to comment.