<div dir="ltr">Also can convert XML to JSON!<div><br></div><div>Go Holger!</div><div><br></div><div>John</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, Oct 8, 2023 at 12:02 AM Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu">brutzman@nps.edu</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class="msg-5364132935792489613"><div lang="EN-US" style="overflow-wrap: break-word;"><div class="m_-5364132935792489613WordSection1"><p class="MsoNormal">Holger, something I just noticed about this: you are loading a .gltf file but displaying it as an X3D file in X_ITE Playground?<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Interesting, assume you are converting directly from glTF JSON to X3D XML on the fly…<u></u><u></u></p><div><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New""><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New"">all the best, Don<u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New"">-- <u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New"">Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New"">Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149<u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9pt;font-family:"Courier New"">X3D graphics, virtual worlds, navy robotics <a href="https://faculty.nps.edu/brutzman" target="_blank">https://faculty.nps.edu/brutzman</a><u></u><u></u></span></p></div><p class="MsoNormal"><u></u> <u></u></p><div><div style="border-right:none;border-bottom:none;border-left:none;border-top:1pt solid rgb(225,225,225);padding:3pt 0in 0in"><p class="MsoNormal"><b>From:</b> Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>> <br><b>Sent:</b> Monday, September 25, 2023 4:04 PM<br><b>To:</b> Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>><br><b>Cc:</b> Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>; Joe D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>>; X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>; Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>><br><b>Subject:</b> Re: [x3d-public] Negative scale and winding order<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">There is another glTF negative scale test:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><p class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fraw.githubusercontent.com%2FKhronosGroup%2FglTF-Sample-Models%2Fmaster%2F2.0%2FNegativeScaleTest%2FglTF%2FNegativeScaleTest.gltf&data=05%7C01%7Cbrutzman%40nps.edu%7C46179475647e4b5b0d3c08dbbe1bb590%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638312798479012285%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=P7s2bOtTjM1C8B6mP3jHhvFQ%2B6OtMoSTfNFydbEas4g%3D&reserved=0" target="_blank">https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/NegativeScaleTest/glTF/NegativeScaleTest.gltf</a> <u></u><u></u></p><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">View in Playground:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fcreate3000.github.io%2Fx_ite%2Fplayground%2F%3Furl%3Dhttps%3A%2F%2Fraw.githubusercontent.com%2FKhronosGroup%2FglTF-Sample-Models%2Fmaster%2F2.0%2FNegativeScaleTest%2FglTF%2FNegativeScaleTest.gltf&data=05%7C01%7Cbrutzman%40nps.edu%7C46179475647e4b5b0d3c08dbbe1bb590%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638312798479012285%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=i4ydl0AFyPBHrlz9109s9vpxdG3CRIP68ZafsAioGO0%3D&reserved=0" target="_blank">https://create3000.github.io/x_ite/playground/?url=https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/NegativeScaleTest/glTF/NegativeScaleTest.gltf</a><u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p><div><div><div><div><div><div><div><div><p class="MsoNormal"><span style="color:black">--<u></u><u></u></span></p></div><div><p class="MsoNormal"><span style="color:black">Holger Seelig<u></u><u></u></span></p></div><div><p class="MsoNormal"><span style="color:black">Leipzig, Germany<u></u><u></u></span></p></div><div><p class="MsoNormal"><span style="color:black"><u></u> <u></u></span></p></div><div><p class="MsoNormal"><span style="color:black"><a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a><u></u><u></u></span></p></div><div><p class="MsoNormal"><span style="color:black"><a href="https://create3000.github.io/x_ite/" target="_blank">https://create3000.github.io/x_ite/</a><u></u><u></u></span></p></div></div></div></div></div></div></div></div><div><p class="MsoNormal"><br><br><u></u><u></u></p><blockquote style="margin-top:5pt;margin-bottom:5pt"><div><p class="MsoNormal">Am 25.09.2023 um 04:14 schrieb Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>>:<u></u><u></u></p></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">Using Holger's example of using negative scale for mirroring, this<br>gist shows how various browsers treat negative scale:<br><br><a href="https://gist.github.com/andreasplesch/220e5b2bdc5422d998b24f30f90e255d" target="_blank">https://gist.github.com/andreasplesch/220e5b2bdc5422d998b24f30f90e255d</a><br><br>It turns out all browsers do not treat negative scale as a special<br>case leading to inverted faces.<br><br>This does not necessarily mean that x3d could not align with glTF type<br>negative scale behaviour in the future but it clearly shows that spec.<br>changes would be needed.<br><br>Another consideration is that the required checking for negative scale<br>requires some per frame cost which currently is overhead for almost<br>all scenes but could be seen as a worthwhile investment to make<br>negative scale usable for mirroring purposes.<br><br>I think Viewpoints are already required to ignore scale, so that<br>should not be an issue.<br><br>The x3dom dev. version now supports negative scale for glTF inlines as<br>required by the glTF spec. It would be straightforward to expand that<br>behaviour to all Shapes.<br><br>-Andreas<br><br>On Fri, Sep 22, 2023 at 1:00 PM Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:<br><br><u></u><u></u></p><blockquote style="margin-top:5pt;margin-bottom:5pt"><p class="MsoNormal"><br>I looked into the feasibility of automatically adjusting ccw based on<br>negative world scale for x3dom. It looks like it could be pretty<br>straightforward but has a potentially significant drawback for scenes<br>with a lot of Shapes. Since it requires computing the determinant at<br>every frame for every Shape, it actually would likely be slower than<br>just using solid='false' even if that doubles the amount of drawing<br>because that is entirely GPU based. Also it would impact any scene. So<br>I am not sure if supporting a negative scale is worth the performance<br>cost across the board. This is potentially the reason why it is<br>optional for view3dscene. For glTF support, in x3dom it is still<br>possible to only compute the determinant at every frame for<br>BufferGeometry which is the only geometry used for glTF. So I am<br>leaning towards enabling automatic ccw for negative scale only for<br>glTF inlines (which is opaque to the X3D spec.) and otherwise<br>recommending solid='false' for mirroring use cases.<br><br>-Andreas<br><br>On Fri, Sep 22, 2023 at 12:02 PM Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:<br><br><u></u><u></u></p><blockquote style="margin-top:5pt;margin-bottom:5pt"><p class="MsoNormal"><br>We could check behaviour of other existing X3D browsers, especially<br>freeWRL, Octaga and BSContact which are still available.<br><br>Since negative scaling has not been historically supported, it may be<br>worth deviating from established, but not well defined interpretations<br>in browsers. This would definitely require a spec. change/addition.<br><br>glTF compatibility can be accomplished by checking for negative scale<br>during import and adjusting ccw accordingly, or by global behaviour<br>affecting all geometres. If there are no backward compatibility<br>concerns, consistent behaviour for any affected geometry would be most<br>helpful for authoring.<br><br>glTF style, automatic adjustment of normals in case of negative<br>scaling presumably also applies to explicitly provided normals (in<br>normal maps) ? I think it must to support the mirroring use case.<br><br><a href="https://github.com/KhronosGroup/glTF/issues/1697" target="_blank">https://github.com/KhronosGroup/glTF/issues/1697</a> has more discussion<br>about similar questions and points to<br><br><a href="https://github.com/KhronosGroup/glTF-Asset-Generator/blob/master/Output/Positive/Node_NegativeScale/README.md" target="_blank">https://github.com/KhronosGroup/glTF-Asset-Generator/blob/master/Output/Positive/Node_NegativeScale/README.md</a><br><br>for a series of tests.<br><br>-Andreas<br><br><br>On Thu, Sep 21, 2023 at 7:55 PM Brutzman, Donald (Don) (CIV)<br><<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br><br><u></u><u></u></p><blockquote style="margin-top:5pt;margin-bottom:5pt"><p class="MsoNormal" style="margin-bottom:12pt"><br>Negative scaling is certainly a special case and not something that has historically been supported in VRML or X3D. Thanks for careful consideration of any unexpected variations.<br><br>Our design goals make it clear that we have no desire to vary from glTF in X3D 4.0. If there are any recommendations needed for authors to maximize and hopefully achieve full interoperability with glTF rendering, they are always welcome.<br><br>v/r Don<br>________________________________<br>From: x3d-public <<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>> on behalf of Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>><br>Sent: Thursday, September 21, 2023 2:56:48 PM<br>To: Joe D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>><br>Cc: Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>>; X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>; <a href="mailto:holger.seelig@googlemail.com" target="_blank">holger.seelig@googlemail.com</a> <<a href="mailto:holger.seelig@googlemail.com" target="_blank">holger.seelig@googlemail.com</a>><br>Subject: Re: [x3d-public] Negative scale and winding order<br><br>Unfortunately, I can't just change something that has been implemented this way since the beginning of X_ITE's existence. The way X_ITE handles negative scaling is exactly the way it is specified in glTF, which is not bad and is implemented in CGE under the term Robust Negative Scale. Until everything is thought over, I have to agree with Andreas with his advice to just set the solid field to false, as it is the easiest way to avoid this issue.<br><br>Best regards,<br>Holger<br><br>--<br>Holger Seelig<br>Leipzig, Germany<br><br><a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a><br><a href="https://create3000.github.io/x_ite/" target="_blank">https://create3000.github.io/x_ite/</a><br><br>Am 21.09.2023 um 19:24 schrieb Joe D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>>:<br><br>So perhaps the question is how to apply negative scale transforms tonormals as intended by the spec.The Leif example has ccw=false and a negative scale (for z). Itappears as outside in on x_ite and outside out on view3dscene andx3dom.<br><br><br>Of course I am interested in this because to me the X_ITE rendering is wrong, unless that is, the player is required to reverse the normals for scale z = -1.<br>X_ITE is 'automagically' reversing the normals, so when I do the ccw=FALSE the thing is transparent from the front of the polygon. Of course if I use ccw=TRUE then the other tools look like X_ITE, transparent from the front.<br><br>Holger, can you please either convince the other players they are wrong, or fix yours to work like the rest. If the spec is not certain what to do about this, then please either fix the spec or X_ITE.<br><br>I just want the model to show as intended and be correct, even if sort of a practical hack, so please l figure it out because I really need everyone to do the right thing on this, whatever that might be.<br><br>. Thanks and Best Regards,<br>Joe<br><br><br>-----Original Message-----<br>From: Joe D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>><br>Sent: Sep 19, 2023 1:26 PM<br>To: Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>>, X3D Graphics public mailing list <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>, <<a href="mailto:holger.seelig@googlemail.com" target="_blank">holger.seelig@googlemail.com</a>><br>Subject: Re: [x3d-public] Negative scale and winding order<br><br>While this approach is very practical, I am not sure what the spec.actually requires in this respect.<br><br><br>I did not care, it worked and I will look more later. The following is all good. I think the players show it different because the user code is changed from what I sent.<br><br><br>Sorry I sort of wrote this off, to both you and Holger.<br>A good, reliable solution to this problem is needed, as learned or not from recent experience.<br><br>One thing I think happened to me was seeing that common graphics authoring programs use as a 'Native' default or pre-selected +Zin with left-hand rule for axis rotations.<br>For the Humanoid animation, we want to align ourselves in +Zout character space, so the character Front is looking out of the screen with +y up, +x to character left. In the case of x3d +Zout, the character is gaze is toward +z. In the case of +Zin, the character Front gaze is toward -z. Or, we may find the situation where the character is drawn in +Zin with gaze toward +z.<br><br>For HAnim there are three main issues: skeleton and skin and animations. Well, actually these boil down into just one problem: They all have to work together. So to even consider importing stuffs drawn or animated in a different space a plan is needed. I used standard features to force display of skin because it was drawn in a different space. This almost worked everywhere.<br><br>I think it should work everywhere, because the -1 for z scaling is going to operate just the same as if I had actually negated the coord points(?). Since the +Zin model with scale 1 1 1 will be seen as facing -z the character's back is toward the x3d default camera. Using scale 1 1-1 operates so that the character is now facing the x3d default camera.<br>However, just guessing, since the polygon that was drawn ccw true is now being drawn ccw false and is now transparent from its front. Changing ccw to false seemed to get the normal aimed in the right direction.<br><br>Thanks for the help,<br>Joe<br><br><br><br><br><br><br><br>-----Original Message-----<br>From: Joe D Williams<br>Sent: Sep 19, 2023 11:09 AM<br>To: Andreas Plesch , X3D Graphics public mailing list<br>Subject: Re: [x3d-public] Negative scale and winding order<br><br><br>-----Original Message-----<br>From: Andreas Plesch<br>Sent: Sep 19, 2023 9:03 AM<br>To: X3D Graphics public mailing list<br>Subject: [x3d-public] Negative scale and winding order<br><br>Holger made good points on why a negative scale in the parent<br><br>transform should not affect which side of a geomet is considered<br>facing outward and visible with solid=true.<br><br>OK, I thought I tried that with no effect.<br><br>While this approach is very practical, I am not sure what the spec.<br><br>actually requires in this respect.<br><br>I did not care, it worked and I will look more later.<br>The following is all good. I think the players show it different because the user code is changed from what I sent.<br><br>First, it does not explicitly single out the case of a negative scale.<br><br>Should it ? If so, it would probably have to deal with the effective<br>world transform.<br><br><a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/components/rendering.html#CommonGeometryFields" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/components/rendering.html#CommonGeometryFields</a><br><br>'The ccw field defines the ordering of the vertex coordinates of the<br>geometry with respect to user-given or automatically generated normal<br>vectors used in the lighting model equations. If ccw is TRUE, the<br>normals shall follow the right hand rule; the orientation of each<br>normal with respect to the vertices (taken in order) shall be such<br>that the vertices appear to be oriented in a counterclockwise order<br>when the vertices are viewed (in the local coordinate system of the<br>Shape) from the opposite direction as the normal. If ccw is FALSE, the<br>normals shall be oriented in the opposite direction. If normals are<br>not generated but are supplied using a Normal node, and the<br>orientation of the normals does not match the setting of the ccw<br>field, results are undefined.'<br><br>has the relevant ccw field language.<br><br>I think the specified process is:<br><br>- Compute the outward facing normal of a triangle using the ordering<br>of the vertices in such a way that the ordering appears<br>counterclockwise when viewed in the opposite direction of the computed<br>normal. This uses the local, untransformed (raw) coordinates.<br><br>- invert the normal if ccw=false.<br><br>- Apply the accumulated transforms to both the vertices and the<br>computed normal. The spec. has a strict definition on how to apply a<br>transform to vertices to transform from the child space to the parent<br>space. For normals transformations there is a computer graphics<br>standard approach and probably opengl based equations but the spec.<br>itself seems to be silent.<br><br>So perhaps the question is how to apply negative scale transforms to<br>normals as intended by the spec.<br><br>The Leif example has ccw=false and a negative scale (for z). It<br>appears as outside in on x_ite and outside out on view3dscene and<br>x3dom.<br><br>A workaround is solid=false but that may not always be possible or desired.<br>Another workaround is to not use negative scales/mirroring, eg.<br>preprocess geometry accordingly which seems like a major limitation.<br><br>-Andreas<br><br>On Tue, Sep 19, 2023 at 10:37 AM wrote:<br><br><br>Send x3d-public mailing list submissions to<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><br>To subscribe or unsubscribe via the World Wide Web, visit<br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>or, via email, send a message with subject or body 'help' to<br><a href="mailto:x3d-public-request@web3d.org" target="_blank">x3d-public-request@web3d.org</a><br><br>You can reach the person managing the list at<br><a href="mailto:x3d-public-owner@web3d.org" target="_blank">x3d-public-owner@web3d.org</a><br><br>When replying, please edit your Subject line so it is more specific<br>than "Re: Contents of x3d-public digest..."<br><br><br>2. Negative Scale<br><br>A negative scale will not affect what is front face and what is back face. This means that a Text node with solid true, mirrored with negative scale (0 -1 0), also shows its front face to the camera. This makes it possible to create a text with solid true which has a mirrored counterpart which is a clone of the Text node.<br><br>A negative scale will not turn the model inside out, it stays as it is. The main advantage is as described above: we can use solid true models in many situations where a negative scale is used without flipping inside out.<br><br>This effect is achieved by detecting if there is any negative scale, which can be determined if the determinant of the scale-rotation matrix is less than zero. If this is the case, ccw must be exchanged with cw and vice versa.<br><br><br>_______________________________________________<br>x3d-public mailing list<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br><br><br>_______________________________________________<br>x3d-public mailing list<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br><br><br><br>_______________________________________________<br>x3d-public mailing list<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br><br><br><br>_______________________________________________<br>x3d-public mailing list<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br><br><u></u><u></u></p></blockquote><p class="MsoNormal"><br><br>--<br>Andreas Plesch<br>Waltham, MA 02453<u></u><u></u></p></blockquote><p class="MsoNormal"><br><br><br>--<br>Andreas Plesch<br>Waltham, MA 02453<u></u><u></u></p></blockquote><p class="MsoNormal"><br><br><br>-- <br>Andreas Plesch<br>Waltham, MA 02453<u></u><u></u></p></div></div></blockquote></div><p class="MsoNormal"><u></u> <u></u></p></div></div></div></div>_______________________________________________<br>
x3d-public mailing list<br>
<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
<a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
</div></blockquote></div>