Added a new bones_updated signal to Skeleton.

This commit is contained in:
Relintai 2022-08-10 12:42:04 +02:00
parent 49f76407ba
commit b352060a62

View File

@ -213,20 +213,23 @@ void Skeleton::_update_process_order() {
} }
process_order_dirty = false; process_order_dirty = false;
emit_signal("bones_updated");
} }
void Skeleton::_notification(int p_what) { void Skeleton::_notification(int p_what) {
switch (p_what) { switch (p_what) {
case NOTIFICATION_UPDATE_SKELETON: { case NOTIFICATION_UPDATE_SKELETON: {
// Update bone transforms
force_update_all_bone_transforms();
VisualServer *vs = VisualServer::get_singleton(); VisualServer *vs = VisualServer::get_singleton();
Bone *bonesptr = bones.ptrw(); Bone *bonesptr = bones.ptrw();
int len = bones.size(); int len = bones.size();
dirty = false; dirty = false;
// Update bone transforms
force_update_all_bone_transforms();
//update skins //update skins
for (Set<SkinReference *>::Element *E = skin_bindings.front(); E; E = E->next()) { for (Set<SkinReference *>::Element *E = skin_bindings.front(); E; E = E->next()) {
const Skin *skin = E->get()->skin.operator->(); const Skin *skin = E->get()->skin.operator->();
@ -544,6 +547,8 @@ void Skeleton::set_bone_parent(int p_bone, int p_parent) {
bones.write[p_bone].parent = p_parent; bones.write[p_bone].parent = p_parent;
process_order_dirty = true; process_order_dirty = true;
version++;
_make_dirty(); _make_dirty();
} }
@ -561,6 +566,7 @@ void Skeleton::unparent_bone_and_rest(int p_bone) {
bones.write[p_bone].parent = -1; bones.write[p_bone].parent = -1;
process_order_dirty = true; process_order_dirty = true;
version++;
_make_dirty(); _make_dirty();
} }
@ -596,6 +602,7 @@ void Skeleton::set_bone_children(int p_bone, Vector<int> p_children) {
bones.write[p_bone].child_bones = p_children; bones.write[p_bone].child_bones = p_children;
process_order_dirty = true; process_order_dirty = true;
version++;
_make_dirty(); _make_dirty();
} }
@ -606,6 +613,8 @@ void Skeleton::add_bone_child(int p_bone, int p_child) {
bones.write[p_bone].child_bones.push_back(p_child); bones.write[p_bone].child_bones.push_back(p_child);
process_order_dirty = true; process_order_dirty = true;
version++;
_make_dirty(); _make_dirty();
} }
@ -621,6 +630,7 @@ void Skeleton::remove_bone_child(int p_bone, int p_child) {
} }
process_order_dirty = true; process_order_dirty = true;
version++;
_make_dirty(); _make_dirty();
} }
@ -1340,6 +1350,7 @@ void Skeleton::_bind_methods() {
//#endif // TOOLS_ENABLED //#endif // TOOLS_ENABLED
ADD_SIGNAL(MethodInfo("bone_pose_changed", PropertyInfo(Variant::INT, "bone_idx"))); ADD_SIGNAL(MethodInfo("bone_pose_changed", PropertyInfo(Variant::INT, "bone_idx")));
ADD_SIGNAL(MethodInfo("bones_updated"));
BIND_CONSTANT(NOTIFICATION_UPDATE_SKELETON); BIND_CONSTANT(NOTIFICATION_UPDATE_SKELETON);