-
Notifications
You must be signed in to change notification settings - Fork 2
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
VRM Importing #7
Comments
I think it would be worth linking this discussion from the Discord as well: https://discord.com/channels/1040316820650991766/1158258132435337266 It discusses the use of VRM metadata and licensing restrictions, and various ways that Resonite may be able to go about those in a way that is respectful to creators. |
From the perspective of writing a comprehensive guide article for Japanese people at Resonite and creating conversion software, I will write down the contents that may be necessary. LinksWhat is VRM?: https://vrm.dev/ VRM is available in 0.x and 1.0. You can differentiate them by checking the contents of gltf and seeing whether the add-on you have is "vrm" or "VRMC_vrm-1.0". About DataAs Prime mentioned, VRM is an extension of gltf. Therefore, I believe it's appropriate to initially read [.vrm] files as gltf2.0. Of course, it would be nice if all or a series of data could be loaded properly (for instance, a group of shape keys could be baked and added as expressions, requiring minimal modifications post-implementation. Or, avatar settings could appear in the position where they were initially set. It would be helpful if SpringBone settings could be roughly formatted as text, even if some are not compatible). |
As noted above- the only functional difference between VRM, and GLTF is the existence of licensing and other meta-data. As such, this issue is blocked by the implementation of a licensing system, e.g. #626. |
VRM also contains metadata relevant to avatar behavior, such as viewpoint positions, facial expressions, springbones, material configuration, etc… |
Licensing metadata is different in this case, and may not be trivial to really respect beyond the user acting in good faith. Basically our concept of a license is not likely to fully align with VRM's concept of a license. |
Good to know, @bdunderscore - I'd only previously heard about the licensing aspect of it. Adding support for those would require a much more involved/in-depth integration, as we'd have to somehow detect and map those things using equivalent components we have in Resonite. |
As mentioned above, VRM is not just a monolithic format, it is composed of many pieces, and all these pieces do a lot more than just licensing. Each
Therefore, VRM is not just one monolithic thing, it is a standard built out of many pieces. One does not necessarily have to implement the entirety of VRM. You can for example take the extension for VRM constraints and use it outside of VRM in a regular .glb file, as I did here. It makes sense to provide these general tools for any glTF model. The complete list of VRM extensions can be found here: https://github.com/vrm-c/vrm-specification/tree/master/specification This issue is highly related to #2778, since VRM is based on glTF. The same codebase can be used to import these files, optionally mixing and matching VRM and non-VRM features. |
I looked into this a little bit due to some business requirements in a nearby area. There's a lot of conflation that exists here between a variety of items, but we could split those up a bit. A suitable split might be:
Splitting it up a bit like that, may help to get some blockers moved aside. |
In the most basic sense, Resonite already supports VRM so long as you first rename the files to .GLB and I've done this dozens of times in the past. If you want to split it up and add format support piecemeal it can be done at the very most basic level by simply adding VRM to the glTF import extension list. Having support for the most relevant metadata components would be preferable long term however. |
Is your feature request related to a problem? Please describe.
VRM is an "all in one" file format for 3D Avatars that many platforms already support. There are lots of VRM tools and avatars out there.
VRM imports into Resonite are currently not fully supported. The underlying GLTF data can be looked at but other VRM features are ignored.
Describe the solution you'd like
I'd like Resonite to support the VRM standard for import/setup of avatars as closely as it can.
Describe alternatives you've considered
Extracting the GLTF data from a VRM is possible but much of the meta-data is lost.
Additional Context
I am pre-seeding the issue repository with commonly requested items to prevent those issues from being made as duplicates once open.
The text was updated successfully, but these errors were encountered: