Difference between revisions of "X3D version 3.4 Development"

From Web3D.org
Jump to: navigation, search
(fix headers and spaces)
(http instead of https to speedup loading)
Line 45: Line 45:
 
*'''Events'''
 
*'''Events'''
 
** Review X3D event interoperability with other event models, such as Document Object Model (DOM) Recommendations
 
** Review X3D event interoperability with other event models, such as Document Object Model (DOM) Recommendations
*'''Audio and video''': adding royalty-free formats, streamability, [http://web3d.org/pipermail/x3d-public_web3d.org/2013-December/002681.html disabling attenuation], 3D aural spatialization using reflection from simple geometry (such as [http://gamma.cs.unc.edu/Sound/RESound RESOUND] or [https://dvcs.w3.org/hg/audio/raw-file/tip/webaudio/specification.html Web Audio API])
+
*'''Audio and video''': adding royalty-free formats, streamability, [http://web3d.org/pipermail/x3d-public_web3d.org/2013-December/002681.html disabling attenuation], 3D aural spatialization using reflection from simple geometry (such as [http://gamma.cs.unc.edu/Sound/RESound RESOUND] or [http://dvcs.w3.org/hg/audio/raw-file/tip/webaudio/specification.html Web Audio API])
 
*'''[http://www.web3d.org/realtime-3d/working-groups/computer-aided-design-cad Computer Aided Design (CAD)]''' Interactive/Mobile Profile, to include:
 
*'''[http://www.web3d.org/realtime-3d/working-groups/computer-aided-design-cad Computer Aided Design (CAD)]''' Interactive/Mobile Profile, to include:
 
**[http://www.web3d.org/files/specifications/19775-1/V3.3/Part01/CADInterchange.html CADInterchange profile] plus FillProperties/LineProperties, primitive/Geometry2D nodes, Extrusion, NURBS, ClipPlane
 
**[http://www.web3d.org/files/specifications/19775-1/V3.3/Part01/CADInterchange.html CADInterchange profile] plus FillProperties/LineProperties, primitive/Geometry2D nodes, Extrusion, NURBS, ClipPlane
Line 52: Line 52:
 
*'''[http://www.ecma-international.org/publications/standards/Ecma-262.htm ECMAScript]''' (Javascript) specification revision compatibility with [http://www.web3d.org/files/specifications/19777-1/V3.0/index.html X3D scripting]; possibly add C# or Python support
 
*'''[http://www.ecma-international.org/publications/standards/Ecma-262.htm ECMAScript]''' (Javascript) specification revision compatibility with [http://www.web3d.org/files/specifications/19777-1/V3.0/index.html X3D scripting]; possibly add C# or Python support
 
*'''Generalized input/output interface support'''
 
*'''Generalized input/output interface support'''
** Possibly [http://www.cs.unc.edu/Research/vrpn/index.html Virtual Reality Peripheral Network (VRPN)], gesture recognition (such as [http://en.wikipedia.org/wiki/Kinect KINECT], [https://www.leapmotion.com LEAP]), etc.
+
** Possibly [http://www.cs.unc.edu/Research/vrpn/index.html Virtual Reality Peripheral Network (VRPN)], gesture recognition (such as [http://en.wikipedia.org/wiki/Kinect KINECT], [http://www.leapmotion.com LEAP]), etc.
 
** Support for arbitrary sensors and user interaction devices
 
** Support for arbitrary sensors and user interaction devices
* '''Geometry''': point size (or perspective rendering), progressive meshes (suitable for both compression and streaming), 3D ExtrudedText, support for [https://en.wikipedia.org/wiki/Web_typography Web typography] using [http://www.w3.org/TR/WOFF Web Open Fonts Format (WOFF)]
+
* '''Geometry''': point size (or perspective rendering), progressive meshes (suitable for both compression and streaming), 3D ExtrudedText, support for [http://en.wikipedia.org/wiki/Web_typography Web typography] using [http://www.w3.org/TR/WOFF Web Open Fonts Format (WOFF)]
 
*'''[http://www.web3d.org/realtime-3d/working-groups/x3d-earth Geospatial X3D]''' component
 
*'''[http://www.web3d.org/realtime-3d/working-groups/x3d-earth Geospatial X3D]''' component
 
** [http://www.igraphics.com/Standards/EnhancedGeospatialComponent_2007_10_30/Part01/X3D.html Enhanced Geospatial Component - spatial reference frame (SRF)] and [http://www.opengeospatial.org/standards/kml KML] support, [http://www.opengeospatial.org/projects/initiatives/3dpie OGC 3D Portrayal], [http://web3d.org/pipermail/x3d-public_web3d.org/2010-December/001187.html GpsSensor], [http://openlayers.org OpenLayer] mashups
 
** [http://www.igraphics.com/Standards/EnhancedGeospatialComponent_2007_10_30/Part01/X3D.html Enhanced Geospatial Component - spatial reference frame (SRF)] and [http://www.opengeospatial.org/standards/kml KML] support, [http://www.opengeospatial.org/projects/initiatives/3dpie OGC 3D Portrayal], [http://web3d.org/pipermail/x3d-public_web3d.org/2010-December/001187.html GpsSensor], [http://openlayers.org OpenLayer] mashups
Line 60: Line 60:
 
*'''[http://www.web3d.org/realtime-3d/working-groups/h-anim Humanoid Animation (H-Anim)]''' anatomical correctness for skeleton and skinning, motion capture and playback, interchangeable avatars, animation for hands feet and faces
 
*'''[http://www.web3d.org/realtime-3d/working-groups/h-anim Humanoid Animation (H-Anim)]''' anatomical correctness for skeleton and skinning, motion capture and playback, interchangeable avatars, animation for hands feet and faces
 
* '''Interoperability''': include ''class'' attribute for all nodes to all encodings
 
* '''Interoperability''': include ''class'' attribute for all nodes to all encodings
* '''[http://www.json.org JSON]''': JavaScript Object Notation as an X3D encoding ([http://web3d.org/pipermail/x3d-public_web3d.org/2014-July/thread.html#2854 assessment thread]), relation to [https://www.khronos.org/gltf GlTF], streaming considerations
+
* '''[http://www.json.org JSON]''': JavaScript Object Notation as an X3D encoding ([http://web3d.org/pipermail/x3d-public_web3d.org/2014-July/thread.html#2854 assessment thread]), relation to [http://www.khronos.org/gltf GlTF], streaming considerations
 
*'''[http://www.web3d.org/realtime-3d/working-groups/medx3d Medical working group]''' capabilities
 
*'''[http://www.web3d.org/realtime-3d/working-groups/medx3d Medical working group]''' capabilities
 
** [http://svn.xj3d.org/xj3d_website/trunk/extensions/annotation.html Annotations component] and metadata usage
 
** [http://svn.xj3d.org/xj3d_website/trunk/extensions/annotation.html Annotations component] and metadata usage

Revision as of 13:40, 27 December 2015

Update in progress!

The Web3D Consortium has decided to merge all X3D version 3.4 efforts into X3D version 4.0. Stay tuned for continued reorganization of the still-valid activities listed here.

Strategic overview

X3D version 3.4 Development efforts are evolutionary improvements to the widely proven X3D Graphics architecture.

Web3D Consortium working groups currently define specification goals and requirements. Working group efforts are often the focus for defining and testing new X3D components.

We publicly review these goals annually during Web3D Conference and SIGGRAPH BOF meetings.

Suggestions, development and discussion via the x3d-public mailing list is ongoing. X3D version 3.4 progress also informs and helps to extend X3D version 4.0 Development.

The following list shows that a lot of interesting capabilities have been proposed and are under way for X3D version 3.4. However, topics on this list are not guaranteed to be completed! Rather these are all works in progress.

Activity and approval proceeds based on technical contributions and Web3D Consortium Member priorities. Please consider joining Web3D Consortium to help advance 3D graphics on the Web.

Legacy Issues

We plan to confirm the existence of complete capabilities for X3D v3.3 prior to final approval of X3D v3.4.

  • Full support for all existing X3D v3.3 components:
    • At least two compatible implementations (including at least one in open source) plus repeatable examples
    • Layer, ParticleSystems, RigidBodyPhysics, Shaders, TODO others
    • TransformSensor node: IGD and old Cortona
  • Is it necessary for Layout component to be deprecated or improved?

Candidate capabilities

Each of the following possibilities for X3D 3.4 have been discussed by the various X3D working groups during meetings and on mailing lists. Each potential capability is considered to be a feasible (and in most cases, straightforward) addition to the existing X3D version 3.3 architecture.

  • Appearance
    • Images: recommended formats for imagery and video (.gif .bmp .svg .flv .exr .hdr etc.). Consider QR codes as a first-class image type since it contains imagery and information, especially useful in Mixed Augmented Reality (MAR) applications
    • Materials: advanced parameters
    • Multitexture: review for correctness, completeness and conformance of rendering example scenes
    • Rendering: bump maps, shadows, edge smoothing, gamma correction, Non-Photorealistic Rendering (NPR)
    • Shaders: improved support and better interoperability, library of examples; CommonSurfaceShader?
    • Texturing: Texture atlas, projective texture mapping (PTM), RenderedTexture node for multipass rendering - 2D texture version of GeneratedCubeMapTexture, first proposed by Xj3D and also implemented in X3DOM and InstantReality, useful for all kinds of NPR, shadows, mirrors, etc.
  • Events
    • Review X3D event interoperability with other event models, such as Document Object Model (DOM) Recommendations
  • Audio and video: adding royalty-free formats, streamability, disabling attenuation, 3D aural spatialization using reflection from simple geometry (such as RESOUND or Web Audio API)
  • Computer Aided Design (CAD) Interactive/Mobile Profile, to include:
  • ECMAScript (Javascript) specification revision compatibility with X3D scripting; possibly add C# or Python support
  • Generalized input/output interface support
  • Geometry: point size (or perspective rendering), progressive meshes (suitable for both compression and streaming), 3D ExtrudedText, support for Web typography using Web Open Fonts Format (WOFF)
  • Geospatial X3D component
  • Humanoid Animation (H-Anim) anatomical correctness for skeleton and skinning, motion capture and playback, interchangeable avatars, animation for hands feet and faces
  • Interoperability: include class attribute for all nodes to all encodings
  • JSON: JavaScript Object Notation as an X3D encoding (assessment thread), relation to GlTF, streaming considerations
  • Medical working group capabilities
    • Annotations component and metadata usage
    • Archival 3D medical records, potential emphasis on Traumatic brain injury (TBI) volume visualization
    • Haptics component for force feedback
    • Soft-body physics component to complement rigid-body physics component
  • Mobile Profile. TODO - needed? Calling out a reduced palette for mobile devices remains interesting, but might instead become a goal for X3D version 4.0 efforts.
  • Metadata: support for embedding information useful for applications utilizing X3D
    • Enumerated types: better access, typing, naming, and validation than using MetadataSet/MetadataString combinations
  • Mixed and Augmented Reality (MAR): integration of multiple capabilities with mobile devices
  • Networking: consider NetworkSensor and event-passing issues, streaming using JSON, server-side 3D topics
  • Security and privacy:
    • XML Security provides best-available encryption, digital signature (authentication)
    • Web Privacy: examine X3D compatibility with Do Not Track, P3P, POWDER
    • Review X3D specifications to ensure that Security Considerations are fully documented
  • Viewing and navigation: cinematic camera control, alternative navigation types (such as PAN, TURNTABLE etc.), Recommended navigation behaviours review, and old MatrixTransform node (esp. useful for CAD, VR/AR etc., impl. in X3DOM and InstantReality)

All suggestions and recommendations are welcome. Component improvements and additions are approved by Web3D Consortium members.

  • TODO: Which experimental nodes are ready? Candidates include Fraunhofer, Bit Management, other members and working groups?
  • TODO: articulate Big Data and Cloud, server-side visualization, related issues

Please contact us if you think additional technologies need to be considered.

Backwards and forwards compatibility

Thanks to careful design and insistence on implementation/evaluation, the X3D International Standard has maintained both steady growth and interoperability ever since Virtual Reality Modeling Language (VRML) in 1997. This track record of stability and innovation is among the best in the 3D graphics industry.

X3D version 4.0 Development efforts are focused on HTML5/Declarative 3D/X3DOM, and X3D Version 4.1 is focused on Mixed Augmented Reality (MAR) capabilities, which may require architectural changes. Some new technologies may get pushed from 4.0 to 3.4 (or back again) after careful consideration by the respective working groups.

Related work

Much careful planning is involved, we are working to ensure that X3D v3.4 can be coherently advanced in combination with a coordinated set of steadily evolving ISO/IEC standards.

  • X3D Efficient Binary Encoding (EBE). This work is proceeding in parallel. X3D v3.4 must maintain compatibility with all encodings. See also SRC format (Web3D 2014)and ExternalGeometry node in InstantPlayer and X3DOM
  • X3D JavaScript Object Notation (JSON) Encoding. This work is proceeding in parallel. X3D v3.4 must maintain compatibility with all encodings.
  • X3D version 4.0 (HTML5/X3DOM). This work is proceeding in parallel. X3D v3.4 support is expected.
  • X3D version 4.1 (Mixed Augmented Reality). Nodes and capabilities in this arena will build on v4.0 and HTML5.

Schedule

ISO Considerations

  • Deciding readiness for ISO New Work Item Proposal (NWIP): we need Committee Draft (CD) specification prose for each planned capability.
  • Web3D Consortium is not locked into an annual schedule, ISO handling is flexible.
  • Once the NWIP is approved, ISO rules for schedule and review are established.

X3D version 3.4 execution goals

  • Review progress during monthly calls, Web3D Conference, and SIGGRAPH Conference.
  • We are continuing a monthly review schedule for submissions so that we can build out X3D v3.4 one component at a time.
  • We are planning to have a 1-year deadline for completion of CD specification prose, rather than wait until all possible v3.4 work is ready.
  • Web3D Consortium members and public review when a final draft specification is ready to proceed to ISO.
  • Any new components not meeting Web3D deadlines might be a candidate for deferral as v3.5. Or considered not ready.