Skip to content
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

[Bug] Unrendered sections in Tile3DLayer using maplibre.gl and deck.gl #9247

Open
1 of 7 tasks
eoudejans opened this issue Nov 14, 2024 · 1 comment
Open
1 of 7 tasks
Labels

Comments

@eoudejans
Copy link

Description

Using Tile3DLayer as a maplibre.gl map overlay I find that on flat surfaces in particular unrendered sections occur, see the following two screenshots for an idea what these holes look like:
1

2

The following code is the core of the custom deck.gl layer added in interleaved mode for maplibre-gl:

class MaplibreOverlay extends MapboxOverlay {
  override onAdd(map: any) :HTMLDivElement {
        (<any>this)._map=map; // circumvent type collisions between maplibre and mapbox map classes
        return (<any>this)._interleaved ? (<any>this)._onAddInterleaved(map) : (<any>this)._onAddOverlaid(map);
    }
}

tile3DLayer = new Tile3DLayer({
      id: tile3DLayerId,
      data: url,
      pickable: true,
    })
    
overlay = new MaplibreOverlay({
      interleaved: true,
      layers: [
        this.tile3DLayer
      ]
    });

map.addControl(overlay);

I have experimented with most of the depthTest related settings; turning the depthTest off for example results in a layer without unrendered sections:
3

But obviously this messes up the geometry:
4

The initial hypothesis I had was that there was some sort of z-fighting going on between maplibre.gl and deck.gl. However this hypothesis can be disproven as similar behavior occurs with pure js deck.gl:
5

The above was accomplished using the following code:

import {Deck} from '@deck.gl/core';
import {Tiles3DLoader} from '@loaders.gl/3d-tiles';
import {Tile3DLayer} from '@deck.gl/geo-layers';

const INITIAL_VIEW_STATE = {
  latitude: 52.377956,
  longitude: 4.897070,
  zoom: 10,
  bearing: 0,
  pitch: 45
};

new Deck({
  initialViewState: INITIAL_VIEW_STATE,
  controller: true,
  layers: [
	new Tile3DLayer({
		id: 'tile-3d-layer',
		pointSize: 2,
		data: '.../tileset.json',
		loader: Tiles3DLoader
	})
  ]
});

I have tried most parameters available to control both luma.gl and deck.gl, depthRange seemed to impact the rendering the most:

parameters: {
        depthTest: true,
        depthRange:[0.0, 0.6]
}

6

parameters: {
        depthTest: true,
        depthRange:[0.0, 0.001]
}

7

parameters: {
depthTest: true,
depthRange:[0.3, 1.0]
}
8

parameters: {
        depthTest: true,
        depthRange:[0.3, 1.0]
}

9

There is also a viewing angle dependency as it appears (first image top-down, second image slightly tilted camera):

parameters: {
depthTest: true,
depthRange:[0.3, 0.3001]
}

10
11

      getPolygonOffset: () => {
        return [-1, -1];
      },

12

Not sure if related, luma.gl states the following warning, I assume this is related with maplibre.gl and deck.gl interleaving:
13

Any help and tips on how to proceed are highly appreciated!

Flavors

  • Script tag
  • React
  • Python/Jupyter notebook
  • MapboxOverlay
  • GoogleMapsOverlay
  • CartoLayer
  • ArcGIS

Expected Behavior

No response

Steps to Reproduce

import {Deck} from '@deck.gl/core';
import {Tiles3DLoader} from '@loaders.gl/3d-tiles';
import {Tile3DLayer} from '@deck.gl/geo-layers';

const INITIAL_VIEW_STATE = {
  latitude: 52.377956,
  longitude: 4.897070,
  zoom: 10,
  bearing: 0,
  pitch: 45
};

new Deck({
  initialViewState: INITIAL_VIEW_STATE,
  controller: true,
  layers: [
	new Tile3DLayer({
		id: 'tile-3d-layer',
		pointSize: 2,
		data: '.../tileset.json',
		loader: Tiles3DLoader
	})
  ]
});

Environment

  • Framework version: [email protected]
  • Browser: Chrome Version 130.0.6723.117 (Official Build) (64-bit)
  • OS: Linux Ubuntu / Windows 11

Logs

No response

@eoudejans eoudejans added the bug label Nov 14, 2024
@eoudejans
Copy link
Author

eoudejans commented Dec 13, 2024

We have solved this issue at data generation side. I'll give an update in the near future and properly document what caused the unrendered sections, so it may be helpful to others. After doing so, I'll close this issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant