I just installed the most recent 3.3 version of the SDK, and I’m noticing that random models appear to have distorted texture coordinates when opened in the scene editor.
When I run my game though, they are thankfully rendered properly (phew ) so it must be something specific to the scene editor. It’s only happening with 2 of my models that I’ve found so far.
Here’s a screenshot showing the same model in game at run time, compared to in the SDK, both running the same version of 3.3
The model uses a forked version of PBRLighting, but the issue peresists even when I switched it to use the stock PBR shader, so it doesn’t appear to be a shader bug.
I wasn’t sure if I should open an issue for this in the SDK github repo, but thought I’d at least make a post in case anyone else runs into the problem while upgrading and mistakenly think their models are corrupt.
Side note: I’m also really liking the new updates to the SDK, especially the buttons for applying the default light probe to the open scene in the scene editor and also making it the sky box
Try a custom light probe first.
The only thing that I could imagine is that like it’s some radius/positioning issue here affecting the lighting.
And since this wasn’t part of 3.2, it wasn’t bugged there basically.
It still happens without a light probe. It is specifically the emissive map and metallicRoughnessMap that are appearing to render with distorted texture coordinates.
Its also not a fragment shader bug or a bug with the tex coord buffers, even though it would seem like that is the case, but I can rule that out since they aren’t distorted at run-time. I am entirely lost on what may be causing this in the scene editor but not when I run the app. But I thought I should make this post to document it nonetheless.
I think they are getting flipped, despite not being flagged so in the material file. But if I do flip/unflip it in the material file, it doesn’t correct itself. Additionally, opening the model or the material in the sdk gives this error that I must not have noticed before:
com.jme3.asset.AssetNotFoundException: odels/rockTower/towerBrick/stoneNRML.pn (Flipped)
at com.jme3.asset.DesktopAssetManager.loadAsset(DesktopAssetManager.java:371)
at com.jme3.asset.DesktopAssetManager.loadTexture(DesktopAssetManager.java:391)
at com.jme3.gde.core.properties.preview.TexturePreview$1.call(TexturePreview.java:97)
at com.jme3.gde.core.properties.preview.TexturePreview$1.call(TexturePreview.java:92)
at com.jme3.app.AppTask.invoke(AppTask.java:142)
at com.jme3.app.LegacyApplication.runQueuedTasks(LegacyApplication.java:701)
at com.jme3.app.LegacyApplication.update(LegacyApplication.java:715)
at com.jme3.gde.core.scene.SceneApplication.update(SceneApplication.java:295)
at com.jme3.system.lwjgl.LwjglAbstractDisplay.runLoop(LwjglAbstractDisplay.java:153)
at com.jme3.system.lwjgl.LwjglCanvas.runLoop(LwjglCanvas.java:229)
at com.jme3.system.lwjgl.LwjglAbstractDisplay.run(LwjglAbstractDisplay.java:234)
at java.base/java.lang.Thread.run(Thread.java:834)
The texture it’s looking for definitely exists, and this same material doesn’t throw this error when the model renders properly in game. I notice that it is cutting off the first and last letter of my asset path based on the error message ("odels/rockTower/towerBrick/stoneNRML.pn"). I wonder if this is part of (or contributing to) the glitchy behavior in the scene editor?
Just to confirm that my material file has the proper spelling of the supposedly incorrect assetPath, here is the material file:
Whatever is causing the image to get flipped probably won’t be fixed by messing with materials because the material is just going to use the same buggy loader. In my imagination, it’s somehow ignoring the flip flag and loading it the default way… no matter what the material says. Your post only adds evidence to this wild guess.
Edit: note that the SDK does use its own asset manager implementation so it’s possible something wonky is going on in there.
with quotation marks, it works fine. But don’t ask me what happens behind the scenes in the SDK. Maybe the SDK assumes the first and last letter to be quotation marks and cuts them by default.
Thanks, I added the quotes as you suggested and those exceptions no longer get thrown.
Unfortunately the distorted texture coordinates still persists. But at least it is only a visual bug that goes away at run-time, so it is not a dire problem.
Edit: Since fixing the asset paths with quoatations, the material preview window has now started to display the mini-texture icons properly, and I just noticed that my textures are appearing distorted in the texture browser window, so I think that further backs up Paul’s statement that it is something wrong with the SDK’s asset manager implementation, and is not exclusive to the scene editor as I initially thought in my OP.
The bottom image is how the texture really looks, but the SDK appears to be doing some type of diagonal flip in the texture preview window.
I remember some PR about the Parsing of Materials and changing some default values.
Since I can’t imagine the SDK doing anything special here, I’d think this might be a version mismatch of some sort.
Another thing to factor in is that the SDK uses the Material File Writer, that probably noone else uses.