-
-
Notifications
You must be signed in to change notification settings - Fork 782
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Flickering when zooming with terrain enabled #1077
Comments
Hi, i think the issue is only with raster-tiles, and in the terrain-testpage the hillshading is done via raster-tiles. In 2d mode the raster-tiles are rendered on every frame, and between zoomleves and loading the rastertiles will fade into each other, but 3d works completele different. |
hi,
|
OK, you are right, i will have a look onto it! |
Ok thanks, i think i know now where to start! I think the problem is when filling _coordsDescendingInv. May after the fill process (below line 56) we have to check that there are no parent-tiles in the to-render-tiles array. |
You're right, there are loads of parents in the to-render array. That's clear, because some low zoom tiles (f.ex. 5) are always visible. But the problem really only shows on zooming in, until all requested tiles are loaded. A simple hacky fix reduces the flickering to almost not noticeable.
The tile isn't rendered, if there is a parent or grandparent tile visible. I don't get why the double rendering isn't notice all the time, because tiles are rendered on top of another all the time? |
Thx for your effort! I shortly digged into this but currently i do not have a correct answer for the issue. As soon as i have time, i will look again onto this issue. |
@prozessor13 I finally found the issue, took me a couple of hours. Based on your #1651 PR: The problem is in the renderLayer methode in render_to_texture.ts. When a zoom event occurs and not all tiles are completely loaded, the coords array in the layer loop contains overlapping tiles. Link to source: https://github.com/prozessor13/maplibre-gl-js/blob/c82c13eac651bf96f23e44985bbf62326fc93ad2/src/render/render_to_texture.ts#L247 My suggested fix would be, remove the overlapping tiles for fill layers. Lower zoom levels should be always rendered first, because of ordering in coords array. for (let l = 0; l < layers.length; l++) {
const layer = painter.style._layers[layers[l]];
let coords = layer.source ? this._coordsDescendingInv[layer.source][tile.tileID.key] : [tile.tileID];
if (coords && coords.length > 1 && layer.type == "fill") {
let parentPresent = false
let nonOverlappingCoords = []
for (const tileID of coords) {
for (const parentTileID of coords) {
if (parentTileID != tileID && tileID.isChildOf(parentTileID)) {
parentPresent = true
break;
}
}
if (!parentPresent) {
nonOverlappingCoords[nonOverlappingCoords.length] = tileID
}
}
coords = nonOverlappingCoords
}
painter._renderTileClippingMasks(layer, coords);
painter.renderLayer(painter, painter.style.sourceCaches[layer.source], layer, coords);
if (layer.source) tile.rttCoords[layer.source] = this._coordsDescendingInvStr[layer.source][tile.tileID.key];
} What do you think? |
Hi, thanks very much for digging into this. Your approach is one way, but i think the problem can be solved otherwise. In 2d Maplibre has a stencil logic to render on a pixel only the data of the tile with the highest zoomlevel. But currently in terrain-mode the stencil is not handled correct, and so this artefacts accours. I played also with a solution you did, but run into problems when sources has no global coverage. So i created another branch for this issue https://github.com/prozessor13/maplibre-gl-js/tree/rtt_stencil . Hopefully with this logic your problem dissapears as well, because currently i only tested with raster and hillshade layers. It would be great, if you can test this branch. |
I tested your rtt_stencil branch an it works great! It also fixes another related issue where tile borders (overdraw) where overlapping when zooming out. Really fantastic! |
No need to assign a bounty here since it was assigned in #1540. |
Hi all,
great work on the 3d feature, looks beautiful!
When testing your branch I noticed some flickering when zooming in (using the toursprung/terrain.json style) which is quite noticeable. It seems like semi-transparent polygons are rendered twice and for a few frames and the opacity is therefore doubled.
Edit: It only seems to happen on the first zooming of an area, when all tiles are cached it doesn't happen.
Tile in the southeast with wrong opacity:
data:image/s3,"s3://crabby-images/ec3c0/ec3c056fca5cf2e618c99c645cf391e31d9228c1" alt="2200ms"
200ms later the tile is rendered correctly:
data:image/s3,"s3://crabby-images/2b46f/2b46fb13e51cee8017b8f70ff9ec4a9a76485a64" alt="2400ms"
This doesn't happen with terrain disabled, I think it's related to some networking activity (new DEM or image tiles available).
Any idea where that may come from? Happy to help if you can point me in the right direction.
Regards,
Florian
Original issue in prozessor13's repo: prozessor13#60
The text was updated successfully, but these errors were encountered: