-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add NameLookup Type to make looking up entities by name easier #5976
Conversation
I'm not sure if animations is the right place to put this, since it might belong in core or ecs (given that is could be used more generally, even if animations aren't enabled). |
Yep, I'd put this in core :) |
In or next to https://github.com/bevyengine/bevy/blob/main/crates/bevy_core/src/name.rs please! I would also like a few tests on those functions. |
After some analysis, I think it might be possible to remove |
Fantastic, I like the sounds of that direction. Can you make sure to update the PR description and title to match the actual work done in the PR when you're ready? |
That's actually not possible because an The scenario you're describing would only work for an animation on only one scene, but would break if one was to spawn the same scene multiple time and reuse the same animation. Also, it's often the case to distribute animations and models in different gltf files, in which case there are no knowledge shared of entities. |
I'm not sure how to distribute animations and models between multiple gltf files, especially since the gltf format uses indicies internally. I guess maybe you could duplicate the bones into a separate files, but I'm not sure how common this actually is. I'm not a fan of the current name based approach, and I don't think applying the same animation to several entity hierarchies is necessarily worth while. That being said, it is something I'm going to have think about. Spawning the same scene multiple times is a major issue though. I see things like Overall, I don't like the name approach, and I would like to come up with a better option. I'm going to mark this as a draft for now, but I'd like to tackle this. |
You should look at bevyengine/rfcs#49 (and bevyengine/rfcs#51 while you're there) |
5373380
to
54cba7a
Compare
After careful reflection, I've chosen to revert back to my original goal with this PR, and open a new PR when and if I have a more complete solution. For now, I'm looking at contributing to the discussion around the RFCs listed above. |
CI seems to be lost with your force pushes. Could you push a new commit to trigger it? |
At this point, I'm still looking into writing tests, so it's not quite ready. I think the actual issue is that my branch is out of date, and CI is does a merge with master before running tests. |
@the10thWiz do you have the time to drive this PR to completion? This would be super useful in simplifying our animation code, and I'd like to see it completed. If not, we can mark this PR up for adoption, your commit history and credit to you will be retained. |
Removing the Animation label since animation is no longer reliant on name lookups after #11707. |
Backlog cleanup: closing due to inactivity, and in favour of #11842 which itself is a little stalled right now. If Discord wills it, I'll create a tracking issue. |
Objective
Looking up an entity by name is somewhat difficult, and only done within
bevy_animation
. The actual code is difficult to read, and outside crates also have a need to lookup entities by name. To facilitate an easier interface, I've created aNameLookup
type (which implements SystemParam), and provided a few methods for looking up entities.Motivation
I'm currently working on a Inverse Kinematics solver for Bevy, which requires the ability to lookup bones in an armature by name (in the same way an animation does).
Solution
I've provided an implementation of a
NameLookup
type, which implementsSystemParam
.The interface is roughly:
This also avoids the need to use loop labels (sort of a goto), be refactoring into multiple methods.
There is a note in the current code that lookup by EntityPath can be optimized for better performance. By refactoring it into an independent method, we isolate the lookup itself, and allow benchmarking & testing of the lookup code independent of the rest of the animation logic. Because this is also a public type, external crates can also benefit from performance improvements. Finally, this is also a unified place to implement caching (if possible), to avoid repeated lookups.