PlaneGeometry’s uv coordinates should all be between [0, 1], but I discard all pixels less than or equal to 1 in the shader, still showing a thin line at the edge
I can’t use clamp to keep it between 0-1, because the uv coordinates passed by this custom material may not be in the 0-1 range like plane.
what is the cause of this and how can I fix it
Thanks for any help!
I discard all pixels less than or equal to 1 in the shader
but then said:
I can’t use clamp to keep it between 0-1
just one more attempt:
if( uv != fract( uv )) discard;
const float shrinkFactor = .95; //adjust this until edge artifacts go away...
uv = ((fract(uv)-.5)*shrinkFactor)+.5; //Shrink the UVs away from texture edge to avoid filtering/aa artifacts
Also if you could describe on a higher level what you’re trying to do, it might inform the approach like…
“I’m trying to allow users to place a decal on their model for clothing design”
or whatnot…
Another thing to look into/read about are the wrapping modes…(three.js docs)
You can use a decal with a transparent+black pixel border, and ClampToEdgeWrapping to place a smaller image somewhere on a larger mesh.
The artifact you’re seeing is because antialising hardware sometimes has to read samples outside of the UV coordinates to filter the fragments… the higher the aa setting, the more pixels outside the boundary it has to sample.
If you set the outer edge of pixels on your texture to black/transparent, the clamp to edge wrapping will repeat that transparent color value for the filtering.
I.e. instead of using discard… use a texture with a single black pixel border, and texture.wrapS = texture.wrapT = THREE.ClampToEdgeWrapping
and texture.alphaTest = .1; // Alpha test is the non shader way to discard pixels below a certain alpha threshold.
I’m just thinking out loud though, take this all with a large grain of salt.