From cffd1e1446285191779044b058ca98422127083a Mon Sep 17 00:00:00 2001
From: Leon van Kammen
Vendor Prefixes (XRFVP’s) allows embedding a 3D file with popular 3D engines/framework-specific features via metadata:
+Vendor-specific metadata in a 3D scenefiles, are similar to vendor-specific CSS-prefixes (-moz-opacity: 0.2
e.g.).
+This allows popular 3D engines/frameworks, to initialize specific features when loading a scene/object, in a progressive enhanced way.
Vendor Prefixes allows embedding 3D engines/framework-specific features a 3D file via metadata:
XR Fragments | +CSS | vendor-agnostic | -camera + 3D object(file) load/embed/click/referencing | +2D canvas + object referencing/styling |
XR Fragments VP’s | +XR Fragments | +vendor-agnostic | +3D camera + object(file) load/embed/click/referencing | +|
Vendor prefixs | vendor-specific | -Entity-Component System (ECS) | +Specialized Entity-Component implementation |
Vendor-specific metadata in a 3D scenefiles, are similar to vendor-specific CSS-prefixes (-moz-opacity: 0.2
e.g.).
-This allows popular 3D engines/frameworks, to initialize specific features when loading a scene/object, in a progressive enhanced way.
-Why? Because not all XR interactions can be solved/standardized by embedding XR Fragments into any 3D file. -Some XR experiences need more than navigation and show/hide/filtering of objects (via click-state machines). -The lowest common denominator between s that 3D engines use entity-component-system
+Why? Because not all XR interactions can/should be solved/standardized by embedding XR Fragments into any 3D file. +The lowest common denominator between 3D engines is the ‘entity’-part of their entity-component-system (ECS). The ‘component’-part can be progressively enhanced via vendor prefixes.
For example, the following metadata can be added to a .glb file, to make an object grabbable in AFRAME:
@@ -1563,11 +1569,11 @@ The lowest common denominator between s that 3D engines use entity-component-sys │ [3D mesh-+ | // save to z.glb in AFRAME inspector │ │ | ├─ name: john | │ │ | O ├─ age: 23 | │ -│ | /|\ ├─ -AFRAME-grabbable: '' | > inits 'grabbable' component on object john │ -│ | / \ ├─ -AFRAME-material.color: '#F0A' | > inits 'material' component on object john │ -│ | ├─ -AFRAME-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ -│ | ├─ -THREE-material.fog: false | > changes material settings in THREE.js app │ -│ | ├─ -GODOT-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ +│ | /|\ ├─ -aframe-grabbable: '' | > inits 'grabbable' component on object john │ +│ | / \ ├─ -aframe-material.color: '#F0A' | > inits 'material' component on object john │ +│ | ├─ -aframe-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ +│ | ├─ -three-material.fog: false | > changes material settings in THREE.js app │ +│ | ├─ -godot-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ │ +--------+ | │ │ | │ ├─ -AFRAME-version: '1.6.0' | > │ diff --git a/doc/RFC_XR_Fragments.md b/doc/RFC_XR_Fragments.md index 9e7ea06..0fe8293 100644 --- a/doc/RFC_XR_Fragments.md +++ b/doc/RFC_XR_Fragments.md @@ -955,21 +955,21 @@ Therefore a 2-button navigation-interface is the bare minimum interface: 2. objects with href metadata can be activated via a key (enter on a keyboard) 3. the TTS reads the href-value (and/or aria-description if available) -## XR Fragment Vendor Prefixes - -Vendor Prefixes (XRFVP's) allows embedding a 3D file with popular 3D engines/framework-specific features via metadata: - -| what | XR metadata | Lowest common denominator | -|------------------|---------------------|-------------------------------------------------------| -| XR Fragments | vendor-agnostic | camera + 3D object(file) load/embed/click/referencing | -| XR Fragments VP's| vendor-**specific** | Entity-Component System (ECS) | +## Vendor Prefixes Vendor-specific metadata in a 3D scenefiles, are similar to vendor-specific [CSS-prefixes](https://en.wikipedia.org/wiki/CSS#Vendor_prefixes) (`-moz-opacity: 0.2` e.g.). This allows popular 3D engines/frameworks, to initialize specific features when loading a scene/object, in a progressive enhanced way. -> Why? Because not all XR interactions can be solved/standardized by embedding XR Fragments into any 3D file. -Some XR experiences need more than **navigation** and **show/hide/filtering** of objects (via click-state machines). -The lowest common denominator between s that 3D engines use entity-component-system +Vendor Prefixes allows embedding 3D engines/framework-specific features a 3D file via metadata: + +| what | XR metadata | Lowest common denominator | +|------------------|---------------------|-------------------------------------------------------| +| CSS | vendor-agnostic | 2D canvas + object referencing/styling | +| XR Fragments | vendor-agnostic | 3D camera + object(file) load/embed/click/referencing | +| Vendor prefixs | vendor-**specific** | Specialized Entity-Component implementation | + +> Why? Because not all XR interactions can/should be solved/standardized by embedding XR Fragments into any 3D file. +The lowest common denominator between 3D engines is the 'entity'-part of their entity-component-system (ECS). The 'component'-part can be progressively enhanced via vendor prefixes. For example, the following metadata can be added to a .glb file, to make an object grabbable in AFRAME: @@ -992,11 +992,11 @@ For example, the following metadata can be added to a .glb file, to make an obje │ [3D mesh-+ | // save to z.glb in AFRAME inspector │ │ | ├─ name: john | │ │ | O ├─ age: 23 | │ -│ | /|\ ├─ -AFRAME-grabbable: '' | > inits 'grabbable' component on object john │ -│ | / \ ├─ -AFRAME-material.color: '#F0A' | > inits 'material' component on object john │ -│ | ├─ -AFRAME-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ -│ | ├─ -THREE-material.fog: false | > changes material settings in THREE.js app │ -│ | ├─ -GODOT-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ +│ | /|\ ├─ -aframe-grabbable: '' | > inits 'grabbable' component on object john │ +│ | / \ ├─ -aframe-material.color: '#F0A' | > inits 'material' component on object john │ +│ | ├─ -aframe-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ +│ | ├─ -three-material.fog: false | > changes material settings in THREE.js app │ +│ | ├─ -godot-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ │ +--------+ | │ │ | │ ├─ -AFRAME-version: '1.6.0' | > │ diff --git a/doc/RFC_XR_Fragments.txt b/doc/RFC_XR_Fragments.txt index 7abb504..e3f3ae9 100644 --- a/doc/RFC_XR_Fragments.txt +++ b/doc/RFC_XR_Fragments.txt @@ -118,7 +118,7 @@ Internet-Draft XR Fragments September 2024 23. Additional scene metadata . . . . . . . . . . . . . . . . . . 32 24. Accessibility interface . . . . . . . . . . . . . . . . . . . 33 24.1. Two-button navigation . . . . . . . . . . . . . . . . . 34 - 24.2. XR Fragment Vendor Prefixes . . . . . . . . . . . . . . 35 + 24.2. Vendor Prefixes . . . . . . . . . . . . . . . . . . . . 35 25. Security Considerations . . . . . . . . . . . . . . . . . . . 37 26. FAQ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 27. authors . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 @@ -1906,22 +1906,7 @@ van Kammen Expires 24 March 2025 [Page 34] Internet-Draft XR Fragments September 2024 -24.2. XR Fragment Vendor Prefixes - - Vendor Prefixes (XRFVP's) allows embedding a 3D file with popular 3D - engines/framework-specific features via metadata: - - +==============+===================+==============================+ - | what | XR metadata | Lowest common denominator | - +==============+===================+==============================+ - | XR Fragments | vendor-agnostic | camera + 3D object(file) | - | | | load/embed/click/referencing | - +--------------+-------------------+------------------------------+ - | XR Fragments | vendor-*specific* | Entity-Component System | - | VP's | | (ECS) | - +--------------+-------------------+------------------------------+ - - Table 14 +24.2. Vendor Prefixes Vendor-specific metadata in a 3D scenefiles, are similar to vendor- specific CSS-prefixes (https://en.wikipedia.org/wiki/ @@ -1929,11 +1914,29 @@ Internet-Draft XR Fragments September 2024 3D engines/frameworks, to initialize specific features when loading a scene/object, in a progressive enhanced way. - | Why? Because not all XR interactions can be solved/standardized - | by embedding XR Fragments into any 3D file. Some XR experiences - | need more than *navigation* and *show/hide/filtering* of objects - | (via click-state machines). The lowest common denominator between - | s that 3D engines use entity-component-system + Vendor Prefixes allows embedding 3D engines/framework-specific + features a 3D file via metadata: + + +===========+===================+==============================+ + | what | XR metadata | Lowest common denominator | + +===========+===================+==============================+ + | CSS | vendor-agnostic | 2D canvas + object | + | | | referencing/styling | + +-----------+-------------------+------------------------------+ + | XR | vendor-agnostic | 3D camera + object(file) | + | Fragments | | load/embed/click/referencing | + +-----------+-------------------+------------------------------+ + | Vendor | vendor-*specific* | Specialized Entity-Component | + | prefixs | | implementation | + +-----------+-------------------+------------------------------+ + + Table 14 + + | Why? Because not all XR interactions can/should be solved/ + | standardized by embedding XR Fragments into any 3D file. The + | lowest common denominator between 3D engines is the 'entity'-part + | of their entity-component-system (ECS). The 'component'-part can + | be progressively enhanced via vendor prefixes. For example, the following metadata can be added to a .glb file, to make an object grabbable in AFRAME: @@ -1954,9 +1957,6 @@ Internet-Draft XR Fragments September 2024 - - - van Kammen Expires 24 March 2025 [Page 35] Internet-Draft XR Fragments September 2024 @@ -1980,11 +1980,11 @@ Internet-Draft XR Fragments September 2024 │ [3D mesh-+ | // save to z.glb in AFRAME inspector │ │ | ├─ name: john | │ │ | O ├─ age: 23 | │ -│ | /|\ ├─ -AFRAME-grabbable: '' | > inits 'grabbable' component on object john │ -│ | / \ ├─ -AFRAME-material.color: '#F0A' | > inits 'material' component on object john │ -│ | ├─ -AFRAME-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ -│ | ├─ -THREE-material.fog: false | > changes material settings in THREE.js app │ -│ | ├─ -GODOT-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ +│ | /|\ ├─ -aframe-grabbable: '' | > inits 'grabbable' component on object john │ +│ | / \ ├─ -aframe-material.color: '#F0A' | > inits 'material' component on object john │ +│ | ├─ -aframe-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ +│ | ├─ -three-material.fog: false | > changes material settings in THREE.js app │ +│ | ├─ -godot-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ │ +--------+ | │ │ | │ ├─ -AFRAME-version: '1.6.0' | > │ diff --git a/doc/RFC_XR_Fragments.xml b/doc/RFC_XR_Fragments.xml index d5490ee..3b02dda 100644 --- a/doc/RFC_XR_Fragments.xml +++ b/doc/RFC_XR_Fragments.xml @@ -1346,8 +1346,10 @@ Therefore a 2-button navigation-interface is the bare minimum interface: -XR Fragments | +CSS | vendor-agnostic | -camera + 3D object(file) load/embed/click/referencing | +2D canvas + object referencing/styling |
XR Fragments VP's | +XR Fragments | +vendor-agnostic | +3D camera + object(file) load/embed/click/referencing | +|
Vendor prefixs | vendor-specific | -Entity-Component System (ECS) | +Specialized Entity-Component implementation |
Why? Because not all XR interactions can be solved/standardized by embedding XR Fragments into any 3D file. -Some XR experiences need more than navigation and show/hide/filtering of objects (via click-state machines). -The lowest common denominator between s that 3D engines use entity-component-system +Why? Because not all XR interactions can/should be solved/standardized by embedding XR Fragments into any 3D file. +The lowest common denominator between 3D engines is the 'entity'-part of their entity-component-system (ECS). The 'component'-part can be progressively enhanced via vendor prefixes. For example, the following metadata can be added to a .glb file, to make an object grabbable in AFRAME: inits 'grabbable' component on object john │ -│ | / \ ├─ -AFRAME-material.color: '#F0A' | > inits 'material' component on object john │ -│ | ├─ -AFRAME-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ -│ | ├─ -THREE-material.fog: false | > changes material settings in THREE.js app │ -│ | ├─ -GODOT-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ +│ | /|\ ├─ -aframe-grabbable: '' | > inits 'grabbable' component on object john │ +│ | / \ ├─ -aframe-material.color: '#F0A' | > inits 'material' component on object john │ +│ | ├─ -aframe-text.value: '{name}{age}'| > inits 'text' component (*) with value 'john' │ +│ | ├─ -three-material.fog: false | > changes material settings in THREE.js app │ +│ | ├─ -godot-Label3D.text: '{name}{age}'| > inits 'Label3D' component (*) in Godot │ │ +--------+ | │ │ | │ ├─ -AFRAME-version: '1.6.0' | > │