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

Disable depth test against a specific asset for Primitives #12410

Open
jjspace opened this issue Jan 3, 2025 · 0 comments
Open

Disable depth test against a specific asset for Primitives #12410

jjspace opened this issue Jan 3, 2025 · 0 comments

Comments

@jjspace
Copy link
Contributor

jjspace commented Jan 3, 2025

This primarily stems from an observation I've made of the behavior of billboards at the horizon. Ideally billboards usually should be drawn "on top" of everything else until they are on the opposite side of the globe.

By default in Cesium this happens "for free" out of the box as can be observed in the Billboards sandcastle

When it's near the horizon but on "this side"
2025-01-03_13-35
When the globe is turned slightly so the billboard is on "the other side" of the globe it gets clipped off
2025-01-03_13-35_1

However, when using a global 3d tiles tileset like the Google photogrammetry tiles this behavior is not the same. The billboard is always drawn "under" the tileset
"In front"
2025-01-03_13-42
"Behind"
2025-01-03_13-43

The behavior of the 3dtiles can be replicated with terrain if you set globe.depthTestAgainstTerrain to true.
2025-01-03_13-44

I think the default behavior of terrain is normally the expected result out of the box (given issues like #12396) however this requires some new architecture to add a way to ignore depth tests against a specific asset or tileset like we do with the terrain.

Workaround

The best solution right now is to control the value of disableDetphTestDistance on the billboard itself. Setting this to Number.POSITIVE_INFINITY "works" to always show a billboard on top of 3d tiles as terrain but it also allows you to see billboards on the other side of the globe.

A niave workaround I used for the Moon sandcastle is to set this distance based on the position of the camera which lets you approximately achieve the same cutoff at the horizon but it's not perfect. Check out this sandcastle showing this off

disableDepthTestDistance: new Cesium.CallbackProperty(() => {
  return Cesium.Cartesian3.magnitude(viewer.scene.camera.positionWC);
}, false),

2025-01-03_13-54
2025-01-03_13-55

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

No branches or pull requests

1 participant