-
-
Notifications
You must be signed in to change notification settings - Fork 21.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
Implement Animation Libraries #59980
Conversation
|
8fc1031
to
1e4343d
Compare
Alright, its now ready for review. |
e37b86e
to
13f0cfa
Compare
It would be great to see an example of real-life use and how it will improve there. I am a bit afraid that many users won't care or really look into this feature until it's too late ( and there is a total mess in the library). My second fear is that in a bigger project, this will be absolutely cluttered and the animation library window will be unusable at some point. How is this management handled? Maybe I also didn't grasp how libraries interact with the Animation Player. |
@RPicster If you don't really want to use the libraries, you don't use them and it just works the same as before (everything is put into the "default" library without you doing anything). This is majorly optional for those who want to take advantage of it. |
I am wondering if these animation libraries could support blend spaces as well across all its animations. |
Reposting this from my twitter comment: For duplicate names - maybe there could be a way to change which library the player "prioritizes" during conflicts? Instead of always going alphabetical/etc. Seems like it'd be a nice way to "swap out" certain animations for stuff like multiple types of weapons. |
Matching animation names are no longer necessarily "conflicts" when a new layer of abstraction (libraries) is added, they could be an intentional design decision. Rather than simply using the first option found in alphabetical order (which is unlikely to be what the user expects and intends), perhaps Godot should have a way of specifying the library to be used in that case or give an error when unspecified? Maybe have AnimationPlayer.play use the default behavior when the first parameter is a string, but when an array is used, the first element refers to the library? |
Many systems do use |
Is there a reason why duplicate names can't be treated the same way they are in the editor? E.g. when two scenes are open with the same name the editor shows their full path so you can differentiate them: /library_one/jump |
One solution to this is to allow using a NodePath-like syntax for identifying animations, like this: |
Or make libraries Nodes (which have to be children of an AnimationPlayer) and move the play method to libraries, keeping AnimationPlayer.play() as a proxy for the play method for the default library. Then you could just use the normal path syntax and it's always explicit whether you want to use a library or not:
|
But when I have ten different things using the animation name "explosion", I would run into the duplicate names issue from my understanding? |
@RPicster the libraries are local to the player, they are not global, so I doubt you will have 10 explosions in the same player. |
@fire-forge @kennethrapp I already considered something like this, the problem is that, for the most part users are not forced to use libraries, so since you now have to always use the libraries it may get a bit difficult. An alternative could be to assume you have a default animation library ("") so those are compatible with the current way of using it (just the name) but if the library has a name, you have to supply it, like libname/animation. Would this work better? |
@reduz Well, then the library name could be optional. If they user adds the For example, if you have multiple libraries with a "walk" animation, you can tell it which one to use: animation_player.play("library_name/walk") If you only have 1 library with a "walk" animation, you can use the same syntax that's currently used: animation_player.play("walk") That way, nothing is changed for most users who are using only one AnimationLibrary per AnimationPlayer, but it gives more control to those who use multiple libraries. |
Lets do this then, I will make it so the "" library is the global one, and the others you will access as library/. If you don't want to use libraries, then its assumed that you want to use the global one automatically, otherwise you have to specify the name. This sounds like it should solve the problem, is more elegant and there should be no collisions. I will work on doing the changes. |
BTW, I think the breaks compat label is not right. At least old scenes can be opened and the Animations are just grouped in the GlobalAnimationLibrary. |
854d999
to
ada950d
Compare
Alright, should be finally good to merge now. |
ada950d
to
798dfea
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good. I couldn't find major issues. Posted some small issues. The major reviewer is tokage and he found some crashes earlier. I need to see it in a system to test further.
@fire The crashes he found should be solved now |
I have confirmed that the crash has already been fixed, so unless there are other problems, I think this can be merged. |
Are there any plans to backport this feature to 3.x? |
bde5dbe
to
a4369cb
Compare
* Instead of containing single animations, AnimationPlayer now contains libraries. * Libraries, in turn, contain the animations. This paves the way for implementing the possibility of importing scenes as animation libraries, finally allowing to import animations separate from the 3D models. Missing (will be done on separate PRs): * Make it possible to import scenes (dae/fbx/gltf) as animation libraries. * Make it possible for AnimationTree to import animation libraries on its own, so it does not rely on AnimationPlayer for everything.
a4369cb
to
6f40143
Compare
Thanks! |
@Deozaan there are no plans because this work is a part of animation retargeting proposal and to achieve that we've had to significantly change Godot Engine's animation systems. That said, if someone does the work and figures out that the 3.x changes don't break compatibility, maybe it'll be reviewable, but we haven't estimated the work. |
Implements: godotengine/godot-proposals#4296
This paves the way for implementing the possibility of importing scenes as animation libraries, finally allowing to import animations separate from the 3D models.
Missing (will be done on separate PRs):
Screenshots:
Animation Menu simplified, now has a Manage Animations option:
data:image/s3,"s3://crabby-images/44e9f/44e9f36a624965ecc7978331e51bef6053253e3f" alt="image"
data:image/s3,"s3://crabby-images/70ce8/70ce8db8f2471ed7475d03d8454915eca40a5a01" alt="image"
data:image/s3,"s3://crabby-images/3eff0/3eff0ac27a065414af9fbb0423005bc9d9fe41a3" alt="image"
This opens the library manager:
List of animations also shows libraries if multiple ones exist (otherwise ignore it):
Thanks to @tihmas, @fire-forge and @kennethrapp for feedback on adjusting the implementation.
Bonus tracks: