<div dir="auto">As a developer, i agree that normal and vector geometry (not mesh indexes) should be done on the CPU. On older systems <= 2016, modifying mesh vertex coordinates (from spheres or primarily IFS) is otherwise performance inhibited, at least on my 100x100 grids. Computing in the shader works great in browser, as shown with PlayCanvas and non-standard subdivisions in X3DOM. We probably shouldn’t be setting or modifying the vertices or normals in CPU. Yes, we should be laying out indexes and mesh connections in the CPU, especially when mesh connections change.</div><div dir="auto"><br></div><div dir="auto">Note: I am not talking about texture at this point, since existing textures in my programs are provided by fragment shaders and cube maps (after any vertex manipulation). I don’t know how to do X3D texture coordinated at all. Indeed, I don’t really know how the fragment shader is working. All i know is, the fragment shader and vertex shader work great. My goal is primarily ray tracing or ray marching, etc.</div><div dir="auto"><br></div><div dir="auto">I hope people understand my prose.</div><div dir="auto"><br></div><div dir="auto">John</div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Jan 4, 2023 at 12:24 PM Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com">michalis.kambi@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;padding-left:1ex;border-left-color:rgb(204,204,204)">Thanks Don,<br>
<br>
I understand we are aligned then -- and consider the current<br>
X_ITE/view3dscene/CGE/InstantReality approach to be correct then.<br>
<br>
And for Joe testcase, the resolution is just that (if you want texture<br>
to "stick") then explicit texture coordinates should be specified,<br>
using TextureCoordinate.<br>
<br>
( Otherwise, I admit I wanted to object to your earlier suggestion --<br>
I think it would be harder to specify exactly when to recalculate and<br>
when not to. And then we go into discussion how does it interact with<br>
TextureCoordinateGenerator, whether it is doable on GPU etc. So it's<br>
better to keep it simple, as it is now. )<br>
<br>
I'm cool with your proposed clarification sentence """Texture<br>
coordinates are reapplied or else recomputed (if initially NULL)<br>
whenever the corresponding vertex-based geometry changes.”"".<br>
Moreover, I would advise adding the same sentence to<br>
TextureCoordinateGenerator prose,<br>
<a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/components/texturing.html#TextureCoordinateGenerator" rel="noreferrer" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/components/texturing.html#TextureCoordinateGenerator</a><br>
, to make it clear that the situation is consistent for it.<br>
<br>
Note that glTF doesn't have an equivalent feature, so we don't need to<br>
worry about glTF here. In glTF, texture coordinates have to be always<br>
provided if you want to render the texture. There's no automatic<br>
recalculation. So they kind of avoided the whole issue :)<br>
<br>
As for feature idea "might precomputation and addition of texture<br>
coordinates be an option in your converter?" -- hmm, it is definitely<br>
sensible and I see it would be useful (like in this case for Joe<br>
humanoid). But I admit it is not trivial -- because we don't actually<br>
do such calculation now on CPU, that is in CGE we *do not* at any<br>
point calculate automatic texture coordinates on CPU. If the automatic<br>
coordinates are needed (following bounds of shape, or following<br>
TextureCoordinateGenerator) they are just calculated during rendering<br>
on GPU, and we don't really save them anywhere (right now). So, it is<br>
certainly possible but would be quite some additional work to add<br>
"precalculating texture coords".<br>
<br>
Regards,<br>
Michalis<br>
<br>
śr., 4 sty 2023 o 18:41 Brutzman, Donald (Don) (CIV)<br>
<<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> napisał(a):<br>
><br>
> Michalis, apologies our mail crossed. Thanks for excellent and thorough explanation.<br>
><br>
><br>
><br>
> Am keen to keep things aligned as you and Holger (two leading implementers) think best.<br>
><br>
><br>
><br>
> Wondering: are there any further clarifications to add to specification, preventing ambiguous interpretation? For example, perhaps adding a sentence:<br>
><br>
> X3D4, Texturing component, 18.2.3 Texture coordinates<br>
> <a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/components/texturing.html#TextureCoordinates" rel="noreferrer" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/components/texturing.html#TextureCoordinates</a><br>
> “Texture coordinates are reapplied or else recomputed (if initially NULL) whenever the corresponding vertex-based geometry changes.”<br>
><br>
><br>
><br>
> Also wondering: might precomputation and addition of texture coordinates be an option in your converter? Given continued inconsistencies of Blender export to X3D, this might be especially helpful as we try to achieve consistent X3D browser rendering for advanced HAnim skin examples. If that is possible, Joe and I will be happy to update texture coordinates and test relevant X3D HumanoidAnimation example models accordingly.<br>
><br>
><br>
><br>
> Castle Game Engine: Convert everything to X3D<br>
> <a href="https://castle-engine.io/convert.php" rel="noreferrer" target="_blank">https://castle-engine.io/convert.php</a><br>
><br>
><br>
><br>
> HumanoidAnimation (HAnim) X3D Examples Archive<br>
> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation</a><br>
><br>
><br>
><br>
> all the best, Don<br>
><br>
> --<br>
><br>
> Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
><br>
> Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149<br>
><br>
> X3D graphics, virtual worlds, Navy robotics https:// <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">faculty.nps.edu/brutzman</a><br>
><br>
><br>
><br>
> -----Original Message-----<br>
> From: x3d-public <<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>> On Behalf Of Michalis Kamburelis<br>
> Sent: Wednesday, January 4, 2023 8:00 AM<br>
> To: Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>><br>
> Cc: X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> Subject: Re: [x3d-public] X3DCanvas vs x3d-canvas, X_ITE - conversion stylesheet results<br>
><br>
><br>
><br>
> view3dscene and Castle Game Engine recompute the texture coordinates at runtime, potentially each frame. Which, as I understand, is also what X_ITE does. Testing with latest view3dscene (<a href="https://castle-engine.io/view3dscene.php" rel="noreferrer" target="_blank">https://castle-engine.io/view3dscene.php</a>), our results match X_ITE on <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeSkeletonSkinSiteSaluteWalkX_ITE.html" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeSkeletonSkinSiteSaluteWalkX_ITE.html</a><br>
><br>
> .<br>
><br>
><br>
><br>
> In short I think that<br>
><br>
><br>
><br>
> - view3dscene, Castle Game Engine and X_ITE are all correct with respect to spec here. We had this discussion 11 years ago already (see thread "Announcement: view3dscene 3.8.0" in your MUAs). From what I recall, back then I also confirmed that InstantReality on desktop also recalculates texture coordinates. But BS Contact did it differently.<br>
><br>
><br>
><br>
> - I think this is a sensible behavior in general, see below why. I see it doesn't match what Joe expected in this case, but IMHO the resolution is just "you should assign texture coordinates explicitly if you want them to stick, i.e. use TextureCoordinate".<br>
><br>
><br>
><br>
> Details:<br>
><br>
><br>
><br>
> The texture generation based on bbox is treated by view3dscene/CGE as just an implicit use of TextureCoordinateGenerator, with mode="BOUNDS", see<br>
><br>
> <a href="https://castle-engine.io/x3d_implementation_texturing_extensions.php#section_ext_tex_coord_bounds" rel="noreferrer" target="_blank">https://castle-engine.io/x3d_implementation_texturing_extensions.php#section_ext_tex_coord_bounds</a>. And TextureCoordinateGenerator can change coordinates at each frame.<br>
><br>
> The idea is that such texture generation can be done on GPU, right at rendering, so yes -- it can change each frame and this is a feature.<br>
><br>
><br>
><br>
> If you want the texture coordinates to stay unchanged, then just generate texture coordinates in your authoring tool. This is a normal workflow in my experience, artists routinely UV unwrap and assign textures this way to characters. 3D artists do not really depend on automatic texture generation at all in my experience, they also assign texture coordinates explicitly in Blender or such.<br>
><br>
><br>
><br>
> I'm not saying this is some final decision, but I'm saying this ("texture generation happens each frame, and may be done on GPU right at rendering") is how I understood the X3D spec and I think it makes sense. This way texture generation in X3D is a nice feature for some use-cases (if model is static, or if you want the texture to "flow").<br>
><br>
> If you want the texture to "stick", then you should just assign texture coordinates in 3D authoring tool, like in normal 3D workflow.<br>
><br>
><br>
><br>
> If we really want to (but I would discourage from it) we could change X3D spec to have a different behavior, but in this case the X3D spec would really have to be precise *when* should texture generation to be recomputed (at start? and/or caused by some input events?), how it is related to TextureCoordinateGenerator. Holger in last mail raised correct points -- they are some moments when you *have* to recompute the coordinates (like when number of points changes) anyway. Trying to specify when to recompute, and when not to recompute, feels like a "Pandora's box". Better to follow what we have now, and just say "they can be recomputed at each frame".<br>
><br>
><br>
><br>
> So making the texture generation only at certain moments<br>
><br>
><br>
><br>
> - is an additional work for X3D browsers, where they cannot use GPU (easily),<br>
><br>
><br>
><br>
> - is a work that duplicates what typically 3D authoring tools, like Blender, are doing.<br>
><br>
><br>
><br>
> So,<br>
><br>
><br>
><br>
> - you want the texture to stick -> map texture in Blender,<br>
><br>
><br>
><br>
> - you want the texture to move -> rely on X3D texture generation at runtime.<br>
><br>
><br>
><br>
> Regards,<br>
><br>
> Michalis<br>
><br>
><br>
><br>
> śr., 4 sty 2023 o 16:35 Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>> napisał(a):<br>
><br>
> ><br>
><br>
> > Hi Joe, but this is not what spec say, reading it strictly. Your approach has some caveats. The text coords should be calculated once. But what happens when the number of coords changes, or the num triangles or quads, or polygons. It is no more easy to determine when the tex coords should be regenerated.<br>
><br>
> ><br>
><br>
> > Holger<br>
><br>
> ><br>
><br>
> > Am 04.01.2023 um 16:06 schrieb Joseph D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>>:<br>
><br>
> ><br>
><br>
> > >> "The longest dimension of the bounding box defines the S coordinates, and the next longest defines the T coordinates."<br>
><br>
> ><br>
><br>
> > Hi Holger, I certainly agree with this, but not during animation. We would use the default mapping once, for the default pose, then the same after animation begins. Again, the way it is showing is a neat effect, but not realistic, since the texture should stay mapped to the default pose, not recomputed at each frame.<br>
><br>
> > Thanks,<br>
><br>
> > Joe<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > From: Holger Seelig<br>
><br>
> > Sent: Tuesday, January 3, 2023 3:15 AM<br>
><br>
> > To: X3D<br>
><br>
> > Subject: Re: [x3d-public] X3DCanvas vs x3d-canvas,X_ITE - conversion<br>
><br>
> > stylesheet results<br>
><br>
> ><br>
><br>
> > X_ITE does exactly what is documented here <a href="https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/geometry3D.html#f-IndexedFaceSettextureDefaultMapping" rel="noreferrer" target="_blank">https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/geometry3D.html#f-IndexedFaceSettextureDefaultMapping</a> to automatically calculate tex coords.<br>
><br>
> ><br>
><br>
> > >> "The longest dimension of the bounding box defines the S coordinates, and the next longest defines the T coordinates."<br>
><br>
> ><br>
><br>
> > In your example the longest dimension is as we can see the Y-axis, but<br>
><br>
> > the next longest dimension will change when the IFS is animated,<br>
><br>
> > sometimes it is the X-axis and sometimes it is the Z-axis. (You can<br>
><br>
> > see a flip)<br>
><br>
> ><br>
><br>
> > Second, because the IFS is animated the tex coords will always change.<br>
><br>
> > (You see the texture moving)<br>
><br>
> ><br>
><br>
> > Here are the lines how X_ITE does the calc:<br>
><br>
> > <a href="https://github.com/create3000/x_ite/blob/ad74f5212dae83c436bf0fc25eb4ac471301ae50/src/x_ite/Components/Rendering/X3DGeometryNode.js#L357" rel="noreferrer" target="_blank">https://github.com/create3000/x_ite/blob/ad74f5212dae83c436bf0fc25eb4ac471301ae50/src/x_ite/Components/Rendering/X3DGeometryNode.js#L357</a><br>
><br>
> ><br>
><br>
> > Please have a look at it. I cannot find a bug.<br>
><br>
> ><br>
><br>
> > Best regards,<br>
><br>
> > Holger<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > Am 02.01.2023 um 18:58 schrieb Joseph D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>>:<br>
><br>
> ><br>
><br>
> > Humanoid Animation X3D Examples Archive, Skin, Joe Skeleton Skin Site<br>
><br>
> > Salute Walk (<a href="http://web3d.org" rel="noreferrer" target="_blank">web3d.org</a>)<br>
><br>
> ><br>
><br>
> > Notice how skin moves around with animations.<br>
><br>
> > I still think this is because browser does not honor textCoords, Do I need to make a change to get thisto work right when it works correctly in others. As I recall from past, xite doesn’t autogenerate texcoords and needs repeat for every point?<br>
><br>
> > Thanks,<br>
><br>
> > Joe<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > From: Brutzman, Donald (Don) (CIV)<br>
><br>
> > Sent: Saturday, December 31, 2022 2:42 PM<br>
><br>
> > To: Holger Seelig<br>
><br>
> > Cc: X3D<br>
><br>
> > Subject: Re: [x3d-public] X3DCanvas vs x3d-canvas,X_ITE - conversion<br>
><br>
> > stylesheet results<br>
><br>
> ><br>
><br>
> > [related topic: upgrading "X3D to X_ITE" stylesheet, to match your<br>
><br>
> > announcement]<br>
><br>
> ><br>
><br>
> > Holger, thanks for all of the amazing work that you continue to accomplish.<br>
><br>
> ><br>
><br>
> > After finishing much other work, I’ve finally been able to update the (newly renamed) X3dToX3domX_ITE.xslt stylesheet to support your use of <x3d-canvas> element.<br>
><br>
> ><br>
><br>
> > Apologies for delays reaching this point. The new version of X_ITE looks good!<br>
><br>
> ><br>
><br>
> > Hoping that you can confirm I’m using your publishing patterns correctly. Might you please check HTML/CSS source for the following developmental example. If there are better ways of doing things please advise.<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > X3D Example Archives: Humanoid Animation, Skin, Joe Skeleton Skin Site<br>
><br>
> > Salute Walk<br>
><br>
> > <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS</a><br>
><br>
> > keletonSkinSiteSaluteWalkIndex.html<br>
><br>
> > <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS</a><br>
><br>
> > keletonSkinSiteSaluteWalkX_ITE.html<br>
><br>
> > <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeS</a><br>
><br>
> > keletonSkinSiteSaluteWalk_X_ITE.png<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > One thing I was not able to figure out… if you unzoom the JoeSkeletonSkinSiteSaluteWalkX_ITE.html page (using 4-arrow button in upper left) there is space for X_ITE Console, to appear as before in prior version. However this feature is no longer working. Am happy to correct it, or omit it, as appropriate.<br>
><br>
> ><br>
><br>
> > <div><br>
><br>
> > <h3>X_ITE Console</h3><br>
><br>
> > <p class="x_ite-console"/><br>
><br>
> > </div><br>
><br>
> ><br>
><br>
> > Hmm, reviewing: another thing is that the stylesheet link is still there but without apparent harm. Will try removing that later.<br>
><br>
> ><br>
><br>
> > Having fun with X_ITE, X3D and HTML5! 8)<br>
><br>
> ><br>
><br>
> > all the best, Don<br>
><br>
> > --<br>
><br>
> > Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
><br>
> > Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149<br>
><br>
> > X3D graphics, virtual worlds, Navy robotics https://<br>
><br>
> > <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">faculty.nps.edu/brutzman</a><br>
><br>
> ><br>
><br>
> > -----Original Message-----<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<br>
><br>
> > Seelig<br>
><br>
> > Sent: Tuesday, November 1, 2022 8:04 AM<br>
><br>
> > To: X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
><br>
> > Subject: [x3d-public] X3DCanvas vs x3d-canvas, X_ITE<br>
><br>
> ><br>
><br>
> > With version 6.0.0, X_ITE uses the new element name <x3d-canvas>, lowercase and with dash. Because X_ITE uses the Custom Element API from JavaScript now. This has the advantages that the element can be created with document.createElement, and is then immediately ready to use :). Other advantage is that the CSS file must not be included anymore.<br>
><br>
> ><br>
><br>
> > For compatibility the old name can still be used, but we encourage all users to update to the new tag name.<br>
><br>
> ><br>
><br>
> > Best regards,<br>
><br>
> > Holger<br>
><br>
> ><br>
><br>
> ><br>
><br>
> > _______________________________________________<br>
><br>
> > x3d-public mailing list<br>
><br>
> > <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
><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>
><br>
> ><br>
><br>
> ><br>
><br>
> > _______________________________________________<br>
><br>
> > x3d-public mailing list<br>
><br>
> > <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
><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>
<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" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
</blockquote></div></div>