<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;background-color:#FFFFFF;font-family:Calibri,Arial,Helvetica,sans-serif;">
<p>v4 vs v3.4 and d1 compiler domain:</p>
<p><br>
</p>
<p>I suspect the x3d v3.3 specs is close to what the compiler domain solutions would need. It's looking for 'technology agnostic, high level, LTS' - something that can be compiled/transformed into more specific web technologies.</p>
<p>For example in x3d, adding something like <Platform> or <Ifdef> would help configure scenes for more specific downstream variants while still authoring in upstream format. Desktop already proven for v3.3, authoring tools in place, adding stability.</p>
<p>So just add a few conveniences for the 'compilers/transformers' for x3dom, cobweb A and B, <future webcomponents variants>, and proto-unrolling variants - what the compilers/transformers would need to do their job.</p>
<p><br>
</p>
<p>Then v4 can pick one variant and do a great job, and other variants would still be allowed / supported / encouraged under the compiler domain, v3.4</p>
<p><br>
</p>
<p><br>
</p>
<br>
<br>
<div style="color: rgb(0, 0, 0);">
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> x3d-public <x3d-public-bounces@web3d.org> on behalf of doug sanden <highaspirations@hotmail.com><br>
<b>Sent:</b> June 10, 2016 3:40 PM<br>
<b>To:</b> X3D Graphics public mailing list<br>
<b>Subject:</b> Re: [x3d-public] [x3d] V4.0 Open discussion/workshop on X3D HTML integration</font>
<div> </div>
</div>
<div>
<div id="divtagdefaultwrapper" style="font-size:12pt; color:#000000; background-color:#FFFFFF; font-family:Calibri,Arial,Helvetica,sans-serif">
<p></p>
<div>> DOM integration: While I do think that good thinking on a spec. is </div>
<div>> very necessary, I also think it is critical to work from existing</div>
<div>> implementations or from building new implementation based on Xflow or</div>
<div>> aframe. It is too easy to get carried away otherwise. My best idea at</div>
<div>> this point is to work from cobweb but enhance it with a bridge between</div>
<div>> the x3d graph and a new, constructed DOM graph. </div>
<div>> </div>
<div><br>
</div>
<div><span style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px">I think some of these implementation ideas are very interesting, and it would be a shame if a new spec mandated them excluded.</span><br>
</div>
<div><span style="font-family:Calibri,Arial,Helvetica,sans-serif; font-size:16px"><br>
</span></div>
<div>e1 stability</div>
<div>d1 compiler</div>
<div>e1/d1 From the compiler domain, they would be seen as target technology variants -like ARM vs x86 vs x64- and nothing would be inherently excluded, as long as the upstream high-level LTS (long term stable) technology-agnostic specification was friendly
toward downstream technology variants in general, and someone develops a 'compiler' to do the specific transforms.</div>
<br>
<p></p>
<br>
<br>
<div style="color:rgb(0,0,0)">
<hr tabindex="-1" style="display:inline-block; width:98%">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" color="#000000" style="font-size:11pt"><b>From:</b> x3d-public <x3d-public-bounces@web3d.org> on behalf of Andreas Plesch <andreasplesch@gmail.com><br>
<b>Sent:</b> June 10, 2016 3:13 PM<br>
<b>To:</b> X3D Graphics public mailing list<br>
<b>Subject:</b> [x3d-public] [x3d] V4.0 Open discussion/workshop on X3D HTML integration</font>
<div> </div>
</div>
<div>
<div dir="ltr">
<div>Wow, lots of good discussion and trying to understand the issues happening.</div>
<div><br>
</div>
<div>Before I may offer input to some of the discussed points, let me state that I find myself in agreement with many of Leonard's arguments although I do believe that it could be possible to have better backwards compatibility (probably at a performance cost
in the web browser).</div>
<div><br>
</div>
<div>Time: x3d has a good, strict time model allowing for precise simulations. I do not believe cobweb follows that time model but I may be wrong. With some accounting and overhead it should be possible to implement the x3d time model but I am not sure it is
that desirable.</div>
<div><br>
</div>
<div>Native, declarative 3d support in web browsers: At this point it would be a mistake to assume that web browser will natively support any declarative 3d scene formats in the near (or far) future. There are too many 3d solutions based on webgl already available.
Keep in mind that web browsers even internally use their own javascript engines to implement HTML5 features in javascript, not compiled code. These js engines are actually byte code compilers which is pretty close to the metal. Without keeping performance
in mind, it is possible to produce slow js code. But it is also possible to produce very performant js code if written carefully. Having said all this, I believe the way to get into web browsers would be to follow the svg example and define a x3d DOM and interfaces
(then come up with a polyfill, and then also come up with a proof of concept implementation in C++ in mozilla, - a huge task which may be rejected). </div>
<div><br>
</div>
<div>webgl vs. opengl: webgl is more focused on the shader. This lets the GPU render very fast, potentially faster than the classic opengl pipeline. I do not believe there is any drawback using webgl only. It is all in how to get the data to the GPU.</div>
<div><br>
</div>
<div>Render loop: cobweb and x3dom render frames independent of waiting to changes to the scene graph to arrive at a finished state. To keep the web browser responsive, accepted practice is to not render as fast as possible but only as fast as necessary to
have a good frame rate. This is accomplished by letting the web browser control when a new frame in a x3d scene needs to be rendered. So instead of a rendering loop, you will just see a requestAnimationFrame invocation with a callback which initiates the rendering
of a new frame whenever the web browser requests it. Typically that happens every 1/60 s I believe if not too many other things are happening. This is a major difference between the x3d browser and the html5 web browser environment since in the web browser
environment it is necessary to coexist in a friendly manner with other elements controlled by js scripts on the same web page.</div>
<div><br>
</div>
<div>plugin vs. js implementation: The traditional web binary plugin container was abandoned for all kinds of content for good reasons. cobweb already provides SAI type html integration. I do not think the spec. needs any changes for this type of integration.
cobweb only adds a html <x3d> tag which is different from the x3d <x3d> element. It simply refers to an .x3d file in an url attribute. This html <x3d> tag could be formalized in the spec. DOM integration like in x3dom is very desirable, however, and is what
would be expected by web programmers.</div>
<div><br>
</div>
<div>DOM integration: While I do think that good thinking on a spec. is very necessary, I also think it is critical to work from existing implementations or from building new implementation based on Xflow or aframe. It is too easy to get carried away otherwise.
My best idea at this point is to work from cobweb but enhance it with a bridge between the x3d graph and a new, constructed DOM graph. </div>
<div><br>
</div>
<div>Roughly, I can see that cobweb could construct a DOM graph by adding html elements to the page while parsing the x3d xml. Then, all x3d nodes could be registered as new html elements which allows 'life cycle' management and lets js catch any changes to
the constructed x3d DOM graph (this is what x3dom does). Then, changes to the attributes of html elements could be transferred to changes in the fields of the corresponding x3d nodes by SAI methods. In turn, cobweb updates the scene. In the extreme, this means
that cobweb could start with an empty scene. It is then populated as the web browser recognizes registered x3d elements on the web page, and the bridge calls the appropriate SAI methods. The bridge could be pretty stupid this way and just needs to maintain
a map between the html and x3d graphs.</div>
<div><br>
</div>
<div>I may try to explain this to Holger and see if he agrees and if he would be inclined to accept help implementing this. But this would not happen any time soon and would slow down cobweb due to the bridging work. One could have a non-DOM and a DOM cobweb
version.</div>
<div><br>
</div>
-Andreas<br clear="all">
<div><br>
</div>
-- <br>
<div class="gmail_signature">Andreas Plesch<br>
39 Barbara Rd.<br>
Waltham, MA 02453</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>