<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>Great, I really like your comments that and will have another look. </p><p class=MsoNormal>The main ideas are that I think automagic generation of empty texCoordIndex for all IndexedFaceSet nodes. </p><p class=MsoNormal>I don’t see any reason to disallow this for hanim. Sure, it may be very unusual if possible at all to make sense of any humanoid textures from a default set of coordinates but it should be allowed as in the rest of x3d. Not tried them all now, but I have only found one browser that would not accept the input and not provide a consistent autogen. As for the TextureCoordinate set, that always seemed to work as a way of limiting use of the supplied texture to a certain area, and of course if I only give it one set, or just a few, I want them duplicated by default. I will look again but I don’t see why I should need more than the supplied number of values to use a part of the supplied texture to be used for the thing. There are several other fields, like color per vertex, where if you give one set, or eve just a few sets, they get recycled in sequence. The texturetransform seems to work ok without more detail. It shuld try to use what you give it. In this case, an advisory that the single value is being reused, as any author might expect to be the default friendly way. In the same example, ball_Shape does not need all that extra stuff – it is an ifs, so I get the default texturing for free as expected.  </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>OF course all this is different if I choose another geometry for the skin instead of the ifs, then I gotta worry about all that stuff lining up because the browser does not figure it for you. I will check the spec again for these details. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks, Andreas, for looking at the kicker - glad you can do the skin. That joint-skin binding is hard, but the texture-geometry binding … harder?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I think x3d should be very accepting, for simple stuff, like I showed. Learning the skeleton structure, animating the skeleton, using segment geometry, using skin geometry, skeleton-skin bindings and weights, texture-geometry bindings, hanim displacers, and all great reasons to say that learning x3d hanim will not be a waste of time to anyone who wants to see what is actually making the model animation happen. And of course we need to get some advanced texturing and animation features onto the mix. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks again, the x3d xml user code you set up is fine and runs fine where I have tested it. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>>> The intention may be that the texture coordinates are recycled as it<o:p></o:p></p><p class=MsoNormal>is possible with some other fields. However, validation should fail if<o:p></o:p></p><p class=MsoNormal>it included checking for this requirement. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes, that is the intent. Anyway, please. IFS have special cases for these fields. Not like other geometries. Missing this stuff is not failing, but since the intent is recycling, if the validator catches that,  then, for ifs, it should be warning, not failure, if possible. After all, without the stuff, for ifs, it runs everywhere the spec is followed. <o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>All Best, </p><p class=MsoNormal>Joe </p><p class=MsoNormal><o:p> </o:p></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:andreasplesch@gmail.com">Andreas Plesch</a><br><b>Sent: </b>Wednesday, August 8, 2018 2:25 PM<br><b>To: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a><br><b>Subject: </b>[x3d-public] JoeSkinTexcoordDisplacerKick example issue</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>http://www.web3d.org/x3d/content/examples/Basic/HumanoidAnimation/JoeSkinTexcoordDisplacerKickIndex.html</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>has an excellent example of HAnim animation using many of its features.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It has a large IndexedFaceSet node which contains the player:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><IndexedFaceSet DEF='Joe_skin_IndexedFaceSet' ..</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The node has an empty texCoordIndex field and a short texCoord field:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><TextureCoordinate point='0 0 0.5 0.5 0.5 0 0 0.5'/></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/geometry3D.html#IndexedFaceSet</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>section g) requires that there are N+1 texture coordinates with N</p><p class=MsoNormal>being the largest index in coordIndex. The largest index in coordIndex</p><p class=MsoNormal>is 389. There are 390-4 texture coordinates missing.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The intention may be that the texture coordinates are recycled as it</p><p class=MsoNormal>is possible with some other fields. However, validation should fail if</p><p class=MsoNormal>it included checking for this requirement.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Here is a fixed x3d file:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>https://raw.githubusercontent.com/x3dom/x3dom/master/test/functional/hanim/JoeSkinTexcoordDisplacerKickTest.x3d</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>-Andreas</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>--</p><p class=MsoNormal>Andreas Plesch</p><p class=MsoNormal>Waltham, MA 02453</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>_______________________________________________</p><p class=MsoNormal>x3d-public mailing list</p><p class=MsoNormal>x3d-public@web3d.org</p><p class=MsoNormal>http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>