Hello! The tile is rendering with semi-transparent pixels along its edges, and I’m not sure why. This results in a “tile bleeding” artifact when the camera moves. How can I fix this?
data:image/s3,"s3://crabby-images/8c8ad/8c8ad4466892cbe073005c2b59c4e41d6c387d53" alt="tile-bleeding"
Hello! The tile is rendering with semi-transparent pixels along its edges, and I’m not sure why. This results in a “tile bleeding” artifact when the camera moves. How can I fix this?
The problem was that the character wasn’t moving in whole pixel increments. Setting this.cameras.main.roundPixels = true; fixed the issue
It appears the problem persists, but its occurrence has significantly decreased. The issue remains relevant
Sometimes this needs extruding (padding) texture frames in WebGL. Phaser 4 will have a built-in solution for tilemap rendering.
I’ve updated Phaser from version 3.80.1 to 3.87.0, and it seems to have resolved the issue
But now there’s a new problem: the camera is noticeably jittering because of pixel rounding. So, I switched to version 4.0.0-beta.5, and those problems are gone there.
this.load.image('tile', 'path/to/tile.png');
// After loading the texture, set the filter mode to nearest
this.textures.get('tile').setFilter(Phaser.Textures.FilterMode.NEAREST);