A CSS Integration Model for Declarative 3D

Jan Sutter, Kristian Sons, Philipp Slusallek

In: Proceedings of the 20th International Conference on 3D Web Technology. ACM International Conference on 3D Web Technology (Web3D-15) 20th International Conference on 3D Web Technology July 17-21 Heraklion, Crete Greece Seiten 209-217 Web3D '15 ISBN 978-1-4503-3647-5 ACM New York, NY, USA 2015.


Declarative 3D (Dec3D) implementations, most notably XML3D and X3DOM, have enabled a seamless integration of 3D and 2D content on the same web page. Yet one of the major web technologies, Cascading Style Sheets (CSS), has not been integrated. The usage of CSS for 3D content has always been envisaged but never fully approached, because only polyfills for declarative 3D implementations exist and only recent developments have made custom CSS properties available. In this paper we will present a deep integration and adaption of CSS for Dec3D content and, hence, provide the final component necessary to fully integrate 3D content into the web technology stack. Our integration model allows for appearance definitions, such as visibility and materials, at a novel level of expressiveness. CSS-Selectors, inheritance, as well as media types provide unique means to change a scene's final appearance in a flexible and powerful way. Using CSS, it is possible to define the appearance of a 3D object dependent on the DOM hierarchy position or the screen resolution and orientation without a single line of JavaScript. The integration of CSS further enables the use of browser debugging facilities that have not been usable before. Because the requirements of 3D content are different compared to those of 2D content, we will point out existing limitations and necessary future additions to improve the interoperability of CSS with 3D content.


Weitere Links

Sutter,_Sons,_Slusallek_-_2015_-_A_CSS_Integration_Model_for_Declarative_3D.pdf (pdf, 347 KB )

Deutsches Forschungszentrum für Künstliche Intelligenz
German Research Center for Artificial Intelligence