Web3D

From HandWiki
Short description: Web-based interactive 3D content

Web3D, also called 3D Web, is a group of technologies to display and navigate websites using 3D computer graphics.

Pre-WebGL era

The emergence of Web3D dates back to 1994, with the advent of VRML, a file format designed to store and display 3D graphical data on the World Wide Web.[1] In October 1995, at Internet World, Template Graphics Software demonstrated a 3D/VRML plug-in for the beta release of Netscape 2.0 by Netscape Communications.[2]

The Web3D Consortium was formed to further the collective development of the format. VRML and its successor, X3D, have been accepted as international standards by the International Organization for Standardization and the International Electrotechnical Commission.[citation needed]

The main drawback of the technology was the requirement to use third-party browser plug-ins to perform 3D rendering, which slowed the adoption of the standard.[citation needed]

Between 2000 and 2010, one of these plug-ins, Adobe Flash Player, was widely installed on desktop computers and was used to display interactive web pages and online games and to play video and audio content.[3] Several Flash-based frameworks appeared that used software rendering and ActionScript 3 to perform 3D computations such as transformations, lighting, and texturing. Most notable among them were Papervision3D and Away3D.[citation needed]

Eventually, Abobe developed Stage3D, an API for rendering interactive 3D graphics with GPU-acceleration for its Flash player and AIR products,[4] which was adopted by software vendors.[5][6]

In 2009, an open-source 3D web technology called O3D was introduced by Google. It also required a browser plug-in, but contrary to Flash/Stage3D, was based on JavaScript API. O3D was geared not only for games but also for advertisements, 3D model viewers, product demos, simulations, engineering applications, control and monitoring systems, and massive online virtual worlds.[7]

WebGL and glTF

WebGL (short for "Web Graphics Library") evolved out of the Canvas 3D experiments started by Vladimir Vukićević at Mozilla Foundation. Vukićević first demonstrated a Canvas 3D prototype in 2006. By the end of 2007, both Mozilla[8] and Opera[9] had made their own separate implementations.

In early 2009, the nonprofit technology consortium Khronos Group started the WebGL Working Group, with initial participation from Apple, Google, Mozilla, Opera, and others.[10] Version 1.0 of the WebGL specification was released in March 2011.[11]

Major advantages of the new technology include conformity with web standards and near-native 3D performance without the use of any browser plug-ins.[12] Since WebGL is based on OpenGL ES, it works on mobile devices without any additional abstraction layers. For other platforms, WebGL implementations leverage ANGLE to translate OpenGL ES calls to DirectX, OpenGL, or Vulkan API calls.[13]

Among notable WebGL frameworks are A-Frame, which uses HTML-based markup for building virtual reality experiences;[14] PlayCanvas, an open-source engine alongside a proprietary cloud-hosted creation platform for building browser games;[15] Three.js, an MIT-licensed framework used to create demoscene from the early 2000s;[16] Unity, which obtained a WebGL back-end in version 5;[17] and Verge3D, which integrates with Blender, 3ds Max, and Maya to create 3D web content.[18]

With the rapid adoption of WebGL, a new problem arose—the lack of a 3D file format optimized for the Web. This issue was addressed by glTF, a format that was conceived in 2012 by members of the COLLADA working group.[19] At SIGGRAPH 2012, Khronos presented a demo of glTF, which was then called WebGL Transmissions Format (WebGL TF). On 19 October 2015, the glTF 1.0 specification was released.[20] Version 2.0 glTF uses a physically based rendering material model, proposed by Fraunhofer.[21] Other upgrades include sparse accessors and morph targets for techniques such as facial animation, and schema tweaks and breaking changes for corner cases or performance, such as replacing top-level glTF object properties with arrays for faster index-based access.[22]

Future

"WebGPU" is the working name for a potential web standard and JavaScript API for accelerated graphics and computing, aiming to provide "modern 3D graphics and computation capabilities". It is developed by the W3C "GPU for the Web" Community Group, with engineers from Apple, Mozilla, Microsoft, and Google, among others.[23]

WebGPU will not be based on any existing 3D API and will use Rust-like syntax for shaders.[24]

See also

References

  1. Dave Raggett (1994). "Extending WWW to support Platform Independent Virtual Reality". https://www.w3.org/People/Raggett/vrml/vrml.html. 
  2. First 3D/VRML Plug-in for Netscape 2.0 shown by TGS; TGS extends leadership in Internet 3D products and technology. AllBusiness.com. 30 Oct 1995. Last accessed 26 Dec 2011.
  3. Looking back at the best Flash sites of 2009 , Adobe Developer Connection, 14 December 2009
  4. 3D game development for Flash and video games
  5. "Adobe Flash 11 adopts Unreal Engine 3 for better browser games | The Verge". theverge.com. 7 October 2011. https://www.theverge.com/2011/10/7/2471974/epics-unreal-3-engine-coming-soon-to-adobe-flash-11. Retrieved 2023-05-22. 
  6. Keith Gladstien (2013). Flash Game Development In a Social, Mobile and 3D World. Cengage Learning. pp. 383–421. ISBN 978-1-4354-6021-8. 
  7. O3D Project Page from Google Code
  8. "Canvas 3D: GL power, web-style". Blog.vlad1.com. http://blog.vlad1.com/2007/11/26/canvas-3d-gl-power-web-style/. 
  9. "Taking the canvas to another dimension". My.opera.com. 2007-11-26. http://my.opera.com/timjoh/blog/2007/11/13/taking-the-canvas-to-another-dimension. 
  10. "WebGL – OpenGL ES 2.0 for the Web". Khronos.org. http://www.khronos.org/webgl/. 
  11. "Khronos Releases Final WebGL 1.0 Specification". 3 March 2011. http://www.khronos.org/news/press/khronos-releases-final-webgl-1.0-specification. 
  12. "WebGL Fundamentals". HTML5 Rocks. http://www.html5rocks.com/en/tutorials/webgl/webgl_fundamentals/. 
  13. "ANGLE – Almost Native Graphics Layer Engine". 2019. https://chromium.googlesource.com/angle/angle/+/master/README.md. 
  14. "A-Frame". https://aframe.io. 
  15. "GDC 2014: Mozilla and partners prove Web is the platform for gaming". blog.mozilla.org. 18 March 2014. https://blog.mozilla.org/blog/2014/03/18/gdc-2014-mozilla-and-partners-prove-the-web-is-the-platform-for-gaming/. 
  16. NVScene. "NVScene 2015 Session: Reinventing The Wheel – One Last Time (Ricardo Cabello)". YouTube. https://www.youtube.com/watch?v=LXWYOF4VibE. 
  17. Robertson, Adi (3 March 2015). "Unity officially releases its new game engine: Unity 5". The Verge. https://www.theverge.com/2015/3/3/8142099/unity-5-engine-release. 
  18. Thacker, Jim (2021-05-28). "Soft8Soft ships Verge3D 3.7". CG Channel. https://www.cgchannel.com/2021/05/soft8soft-ships-verge3d-3-0/. 
  19. Houston, Ben. "glTF: Everything You Need to Know". https://www.threekit.com/blog/gltf-everything-you-need-to-know. Retrieved 2023-05-22. 
  20. Simkin, Aliaksei. "Behind the scene of 3D Magic". https://stayrelevant.globant.com/en/gltf-behind-the-scene-of-3d-magic/. Retrieved 29 October 2020. 
  21. "Physically Based Materials in glTF – Current State. M. Limper, T. Sturm, SIGGRAPH 2016 WebGL & glTF BOF (July 27, 2016)". https://www.youtube.com/watch?v=0eWUzCa_M0E&t=4311s. 
  22. "glTF 2.0 syntax changes and JSON encoding restrictions · Issue #831 · KhronosGroup/glTF". https://github.com/KhronosGroup/glTF/issues/831. 
  23. "GPU for the Web Community Group". https://www.w3.org/community/gpu/. 
  24. "From GLSL to WGSL: the future of shaders on the Web". https://dmnsgn.me/blog/from-glsl-to-wgsl-the-future-of-shaders-on-the-web/.