Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/omigroup/gltf-extensions
This repository is used by OMI to develop and document extensions for the gLTF 3D transmission format.
https://github.com/omigroup/gltf-extensions
Last synced: 2 months ago
JSON representation
This repository is used by OMI to develop and document extensions for the gLTF 3D transmission format.
- Host: GitHub
- URL: https://github.com/omigroup/gltf-extensions
- Owner: omigroup
- License: other
- Created: 2021-07-14T20:46:24.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-14T00:22:28.000Z (9 months ago)
- Last Synced: 2024-04-14T05:39:37.463Z (9 months ago)
- Homepage:
- Size: 7.87 MB
- Stars: 42
- Watchers: 10
- Forks: 9
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-v-sekai - GLTF Extensions
README
# OMI glTF Extensions
This repository is used by the [Open Metaverse Interoperability Group](https://omigroup.org/) to develop and document extensions for the [glTF 3D model format](https://github.com/KhronosGroup/glTF/blob/master/specification/2.0/README.md).
Extensions in this repository are intended to extend the glTF format with features useful for 3D virtual worlds. These extensions could include things related audio, physics, avatars, animations, behaviors, and more.
Vendor extensions are developed and approved via the W3C Metaverse Interoperability Community Group [process](https://github.com/omigroup/OMI/blob/main/PROCESS.md). Our intentions are to create OMI specific vendor extensions, but common extensions that make sense within the greater glTF community may be proposed to the Khronos 3D Formats Working Group at a later date. Our goal with this repository is to prototype and standardize extensions useful for the portability of 3D metaverse media.
## Meetings
OMI's glTF extensions subgroup weekly meetings take place each week on Thursday in the omi-weekly-meeting channel on the [OMI Discord](https://discord.gg/J4vyAWFgkj).
This is the time to chat about glTF extensions with OMI, including those developed by OMI and those developed by other groups. You can find the weekly notes and agenda [here](https://github.com/omigroup/gltf-extensions/discussions).
These meetings take place at 22:30 UTC in the winter (2:30 PM PST) and 21:30 UTC in the summer (2:30 PM PDT).
You can add these meetings to your calendar [here](https://calendar.google.com/calendar/u/1?cid=Y18wZHB1Z2Y5ZjgzZXE0cWVrbWI2b21xYmptZ0Bncm91cC5jYWxlbmRhci5nb29nbGUuY29t).
## Working agreement
Our sub-group has drafted a working agreement that highlights who we are, our purpose, how we communicate, and when we meet. Working agreements are living documents meant to be revisited and revised as needed. To view our working agreement, please visit this [figjam by figma file](https://www.figma.com/file/ns8eBTPfq330lZR3DfsOvD/OMI-gLTFgroup-WorkingAgreement?node-id=0%3A1)
## glTF Working Group Mission
We aim to create an ecosystem of specifications and tooling for accessible creation and use of durable and portable 3D content.
## OMI glTF Working Group Process
OMI uses 5 stages to represent the maturity of an extension:
### Stage 1
A draft proposal has been submitted to the working group and is receiving feedback. It must have at least one "champion" who are responsible for advancing the proposal to the further stages. At this stage a high-level outline of the extension should be published as a GitHub Pull Request to this repository. The champion(s) should be focused on describing why this extension should be developed further and they should be working on finding additional stakeholders. The [W3C Community Contributor License Agreement](https://www.w3.org/community/about/process/cla/) must be signed by all contributors before the proposal can enter Stage 1.
#### Requirements
- [ ] High level outline published as a GitHub PR in this repository
- [ ] [Signed W3C CLA](https://www.w3.org/community/about/process/cla/)### Stage 2
The draft proposal should precisely describe the extension in it's initial form and there should be at least one metaverse implementation of the extension in development and valid sample assets for testing by other potential implementors. The proposal should contain valid a JSON schema describing the extension in its entirety as well as a markdown document explaining the purpose, features, and properties of the extension. This implementation will be used to test the viability of the extension and provide an example for other implementors. Edits to the extension should be voted on and decided by consensus in weekly OMI glTF Working Group meetings.
#### Requirements
- [ ] Previous requirements from Stage 1
- [ ] One metaverse implementation of the extension in development.
- [ ] Valid and publicly acessible sample assets
- [ ] Valid JSON schema describing the extension in its entirety
- [ ] Markdown document explaining the purpose, features, and properties of the extension### Stage 3
The extension has multiple metaverse implementations, a glTF Validator implementation, valid sample assets, and at least one readily available tool for generating content using this extension. The implementations, sample assets, and content creation tool should all consume or produce assets that can be verified by the glTF Validator. The extension at this stage is ready for a vote for ratification. Final proposal modifications should be voted on and decided by consensus in weekly OMI glTF Working Group meetings.
#### Requirements
- [ ] Previous requirements from Stage 2
- [ ] Two or more metaverse implementations
- [ ] glTF Validator implementation
- [ ] Publicly availible content creation tool for generating assets for this extension
- [ ] All implementations, sample assets, and content creation tools should consume or produce assets that pass validation.### Stage 4
The extension has been ratified. It has multiple metaverse implementations, a glTF Validator implementation, valid sample assets, and at least one readily available tool for generating content using this extension. Once ratified, non-substantive changes to a specification via a consensus vote. However, breaking changes to an extension are not allowed and should be addressed by creating a proposal for a new extension with a different extension identifier.
#### Requirements
- [ ] Previous requirements from Stage 3
- [ ] The extension has passed a consensus vote for ratification.### Stage 5
The extension has been submitted and merged as an OMI vendor extension. Alternately, if the extension is intended to be used outside the scope of OMI, it can be submitted and ratified as a KHR or EXT extension. The extension must be published to the [Khronos 3D Formats Working Group](https://github.com/KhronosGroup/glTF) repository to enter stage 5.
#### Requirements
- [ ] Previous requirements from Stage 4
- [ ] Listing on the [Khronos glTF repository](https://github.com/KhronosGroup/glTF/tree/main/extensions) proving the extension has been approved or ratified.## OMI glTF Vendor Extensions
### Stage 0
### Stage 1
- [OMI_audio_ogg_vorbis](extensions/2.0/OMI_audio_ogg_vorbis)
- [OMI_audio_opus](extensions/2.0/OMI_audio_opus)
- [OMI_link](extensions/2.0/OMI_link)
- [OMI_personality](extensions/2.0/OMI_personality)
- [OMI_physics_body](extensions/2.0/OMI_physics_body/README.md)
- [OMI_physics_gravity](extensions/2.0/OMI_physics_gravity/README.md)
- [OMI_physics_joint](extensions/2.0/OMI_physics_joint/README.md)
- [OMI_physics_shape](extensions/2.0/OMI_physics_shape/README.md)
- [OMI_spawn_point](extensions/2.0/OMI_spawn_point)### Stage 2
- [OMI_seat](extensions/2.0/OMI_seat/README.md)
### Stage 3
### Stage 4
### Stage 5
### Graduated to Khronos Extension
- [KHR_audio_emitter](https://github.com/KhronosGroup/glTF/pull/2137)
### Archived Extensions
- [OMI_collider](extensions/2.0/Archived/OMI_collider): Superseded by [OMI_physics_shape](extensions/2.0/OMI_physics_shape)
### Extension Support Table
Extension
Stage
glTF Validator
Blender
Three.js
Godot
Unity
Third Room
3OV
Import
Export
Loader
Exporter
Import
Export
Runtime Import
Runtime Export
Editor Import
Editor Export
KHR_audio_emitter
KHR
❌
❌
❌
🚧🏆
❌
🚧🏆
🚧🏆
❌
❌
❌
❌
🚧🏆
🚧🏆
OMI_audio_ogg_vorbis
Stage 1
❌
❌
❌
❌
❌
🚧🏆
❌
❌
❌
❌
❌
❌
❌
OMI_audio_opus
Stage 1
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
OMI_link
Stage 1
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
OMI_personality
Stage 1
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
❌
OMI_physics_body
Stage 1
❌
❌
❌
❌
❌
✅🏆
✅🏆
❌
❌
❌
❌
❌
❌
OMI_physics_gravity
Stage 1
❌
❌
❌
❌
❌
🚧🧩
🚧🧩
❌
❌
❌
❌
❌
❌
OMI_physics_joint
Stage 1
❌
❌
❌
❌
❌
✅🧩
✅🧩
❌
❌
❌
❌
❌
❌
OMI_physics_shape
Stage 1
❌
❌
❌
❌
❌
✅🏆
✅🏆
❌
❌
❌
❌
❌
❌
OMI_seat
Stage 2
❌
❌
❌
❌
❌
✅🧩
🚧🧩
❌
❌
❌
❌
❌
❌
OMI_spawn_point
Stage 1
❌
❌
❌
❌
❌
✅🧩
❌
❌
❌
❌
❌
❌
✅🏆
Emoji Key:
- ✅ = Done, available and ready to use.
- 🏆 = Available directly in the engine.
- 🧩 = Available as a plugin / add-on.
- 🚧 = Work in progress or not yet merged.
- ❌ = Not available or not started.