Skip to content
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

Open
ProbablePrime opened this issue Oct 12, 2023 · 9 comments
Open

VRM Importing #7

ProbablePrime opened this issue Oct 12, 2023 · 9 comments
Assignees
Labels
New Feature A new addition, whose complexity hasn't been evaluated yet

Comments

@ProbablePrime
Copy link
Member

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.

@ProbablePrime ProbablePrime added the New Feature A new addition, whose complexity hasn't been evaluated yet label Oct 12, 2023
@Casuallynoted
Copy link

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.

@shiftyscales shiftyscales removed their assignment Oct 16, 2023
@Frooxius Frooxius self-assigned this Oct 17, 2023
@kazu0617
Copy link

kazu0617 commented Nov 1, 2023

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.

Links

What is VRM?: https://vrm.dev/
Article on how to implement VRM based on Japanese sources (I share this article as a reference. Keep in mind that most of the data will be missing when read as gltf): https://sharedx.notion.site/VRM-d93c6e3ae2f647e0956054efff1d20b9?pvs=4
About the Version

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 Data

As 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).

@shiftyscales
Copy link
Collaborator

shiftyscales commented Jan 23, 2024

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.

@bdunderscore
Copy link

VRM also contains metadata relevant to avatar behavior, such as viewpoint positions, facial expressions, springbones, material configuration, etc…

@Geenz
Copy link
Collaborator

Geenz commented Jan 23, 2024

As noted above- the only functional difference between VRM, and GLTF is the existence of licensing meta-data. As such, this issue is blocked by the implementation of a licensing system, e.g. #626.

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.

@shiftyscales
Copy link
Collaborator

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.

@aaronfranke
Copy link

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 .vrm file is really a .glb file with VRM-specific glTF extensions, including:

  • Node constraints: Allows controlling the notation of one node/bone based on another. Can be used to implement things like digitigrade legs, taur legs, and multi-arm characters, but could also be used outside of characters.
  • Spring bones: Allows for nodes/bones to spring/jiggle. Can be used to implement things like floppy ears or a dynamic tail on a furry character, but could also be used outside of characters.
  • Toon materials: Allows for a less realistic toon look for meshes, usually characters, but could be other objects too.
  • Animations: Allows expressions and animations to be defined on an avatar.
  • Bone mapping: The base VRM extension requires a humanoid bone map, similar to Unity's bone map menu.
  • First person: The base VRM extension allows defining things to hide when in first person, like hiding the mesh of the head/glasses/etc when in VR but still allowing you to look down and see your body.
  • Meta: The base VRM extension defines metadata like licensing information. Also note, there is some overlap with Khronos's own KHR_xmp_json_ld extension for copyright metadata (see spec and Godot implementation).

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.

@ProbablePrime
Copy link
Member Author

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:

  1. Fixing up any remaining GLTF issues, such as Support importing .glb files compressed with Draco #155
  2. Hooking up Resonite to just import vrm as GLTF without processing the meta-data at all
  3. Incorporating any suitable metadata on import that might be helpful
    • Hierarchy issues can be helped. if the meta data tells us which bones to do (based on bone mapping above)
    • Conversion between spring bones and dynamic bones
    • View point
    • hand location etc
  4. After we have license system, honoring the meta-data of the VRM license data

Splitting it up a bit like that, may help to get some blockers moved aside.

@ko-tengu
Copy link

ko-tengu commented Dec 5, 2024

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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
New Feature A new addition, whose complexity hasn't been evaluated yet
Projects
None yet
Development

No branches or pull requests

9 participants