<div dir="auto">I can try to help with these event questions:<br>
<br>
> Wondering, for full convergence of our sample implementation:<br>
><br>
> a. how have X3DOM and X_ITE each implemented events?<br>
<br>
x3dom and I think also X_ITE do not use DOM events to output and receive X3D events. x3dom registers watcher functions which get called when an event is output. Here is the main postMessage function which is used to output events:<br>
<a href="https://github.com/x3dom/x3dom/blob/e4b752ec0858aeb1ca1c40e2d3b2e9feffe5d947/src/nodes/Core/X3DNode.js#L226" rel="noreferrer noreferrer" target="_blank">https://github.com/x3dom/x3dom/blob/e4b752ec0858aeb1ca1c40e2d3b2e9feffe5d947/src/nodes/Core/X3DNode.js#L226</a><br>
The watcher functions just call an update field function for the To node in routes.<br>
This means that events just get passed around as quickly as possible. I do not think there is an attempt to keep timestamps constant in a given cascade. Not sure how event loops are handled.<div dir="auto">For each X3D output event also a DOM event is fired to give DOM JavaScript a chance to listen in and react. But this is independent of and in addition to the x3d event handling.<br>
<br>
> b. What differences exist?<br>
<br>
I think X-ITE keeps proper timestamps per cascade. It does not emit DOM events unless my DOM bridge is used. There are probaby other differences although I think the idea of field watchers being registered and then called for each output event is the same.</div><div dir="auto"><br></div><div dir="auto">
> c. Are ROUTE connections consistent?</div><div dir="auto"><br></div><div dir="auto">Not sure what the question is. Consistent. Perhaps about timestamps?</div><div dir="auto"><br>
> d. X3DOM is still missing some important/simple Event Utility nodes - is there a problem?<br>
<br>
Here are the currently implemented event utility nodes:<br>
<br>
<a href="https://github.com/x3dom/x3dom/tree/master/src/nodes/EventUtilities" rel="noreferrer noreferrer" target="_blank">https://github.com/x3dom/x3dom/tree/master/src/nodes/EventUtilities</a><br>
<br>
I can help if any are missing or misbehaving but I am not aware of any. Only the dev version has the nodes.</div><div dir="auto"><br></div><div dir="auto">Best, Andreas<br>
<br>
> Date: Fri, 1 Mar 2019 18:21:06 +0000<br>
> From: "Brutzman, Donald (Don) (CIV)" <<a href="mailto:brutzman@nps.edu" target="_blank" rel="noreferrer">brutzman@nps.edu</a>><br>
> To: X3D Graphics public mailing list <<a href="mailto:x3d-public@web3d.org" target="_blank" rel="noreferrer">x3d-public@web3d.org</a>>, "X3D<br>
> Graphics Working Group" <<a href="mailto:x3d@web3d.org" target="_blank" rel="noreferrer">x3d@web3d.org</a>><br>
> Subject: [x3d-public] X3D meeting minutes 1 MAR 2019: X3Dv4<br>
> architecture and event-exchange diagrams, progress review<br>
> Message-ID: <<a href="mailto:a2450931-5645-34fd-0b1d-23c8401a7f94@nps.edu" target="_blank" rel="noreferrer">a2450931-5645-34fd-0b1d-23c8401a7f94@nps.edu</a>><br>
> Content-Type: text/plain; charset="utf-8"<br>
><br>
> 0. *Attendance* Anita Havele, Michalis Kamburelis, Vince Marchetti, Nicholas Polys, Dick Puk, Don Brutzman<br>
><br>
> Plenty to review today, ensuring that our progress continues to be clearly recorded and communicated.<br>
><br>
> All information in this email is releasable publicly, no separate member-only minutes this week.<br>
><br>
> ----<br>
><br>
> Members and invited experts are welcome. We are an open organization.<br>
><br>
> We meet today, as usual, 0800-0930 pacific. To join the teleconference:<br>
> Web3D Teleconference<br>
> <a href="http://www.web3d.org/member/teleconference-information" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/member/teleconference-information</a><br>
><br>
> The X3D Graphics Working Group addresses all X3D specification issues and coordinates the technical development of future improvements.<br>
> <a href="http://www.web3d.org/working-groups/x3d" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/working-groups/x3d</a><br>
><br>
> Each week we report out both public and member-only information - membership has value. To become a Web3D Consortium member:<br>
> Join the Web3D Consortium<br>
> <a href="http://www.web3d.org/join" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/join</a><br>
><br>
> ==================================<br>
><br>
> 1. *Last week's minutes*<br>
><br>
> X3D meeting minutes 22 FEB 2019: X3D v4 Development status categories<br>
> <a href="http://web3d.org/pipermail/x3d-public_web3d.org/2019-March/010188.html" rel="noreferrer noreferrer" target="_blank">http://web3d.org/pipermail/x3d-public_web3d.org/2019-March/010188.html</a><br>
><br>
> Agenda review: looking good.<br>
><br>
> ==================================<br>
><br>
> 2. Update of X3Dv4 Development page forthcoming, following restoration of capability.<br>
> <a href="http://www.web3d.org/wiki/index.php/X3D_version_4.0_Development" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/wiki/index.php/X3D_version_4.0_Development</a><br>
> (snapshot attached for future comparison that changes will be correct)<br>
><br>
> Now that the page is operational again, Don will apply the changes listed last week's minutes, section 2.<br>
><br>
> Category list:<br>
><br>
> === Accepted Capabilities ===<br>
> === Approved Capabilities ===<br>
> === Candidate Capabilities ===<br>
> === Deferred Capabilities ===<br>
> === Deprecated and Removed ===<br>
> === Excluded Capabilities ===<br>
><br>
> Michalis notes that<br>
> a. He is still working on potential Shader revisions. At most he might propose it become Deprecated, not removed.<br>
> > My comment was about "Programmable shaders component" in X3D, that we<br>
> > placed in the "Excluded" section in last week's minutes.<br>
> ><br>
> > To clarify:<br>
> ><br>
> > 1. I am *not* working on it right now.<br>
> ><br>
> > 2. I proposed that, if we do anything with it, we should make it<br>
> > "deprecated", not "excluded". Reasons:<br>
> ><br>
> > - Many browsers implement it (at least FreeWRL, Instant Reality,<br>
> > Castle Game Engine).<br>
> ><br>
> > - It is useful for authors.<br>
> ><br>
> > - Other 3D software/authoring tools also exposes this -- e.g. Unity,<br>
> > Three.js allow to edit the shaders (even though doing it needs to be<br>
> > done carefully, if one doesn't want to break existing rendering).<br>
> ><br>
> > The arguments for deprecating:<br>
> ><br>
> > - Cross-browser compatibility for this is hard (different browsers<br>
> > have various names for uniforms), 100% cross-browser compatibility may<br>
> > be impossible (what can be exposed is connected to internal browser<br>
> > stuff; e.g. do you animate in shaders on not? do you need better<br>
> > floating point precision?)<br>
> ><br>
> > - Unity e.g. deals with it by introducing "surface shaders". Castle<br>
> > Game Engine has "compositing shaders in X3D" (Effect nodes<br>
> > extensions).<br>
><br>
> b. Another item, here is his email:<br>
><br>
> > The second thing (unrelated) I mentioned is that I propose to add<br>
> > "Make RGB and grayscale textures treatment consistent" to the<br>
> > "Accepted" section. My work on it is already on :<br>
> ><br>
> > <a href="https://github.com/michaliskambi/x3d-tests/wiki/Make-RGB-and-grayscale-textures-treatment-consistent" rel="noreferrer noreferrer" target="_blank">https://github.com/michaliskambi/x3d-tests/wiki/Make-RGB-and-grayscale-textures-treatment-consistent</a><br>
><br>
> ==================================<br>
><br>
> 3. *X3D Architecture Design and Events*<br>
><br>
> X3Dv4 design review and discussion of documents/diagrams: Web3D 2017/2018 session notes. Highly detailed event-model diagram are found in prior 2017 X3Dv4 architecture presentations.<br>
><br>
> X3D version 4<br>
> <a href="http://www.web3d.org/x3d4" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/x3d4</a><br>
><br>
> X3D Futures: What is happening, how to get involved!<br>
> Web3D 2018 Conference, Poznan Poland<br>
> <a href="http://www.web3d.org/sites/default/files/page/X3D%20Version%204/X3dFuturesWeb3d2018PoznanPolandBrutzman.pdf" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/sites/default/files/page/X3D%20Version%204/X3dFuturesWeb3d2018PoznanPolandBrutzman.pdf</a><br>
><br>
> "Future of X3D" presentation and detailed notes from Web3D 2017 Conference, Brisbane Australia, 7 June 2017.<br>
> <a href="http://www.web3d.org/sites/default/files/page/X3D%20Version%204/FutureOfX3D.pdf" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/sites/default/files/page/X3D%20Version%204/FutureOfX3D.pdf</a><br>
> <a href="http://www.web3d.org/sites/default/files/page/X3D%20Version%204/FutureOfX3dWeb3d2017June7.pdf" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/sites/default/files/page/X3D%20Version%204/FutureOfX3dWeb3d2017June7.pdf</a><br>
> <a href="http://www.web3d.org/sites/default/files/image/wg/X3D%20Version%204/PresentationPanoramaFutureOfX3dPaulGrimm20170607_135611.1600x492.jpg" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/sites/default/files/image/wg/X3D%20Version%204/PresentationPanoramaFutureOfX3dPaulGrimm20170607_135611.1600x492.jpg</a><br>
><br>
> Based on discussions in Korea and preceding documents, Don has written a further-distilled diagram for HTML5/X3D event models (X3Dv4EventDiagram2019January25.pdf attached). Essentially each (HTML5 and X3D) have internal event loops, and natural times to exchange event buffers occur at the each loop. As with current X3D specification, ordering is guaranteed for each successive timestamp but ordering is not deterministic or guaranteed within a single timestamp.<br>
><br>
> Deep discussions regarding diagram:<br>
> - no changes to X3D or HTML event-render loops are expected,<br>
> - keeping things as simple as possible in the specification is our preferred approach,<br>
> - If we add a diagram to specification, it should add value.<br>
><br>
> Even-simpler event diagram resulted, sketch attached (HtmlX3dEventExchangeSimple.jpg).<br>
><br>
> Existing X3D-only v3.3 specification:<br>
> 4.4.8.3 Execution model, Figure 4.3 ? Conceptual execution model<br>
> <a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#ExecutionModel" rel="noreferrer noreferrer" target="_blank">http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#ExecutionModel</a><br>
><br>
> Link, excerpts from HTML5 Recommendation on event loops:<br>
><br>
> ==============================================<br>
> HTML 5.2, W3C Recommendation, 14 December 2017<br>
> <a href="https://www.w3.org/TR/html52" rel="noreferrer noreferrer" target="_blank">https://www.w3.org/TR/html52</a><br>
><br>
> 1.5.1. Serializability of script execution<br>
> This section is non-normative.<br>
> To avoid exposing Web authors to the complexities of multithreading, the HTML and DOM APIs are designed such that no script can ever detect the simultaneous execution of other scripts. Even with workers, the intent is that the behavior of implementations can be thought of as completely serializing the execution of all scripts in all browsing contexts.<br>
><br>
> -----<br>
><br>
> 1.9.2. Common pitfalls to avoid when using the scripting APIs<br>
> This section is non-normative.<br>
> Scripts in HTML have "run-to-completion" semantics, meaning that the browser will generally run the script uninterrupted before doing anything else, such as firing further events or continuing to parse the document.<br>
><br>
> On the other hand, parsing of HTML files happens incrementally, meaning that the parser can pause at any point to let scripts run. This is generally a good thing, but it does mean that authors need to be careful to avoid hooking event handlers after the events could have possibly fired.<br>
><br>
> There are two techniques for doing this reliably: use event handler content attributes, or create the element and add the event handlers in the same script. The latter is safe because, as mentioned earlier, scripts are run to completion before further events can fire.<br>
> ==============================================<br>
><br>
> Wondering, for full convergence of our sample implementation:<br>
><br>
> a. how have X3DOM and X_ITE each implemented events?<br>
> b. What differences exist?<br>
> c. Are ROUTE connections consistent?<br>
> d. X3DOM is still missing some important/simple Event Utility nodes - is there a problem?<br>
><br>
> Next steps on this topic:<br>
> - write spec prose, then consider if a diagram helps,<br>
> - update presentation materials,<br>
> - offer them as another annual update during Friday 26 JUL 2019 meetings at Web3D 2019.<br>
> <a href="http://web3d2019.web3d.org" rel="noreferrer noreferrer" target="_blank">http://web3d2019.web3d.org</a><br>
><br>
> ==================================<br>
><br>
> 4. Updated README of github specification pages attached for review.<br>
><br>
> As noted a number of times before, our current approach is to<br>
> - follow all Web3D procedures,<br>
> - using mailing list, working group teleconferences and Mantis to create drafts and resolve issues,<br>
> - Dick and Don integrate approved into specification on github.<br>
> - plan Working Draft (WD) at Web3D 2019 with initial functionality,<br>
> - plan Committee Draft (CD) is DEC 2019 with final list of nodes.<br>
> - given improving procedures, opportunity for others to edit spec directly.<br>
><br>
> Discussing schedule:<br>
> - Don and John will be writing X3D JSON Encoding Committee Draft (CD).<br>
> - Another editor assisting us would be helpful.<br>
> - We will also integrate *Tandem Work* listed last week.<br>
> - We will also update all existing encodings: ClassicVRML XML and CompressedBinary.<br>
><br>
> These updates will be applied to the X3Dv4 Development page, posted to list, and discussed next week.<br>
><br>
> As noted earlier, directory names will soon be modified to eliminate whitespace.<br>
><br>
> ==================================<br>
><br>
> 5. Progress report on MetadataSet implementation efforts:<br>
><br>
> As it turns out, the recently identified option to change default containerField value won't work, because all must match to ensure consistent parent-child relationship defaults. Thus merging of MetadataSet.value and MetadataSet.metadata fields as a single MFNode Metadata.children field appears to be the only available resolution of this difficulty.<br>
><br>
> Looking ahead: since prior objections are theoretically reasonable but have never been observed in practice, request that examples demonstrating the necessity current paired-field approach be developed. That way we can more directly evaluate this design issue.<br>
><br>
> [x3d-public] X3D meeting minutes 3 FEB 2019: X3Dv4 mantis github specification changes, glTF plans, MetadataSet<br>
> <a href="http://web3d.org/pipermail/x3d-public_web3d.org/2019-February/010048.html" rel="noreferrer noreferrer" target="_blank">http://web3d.org/pipermail/x3d-public_web3d.org/2019-February/010048.html</a><br>
> section 6. MetadataSet and /metadata/ fields.<br>
><br>
> Don can remember some examples in prior work (though frankly keeping things straight was our biggest challenge then). This exercises the two containerField options. There were no cases where it was essential to disambiguate the set of children nodes as different fields. Design rationale and example template follow.<br>
><br>
> SAVAGE Modeling and Analysis Language (SMAL) Resources<br>
> <a href="https://savage.nps.edu/Savage/Tools/SMAL/SMAL.html" rel="noreferrer noreferrer" target="_blank">https://savage.nps.edu/Savage/Tools/SMAL/SMAL.html</a><br>
><br>
> X3D Example Archives: Savage, Tools, SMAL<br>
> <a href="https://savage.nps.edu/Savage/Tools/SMAL/index.html" rel="noreferrer noreferrer" target="_blank">https://savage.nps.edu/Savage/Tools/SMAL/index.html</a><br>
><br>
> Savage Object Metadata Template<br>
> <a href="https://savage.nps.edu/Savage/Tools/SMAL/SavageObjectMetadataTemplate.x3d" rel="noreferrer noreferrer" target="_blank">https://savage.nps.edu/Savage/Tools/SMAL/SavageObjectMetadataTemplate.x3d</a><br>
> <a href="https://savage.nps.edu/Savage/Tools/SMAL/SavageObjectMetadataTemplate.html" rel="noreferrer noreferrer" target="_blank">https://savage.nps.edu/Savage/Tools/SMAL/SavageObjectMetadataTemplate.html</a><br>
><br>
> Michalis posted exemplar X3D metadata with Blender script that might export metadata.<br>
><br>
> > Inside my "demo models", I have<br>
> ><br>
> > <a href="https://github.com/castle-engine/demo-models/blob/master/x3d/blender_custom_properties.x3d" rel="noreferrer noreferrer" target="_blank">https://github.com/castle-engine/demo-models/blob/master/x3d/blender_custom_properties.x3d</a><br>
> ><br>
> > The idea is that some day we could make X3D exporter that exports this Blender model:<br>
> ><br>
> > <a href="https://github.com/castle-engine/demo-models/blob/master/x3d/blender_custom_properties.blend" rel="noreferrer noreferrer" target="_blank">https://github.com/castle-engine/demo-models/blob/master/x3d/blender_custom_properties.blend</a><br>
> ><br>
> > with the metadata. It has<br>
> ><br>
> > <MetadataSet name="custom_properties"><br>
> > <MetadataString containerField='value' name='MyObjectProperty' value='"object prop value"'/><br>
> > <MetadataInteger containerField='value' name='IntProperty' value='123'/><br>
> > <MetadataFloat containerField='value' name='FloatProperty' value='456.789'/><br>
> > </MetadataSet><br>
> ><br>
> > The containerField may look "too elaborate", but it works nicely in practice<br>
> ><br>
> > Regards,<br>
> > Michalis<br>
><br>
> ==================================<br>
><br>
> Thanks for many contributions and persisting through another necessary slog today.<br>
><br>
> Of note is that no major showstoppers are noted, rather we are getting closer to a comprehensive X3Dv4-HTML5 architecture each time.<br>
><br>
> Having fun with X3Dv4!<br>
><br>
> all the best, Don<br>
> --<br>
> Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank" rel="noreferrer">brutzman@nps.edu</a><br>
> Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149<br>
> X3D graphics, virtual worlds, navy robotics <a href="http://faculty.nps.edu/brutzman" rel="noreferrer noreferrer" target="_blank">http://faculty.nps.edu/brutzman</a><br>
><br>
><br>
><br>
> -------------- next part --------------<br>
> A non-text attachment was scrubbed...<br>
> Name: X3Dv4EventDiagram2019January25.pdf<br>
> Type: application/pdf<br>
> Size: 49816 bytes<br>
> Desc: X3Dv4EventDiagram2019January25.pdf<br>
> URL: <<a href="http://web3d.org/pipermail/x3d-public_web3d.org/attachments/20190301/d5ab18c3/attachment.pdf" rel="noreferrer noreferrer" target="_blank">http://web3d.org/pipermail/x3d-public_web3d.org/attachments/20190301/d5ab18c3/attachment.pdf</a>><br>
> -------------- next part --------------<br>
> A non-text attachment was scrubbed...<br>
> Name: HtmlX3dEventExchangeSimple.jpg<br>
> Type: image/jpeg<br>
> Size: 80871 bytes<br>
> Desc: HtmlX3dEventExchangeSimple.jpg<br>
> URL: <<a href="http://web3d.org/pipermail/x3d-public_web3d.org/attachments/20190301/d5ab18c3/attachment.jpg" rel="noreferrer noreferrer" target="_blank">http://web3d.org/pipermail/x3d-public_web3d.org/attachments/20190301/d5ab18c3/attachment.jpg</a>><br>
><br>
> ------------------------------<br>
><br>
> Subject: Digest Footer<br>
><br>
> _______________________________________________<br>
> x3d-public mailing list<br>
> <a href="mailto:x3d-public@web3d.org" target="_blank" rel="noreferrer">x3d-public@web3d.org</a><br>
> <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" rel="noreferrer noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
><br>
><br>
> ------------------------------<br>
><br>
> End of x3d-public Digest, Vol 120, Issue 3<br>
> ******************************************<br>
<br>
<br>
<br>
-- <br>
Andreas Plesch<br>
Waltham, MA 02453<br></div></div>