<div dir="auto"><div dir="auto"><br></div><div dir="auto"><br></div><div><div class="gmail_extra"><div class="gmail_quote">On Sep 25, 2017 9:17 AM, "Don Brutzman" <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br type="attribution"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">[levels of indentation in reply not being honored by mailer, hopefully transcribed here OK. focused on your recent reply prose.]<div class="m_5402697757400422044quoted-text"></div></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">I am having trouble with the Android mail client which has its own ideas about mail style indenting.</div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="m_5402697757400422044quoted-text"><br>
On 9/24/2017 8:14 AM, Andreas Plesch wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
<a href="http://x3dom-integertrigger.glitch.me/IntegerTrigger_test.x3d" rel="noreferrer" target="_blank">http://x3dom-integertrigger.gl<wbr>itch.me/IntegerTrigger_test.x3<wbr>d</a> has now a way to test set_boolean false:<br>
Clicking on the left cone starts a timer which switches left text off right away and after 2 seconds. So one can click on the right cone to switch left text back on and see if it is switched off after 2 seconds. It is, for all browsers I tested.<br>
<br>
Octaga, view3dscene and x_ite all trigger on set_boolean false.<br>
</blockquote>
<br></div>
it looks like it did the same in InstantReality, though timing seemed immediate.<br></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">It is an awkward test. I wanted to avoid any other event utility node and also the script node, so this was the only scene I could come up with.</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
these are helpful tests but it is certainly a challenge to sleuth how well different players conform.<div class="m_5402697757400422044quoted-text"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Apart from avoiding backwards incompatible changes, there are other arguments but overall I agree restricting triggering to 'True' input adds simplicity and clarity. I do think such would need to be considered as a backwards incompatible change.<br>
<br>
I would probably prefer to avoid confusion between spec. language and tool tip language, meaning marking the set_boolean true explanations in the tool tips somehow.<br>
</blockquote>
<br></div>
Very good. Have amended hint in tooltips.<div class="m_5402697757400422044quoted-text"><br>
<br>
"Hint: input event set_boolean false has no effect."<br>
<br></div>
to<br>
<br>
"Hint: for logical consistency, input event set_boolean false has no effect (under review as part of Mantis issue 519)."<div class="m_5402697757400422044quoted-text"></div></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">Well, currently it has an effect. So a reader may conclude that the review is about having no effect and was already resolved to change to having an effect. </div><div dir="auto">Perhaps:</div><div dir="auto"><span style="font-family:sans-serif">"Hint: for logical consistency, input event set_boolean false is under review as part of Mantis issue 519 targeting such an event to have no effect." ?</span></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="m_5402697757400422044quoted-text"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
In terms of an IntegerTrigger node for x3dom, there just needs to be a decision. I lean towards being compatible with other browsers and a straight interpretation of the current spec. language. There also could be a IntegerTrueTrigger to enable use of the new behaviour.<br>
</blockquote>
<br></div>
Throughout this effort let's decide on simplest and most consistent approach with honoring 'true' events only. Specification process can review and confirm.</blockquote></div></div></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
[now manually reconstructing email-thread levels, hopefully OK]<div class="m_5402697757400422044quoted-text"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Looking into TimeTrigger next.<br>
</blockquote>
<br>
same as point (2), only honoring true events for simplicity and logical clarity.<br>
</blockquote>
<br>
Agreed in general. Likely browsers currently also honor false events but will test.<br>
</blockquote>
<br></div>
OK, great let's keep converging on best answer. As before, reacting to false events is logically confusing and makes design/debugging quite convoluted.<div class="m_5402697757400422044quoted-text"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Feels like we got another step closer, thanks...<br>
<br>
Once we have all this distilled in Mantis issue capturing best-effort prose, it will hopefully be straightforward to confirm resolution.<br>
</blockquote>
<br>
I do not have a sense of how widely the event utilities are used, eg. what the impact of such a resolution would be. I think it would be a positive change but a change nonetheless recognizing that this is the behaviour as it was originally intended.<br>
</blockquote>
<br></div>
Well, "originally intended" is a bit strong! Correctness and usefulness was always intended, functional design of these nodes has just turned out to be more subtle than expected. I think the original ambiguities in spec prose reflect a lack of clarity that continued practice has helped us to understand.<br></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">I think a source of ambiguity is that Boolean can be considered as a logical true/false decision but also simply as neutral two state container bit 0/1, flip/flop.</div><div dir="auto"><br></div><div dir="auto">Treated as a state, it may be valuable to trigger whenever the state is affected by an action.</div><div dir="auto"><br></div><div dir="auto">But overall, I agree, that triggering only on true is simplest. Triggering also on false then could be accomplished by a toggle.</div><div dir="auto"><br></div><div dir="auto">But now I may want to know more about the original design strategy. I suspect it was based on how to get TouchSensor work with Switch in an easy way ?</div><div dir="auto"><br></div><div dir="auto">Here is another thought. In a scene, can IntegerTrigger be substituted by a single keyvalued IntegerSequencer using the next field which explicitly ignores false input ? I think so. It probably still makes sense to have it for scene readability and optimized implementation.</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Getting the event utility functional descriptions distilled to the most concise, coherent and consistent approach will help animation correctness and meet the original intent of this component. Ignoring set_boolean false events definitely helps.<br></blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">Yes, it does. I do think browsers just follow the spec. It may be almost trivial to implement the new behavior for any browser perhaps making it even conditional on the x3d version declared for the scene. But it requires new releases and will take time.</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
Again thanks for your efforts together on this design Andreas.</blockquote></div></div></div><div dir="auto"><br></div><div dir="auto">Just following along,</div><div dir="auto"><br></div><div dir="auto">Andreas</div><div dir="auto"><div class="gmail_extra"><div class="gmail_quote"><blockquote class="m_5402697757400422044quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="m_5402697757400422044elided-text"><br>
<br>
all the best, Don<br>
-- <br>
Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA <a href="tel:%2B1.831.656.2149" value="+18316562149" target="_blank">+1.831.656.2149</a><br>
X3D graphics, virtual worlds, navy robotics <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzma<wbr>n</a><br>
</div></blockquote></div><br></div></div></div>