<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style></head><body lang=EN-US link=blue vlink="#954F72"><div class=WordSection1><p class=MsoNormal>See variety of inputs into web page (X_ITE and X3DOM) here:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><a href="https://coderextreme.net/X3DJSONLD/src/main/html/index.html">https://coderextreme.net/X3DJSONLD/src/main/html/index.html</a><o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I believe I either use XML or DOM to get the JSON or XML scene into the page, even though on the surface, I may be working with JSON.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Excerpt for XML:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    <X3D xmlns:xsd="http://www.w3.org/2001/XMLSchema-instance" profile="Immersive" version="3.3" xsd:noNamespaceSchemaLocation="http://www.web3d.org/specifications/x3d-3.3.xsd" showProgress="false" showStat='false' showLog='false' width='150px' height='75px' backend='webgl'><o:p></o:p></p><p class=MsoNormal>                <Scene id="x3domxml"><o:p></o:p></p><p class=MsoNormal>                </Scene><o:p></o:p></p><p class=MsoNormal>    </X3D><o:p></o:p></p><p class=MsoNormal>    <X3DCanvas id='x_itexml' cache='false'><o:p></o:p></p><p class=MsoNormal>           <p>Your browser may not support all features required by X_ITE!</p><o:p></o:p></p><p class=MsoNormal>           <X3D><o:p></o:p></p><p class=MsoNormal>           <Scene><o:p></o:p></p><p class=MsoNormal>           </Scene><o:p></o:p></p><p class=MsoNormal>           </X3D><o:p></o:p></p><p class=MsoNormal>    </X3DCanvas><o:p></o:p></p><p class=MsoNormal>============================================================================================================<o:p></o:p></p><p class=MsoNormal>function load_X_ITE_XML(content, selector) {<o:p></o:p></p><p class=MsoNormal>        X3D(function() {<o:p></o:p></p><p class=MsoNormal>                var browser = X3D.getBrowser(selector);<o:p></o:p></p><p class=MsoNormal>                browser.replaceWorld(browser.createX3DFromString(content));<o:p></o:p></p><p class=MsoNormal>        }, function() {<o:p></o:p></p><p class=MsoNormal>                alert("Failed to render XML to X_ITE");<o:p></o:p></p><p class=MsoNormal>        });<o:p></o:p></p><div style='mso-element:para-border-div;border:none;border-bottom:double windowtext 2.25pt;padding:0in 0in 1.0pt 0in'><p class=MsoNormal style='border:none;padding:0in'>}<o:p></o:p></p></div><p class=MsoNormal> /** for X3DOM **/<o:p></o:p></p><p class=MsoNormal>                     var doc = document.querySelector(selector);<o:p></o:p></p><p class=MsoNormal>                        if (doc.hasRuntime && doc.runtime.ready) {<o:p></o:p></p><p class=MsoNormal>                                try {<o:p></o:p></p><p class=MsoNormal>                                        doc.runtime.replaceWorld(element);<o:p></o:p></p><p class=MsoNormal>                                } catch (e) {<o:p></o:p></p><p class=MsoNormal>                                        alert(e);<o:p></o:p></p><p class=MsoNormal>                                        console.error(e);<o:p></o:p></p><p class=MsoNormal>                                }<o:p></o:p></p><p class=MsoNormal>                        }<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So it appears possible to load X3D via JavaScript (not an Inline, but follow me).<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It would be instructive to create an equivalent mechanism via inlines.  I believe this has been shown:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><a href="https://coderextreme.net/X3DJSONLD/src/main/html/x_iteexamples.html">https://coderextreme.net/X3DJSONLD/src/main/html/x_iteexamples.html</a> (note missing X3D element, hmm)<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><a href="https://coderextreme.net/X3DJSONLD/src/main/html/x3domexamples3.html">https://coderextreme.net/X3DJSONLD/src/main/html/x3domexamples3.html</a><o:p></o:p></p><p class=MsoNormal><br>If you like, you may show the equivalent for XML (It would be best to try with VRML as well, I haven’t done that).<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Enjoy!  Wow, feels good working together folks!<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It would be problematic to use both X_ITE and X3DOM if X_ITE on the same page if you relied only on X3D nodes like X3DOM does.   It would be hard to distinguish which browser to use if only X3D tags are used.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Perhaps we need an official X3D tag implementation that can forward to either X3DOM or X_ITE based on an attribute?<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>John</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986">Mail</a> for Windows 10</p><p class=MsoNormal><o:p> </o:p></p><div style='mso-element:para-border-div;border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal style='border:none;padding:0in'><b>From: </b><a href="mailto:brutzman@nps.edu">Brutzman, Donald (Don) (CIV)</a><br><b>Sent: </b>Saturday, June 1, 2019 11:23 PM<br><b>To: </b><a href="mailto:andreasplesch@gmail.com">Andreas Plesch</a>; <a href="mailto:yottzumm@gmail.com">John Carlson</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a><br><b>Subject: </b>Re: [x3d-public] jupyter notebook; X3DOM syntax for including X3Dwithin HTML</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks for continuing scrutiny, this issue is quite important for X3Dv4 specification efforts.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I think an earlier version of X_ITE used regular X3D elements without problem - not sure, that was some time ago.  Hard to tell now since the online .html examples all seem to use <X3DCanvas src="somesuch"><!-- fallback --></X3DCanvas></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I spot-checked a few of the examples, am seeing same X3DCanvas pattern at</p><p class=MsoNormal>http://create3000.de/x_ite/getting-started/#x3d-examples</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Perhaps X3DOM is avoiding direct inclusion and parsing of .x3d source for same reason?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Looks like you've worked on this in X_ITE already Andreas</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>* http://create3000.de/x_ite/getting-started/#xhtml-dom-integration</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>* http://create3000.de/x_ite/xhtml-dom-integration/</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>* http://create3000.de/x_ite/xhtml-dom-integration/#example</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>* http://media.create3000.de/create3000/dom-integration/dom.integration.xhtml</p><p class=MsoNormal>excerpt:</p><p class=MsoNormal>                <body></p><p class=MsoNormal>                                <X3DCanvas class="browser" timings="false"></p><p class=MsoNormal>                                                <img class="fallback" src="XHTML.png"/></p><p class=MsoNormal>                                                <X3D xmlns="http://www.web3d.org/specifications/x3d-namespace" id="spheres"></p><p class=MsoNormal>                                                                <Scene DEF='scene'></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Wondering if you had tried a .html version of that preceding file, and what any difficulties might have been?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Wondering why you have a DEF on the <Scene> ?  If applying HTML events, presumably it could be an id="scene" reference instead.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>SVG recommendation allows singleton elements in fragments within HTML, also seems to sometimes use namespaces and sometimes not.  Also SVG appears to have at least 2 lowerCamelCase elements, clipPath and foreignObject, plus a large number of lowerCamelCase attributes - so not every element/attribute has to be all lower case.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                Scalable Vector Graphics (SVG) 2</p><p class=MsoNormal>                W3C Candidate Recommendation 04 October 2018</p><p class=MsoNormal>                </p><p class=MsoNormal>                Chapter 5: Document Structure</p><p class=MsoNormal>                https://www.w3.org/TR/SVG2/struct.html</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Also wondering if you folks think that the <X3DCanvas src=""/> pattern from X_ITE is something we should repeat for X3DOM.  Seems like a good fallback that supports multiple X3D encodings.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I recommend that we try to pursue every possibility that might allow inclusion of .x3d (XML valid) models "as is" within the HTML page.  Certainly the fact that they work when relabeled as an XHTML page shows that it is possible.  SVG also provides corrolary evidence that it is possible.  If we force a special conversion of all X3D models used in HTML, then</p><p class=MsoNormal>- that has a huge impact on the number of just-slightly-different scenes that get created,</p><p class=MsoNormal>- it greatly complicates validation, and</p><p class=MsoNormal>- it also is a huge negative when trying to edit/test/apply improvements to a model when the deployed version has unnecessarily different syntax from the original version.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>As far as jupyter goes, since that notebook supports python and a wide variety of embedded languages I expect that we will be able to align satisfactorily as this work proceeds - you've made great progress already.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Onward...</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 5/31/2019 5:56 PM, Andreas Plesch wrote:</p><p class=MsoNormal>> Well, if it was xhtml we were talking about you would be correct.</p><p class=MsoNormal>> </p><p class=MsoNormal>> But, it is html without the x which is expected by the HTML renderer</p><p class=MsoNormal>> in Jupyter. There is no XHTML renderer since the Jupyter notebook</p><p class=MsoNormal>> itself is a HTML document.</p><p class=MsoNormal>> </p><p class=MsoNormal>> And html allows singleton tags only for certain tags, at least in how</p><p class=MsoNormal>> all browser parse the markup, and probably also as defined in the</p><p class=MsoNormal>> HTML5 spec. These certain tags may include all known HTML elements</p><p class=MsoNormal>> which do not use their text content. Unfortunately, the X3D tags are</p><p class=MsoNormal>> considered Unknown Elements by html and they seem to require the</p><p class=MsoNormal>> explicit end tag.</p><p class=MsoNormal>> </p><p class=MsoNormal>> x3dom does not use any HTML parsing libraries but completely relies on</p><p class=MsoNormal>> the web browser to do the parsing. And the browsers get confused,</p><p class=MsoNormal>> because they do not understand the singleton x3d tags in a html</p><p class=MsoNormal>> document.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Alas, if the xml serializing library in X3DJSAIL does not have an</p><p class=MsoNormal>> option to generate full tags (they would be still legal XML, no?), we</p><p class=MsoNormal>> would need to settle for xhtml IFrames which can also be included in a</p><p class=MsoNormal>> Jupyter notebook (but not tested yet), or, as another option, wrap the</p><p class=MsoNormal>> xml X3D into an Inline since x3dom always uses the browser XML parser</p><p class=MsoNormal>> for Inlines. Would x3d.toStringX3DInline(filename) be considered too</p><p class=MsoNormal>> extravagant ? It would generate an xml X3D document string with a</p><p class=MsoNormal>> single Inline node, and also the content X3D in the file filename.</p><p class=MsoNormal>> x3d.toFileX3DInline(x3dFileName, inlineFileName) would generate two</p><p class=MsoNormal>> files.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Perhaps Python has an option to serialize out the full tags, perhaps</p><p class=MsoNormal>> as HTMLFragments. Then a x3d.toStringFullTags() could be included</p><p class=MsoNormal>> outside of X3DJSAIL, and with X3DPSAIL.</p><p class=MsoNormal>> </p><p class=MsoNormal>> To consider X_ITE and x3dom together it would be first necessary get</p><p class=MsoNormal>> X_ITE to work at all with Jupyter locally generated content. It may be</p><p class=MsoNormal>> possible since X_ITE works with remote URLs in Jupyter.</p><p class=MsoNormal>> </p><p class=MsoNormal>> -Andreas</p><p class=MsoNormal>> </p><p class=MsoNormal>> ---on the phone---</p><p class=MsoNormal>> </p><p class=MsoNormal>> On Fri, May 31, 2019, 5:14 PM <x3d-public-request@web3d.org wrote:</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Send x3d-public mailing list submissions to</p><p class=MsoNormal>>>          x3d-public@web3d.org</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> To subscribe or unsubscribe via the World Wide Web, visit</p><p class=MsoNormal>>>          http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal>>> or, via email, send a message with subject or body 'help' to</p><p class=MsoNormal>>>          x3d-public-request@web3d.org</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> You can reach the person managing the list at</p><p class=MsoNormal>>>          x3d-public-owner@web3d.org</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> When replying, please edit your Subject line so it is more specific</p><p class=MsoNormal>>> than "Re: Contents of x3d-public digest..."</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Today's Topics:</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>>     1. Re: jupyter notebook; X3DOM syntax for including X3D within</p><p class=MsoNormal>>>        HTML/XHTML (Brutzman, Donald (Don) (CIV))</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> ----------------------------------------------------------------------</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Message: 1</p><p class=MsoNormal>>> Date: Fri, 31 May 2019 10:14:05 +0000</p><p class=MsoNormal>>> From: "Brutzman, Donald (Don) (CIV)" <brutzman@nps.edu></p><p class=MsoNormal>>> To: "x3d-public@web3d.org" <x3d-public@web3d.org></p><p class=MsoNormal>>> Subject: Re: [x3d-public] jupyter notebook; X3DOM syntax for including</p><p class=MsoNormal>>>          X3D within HTML/XHTML</p><p class=MsoNormal>>> Message-ID: <b6c49fa9-6afc-34fe-ee57-59f0ad5fc99d@nps.edu></p><p class=MsoNormal>>> Content-Type: text/plain; charset="utf-8"</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> thanks for great progress.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> On 5/28/2019 12:12 PM, Andreas Plesch wrote:</p><p class=MsoNormal>>>> - x3dom has a problem with generated X3D outside of an Inline because</p><p class=MsoNormal>>>> the serialized XML output uses self-closing tags such as <Material /></p><p class=MsoNormal>>>> which is not HTML compatible.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> HTML allows singleton elements, i.e. self-closing tags.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Similarly, element CamelCaseElementNames are legal, so we should not have to rename <Material/> to <material></material> simply because of similarity to another language's naming patterns.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> i think root of this problem likely lies in how X3DOM uses the accompanying DOM libraries - not sure of those details.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Note that I got *all* of the X_ITE and X3DOM examples to work with HTML by assigning scenes to .html and .xhtml respectively.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> http://www.web3d.org/x3d/content/examples/X3dResources.html#Examples</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> http://x3dgraphics.com/examples/X3dForWebAuthors/Chapter01TechnicalOverview/HelloWorldIndex.html</p><p class=MsoNormal>>> http://x3dgraphics.com/examples/X3dForWebAuthors/Chapter01TechnicalOverview/HelloWorldX3dom.xhtml</p><p class=MsoNormal>>> http://x3dgraphics.com/examples/X3dForWebAuthors/Chapter01TechnicalOverview/HelloWorldX_ITE.html</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>>> So the suggestion would be to provide a method, say</p><p class=MsoNormal>>>> x3d.toStringX3DClosingTags(), which generates explicit closing tags:</p><p class=MsoNormal>>>> <Material></Material></p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> I don't think it is good to propagate a side-effect fix (which encourages mysterious improper practices and hides path towards fixes).</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Rather it is more desirable to isolate and fix the actual problem.  If someone can figure out why X3DOM runs differently when included within .xhtml and .html pages, that may reveal whatever idiosyncrasy is actually occurring.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Finally we want to match the same patterns in X_ITE and X3DOM so that choice of player is independent of source-model syntax when using X3D version 4.  So this is a worthy mismatch to figure out and fix.  Hopefully we can get closer to sorting things out fully.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Meanwhile: found and fixed several errors in online X3DOM .xhtml examples:</p><p class=MsoNormal>>> - corrected url to match changed release address:</p><p class=MsoNormal>>>     https://x3dom.org/release/x3dom.css</p><p class=MsoNormal>>>     https://x3dom.org/release/x3dom-full.js</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> - fixed bug in X3dToX3dom.xslt code logic in order to include function toggleFullscreen ()</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> - using XHTML Transitional (vice Strict) DTD in order for anchor target attribute to pass validation</p><p class=MsoNormal>>>     https://stackoverflow.com/questions/4666523/xhtml-strict-1-0-target-blank-not-valid</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> X3dToX3dom.xslt stylesheet correction checked in, X3DOM example pages updated and uploaded.  Having fun with X3DOM!  8)</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> all the best, Don</p><p class=MsoNormal>>> --</p><p class=MsoNormal>>> Don Brutzman  Naval Postgraduate School, Code USW/Br       brutzman@nps.edu</p><p class=MsoNormal>>> Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA   +1.831.656.2149</p><p class=MsoNormal>>> X3D graphics, virtual worlds, navy robotics http://faculty.nps.edu/brutzman</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> ------------------------------</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Subject: Digest Footer</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> _______________________________________________</p><p class=MsoNormal>>> x3d-public mailing list</p><p class=MsoNormal>>> x3d-public@web3d.org</p><p class=MsoNormal>>> http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> ------------------------------</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> End of x3d-public Digest, Vol 122, Issue 137</p><p class=MsoNormal>>> ********************************************</p><p class=MsoNormal>> </p><p class=MsoNormal>> _______________________________________________</p><p class=MsoNormal>> x3d-public mailing list</p><p class=MsoNormal>> x3d-public@web3d.org</p><p class=MsoNormal>> http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal>> </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>all the best, Don</p><p class=MsoNormal>-- </p><p class=MsoNormal>Don Brutzman  Naval Postgraduate School, Code USW/Br       brutzman@nps.edu</p><p class=MsoNormal>Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA   +1.831.656.2149</p><p class=MsoNormal>X3D graphics, virtual worlds, navy robotics http://faculty.nps.edu/brutzman</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>