<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>Don, it would be good to mark out in code when the various methods were introduced into Java SAI, so we know what is compatible with older versions. I think the annotation is @since.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks,</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">Don Brutzman</a><br><b>Sent: </b>Thursday, July 20, 2017 4:11 PM<br><b>To: </b><a href="mailto:yottzumm@gmail.com">John Carlson</a><br><b>Subject: </b>Re: setUSE in X3DJSAIL</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 7/20/2017 8:53 AM, John Carlson wrote:</p><p class=MsoNormal>> I think the resetting of values is if you change the USE attribute to another DEF value.  Is that possible?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>A good way to confirm the answer to such questions is by testing code.  The HelloWorldProgram.java test program (excerpted/linked in prior email response) does that.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>In theory that can be certainly be tricky... so design patterns and best practices can help.  X3DJSAIL methods will clear a DEF value if setting a USE value, and vice versa.  Validation methods are further strict in order to detect problems.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>This approach (explicitly treating DEF and USE similarly to other fields) copes with an omission in the original Java SAI where DEF/USE did not seem to be explicitly supported, preventing serialization.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Because some X3D scene problems are best prevented at compile time (via careful construction of library interfaces), while other problems can only be detected at run time (e.g. validation testing to confirm whether there a DEF node of same node type in the connected scene subgraph), this can be a tricky business.  Getting the right patterns is really helpful because then all of the classes are autogenerated consistently, enabling best practices.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Meanwhile, for DOM as a different object model, is is interesting to note that either DEF or USE attributes (or both) might be set on an X3D node via the DOM interface as well.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>X3DJSAIL currently appears to get the job done effectively, with a further balance to simplify authoring and then confirm correctness using validation.  Once again, these design choices are intended to simplify creation of good X3D models while making creation of incorrect X3D models difficult.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Further problem and solution reports will always be welcome.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                X3D Java Scene Access Interface Library (X3DJSAIL)</p><p class=MsoNormal>                supports programmers with standards-based X3D Java interfaces and objects, all as open source.</p><p class=MsoNormal>                http://www.web3d.org/specifications/java/X3DJSAIL.html</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>