-
Notifications
You must be signed in to change notification settings - Fork 3.5k
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
Ease of use for Non-WGS84 Ellipsoids #12000
Conversation
Thank you for the pull request, @ggetz! ✅ We can confirm we have a CLA on file for you. |
@jjspace Could you please review? Additionally, @angrycat9000 can you take a look from a usability standpoint? |
@@ -446,7 +446,7 @@ ArcGISTiledElevationTerrainProvider.prototype.requestTileGeometry = function ( | |||
encoding: that._encoding, | |||
}); | |||
}) | |||
.catch(function (error) { | |||
.catch(async function (error) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, this is technically an unrelated change, but I was able to track down what I believe was causing #11231 while troubleshooting unit tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi Gabby, thanks for working on this. I wasn't able to run the sandcastle.
TypeError: Simon1994PlanetaryPositions_default.computeSunPositionInMoonInertialFrame is not a function
at setSunAndMoonDirections (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:33500:54)
at UniformState.update (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:33578:3)
at render (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:235243:6)
at tryAndCatchError (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:235283:5)
at Scene4.render (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:235338:5)
at CesiumWidget.render (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:238457:17)
at render2 (https://ci-builds.cesium.com/cesium/ellipsoids/Build/CesiumUnminified/index.js:237868:18)
@angrycat9000 Apologies, I forgot to push up my last commit. Everything should be good to go now. |
Thanks for the update @ggetz. I ran into some problems testing the use case for ion where we re-use the same preview window for different assets. I modified your sandcastle to change back and forth between the earth and moon on left click. However this didn't seem to work as expected (the earth was sized the same as the moon after a click). Just changing the default ellipsoid after the viewer was created did not work. I tried setting the ellipsoid properties individually however I got an error
What would be the expected process to go back to the earth from the moon (and vise versa)? |
Since you instantiated the earth options (terrain provider and imagery provider) while the default ellipsoid was set to the Moon, they were created with the Moon's ellipsoid. You can either manually pass in the WGS84 ellipsoid (which is actually a bit tricky when using |
Hi @ggetz Thanks for that tweaked example. I'm running into some issue with the camera when switching back and forth. See this example. Click to change to moon. Then try to zoom in. Notice it does not let you zoom in very far. Are there other things I would need to reset to change between moon and earth? |
At this point I'm running into enough issues with stuff that was created before changing the default ellipsoid, I'm going to try just throwing out the whole viewer and recreating it if I need to change between Moon/Earth |
@angrycat9000 Gotcha. In the meantime I'll look into seeing if we have better ways of transitioning between the two. |
@angrycat9000 This was turned off by default since the star positions are not accurate when using the moon as the central body. It can be re-enabled. |
That makes sense. I can just update the background to black for the moon for now. Not that it has to be in this PR, but curious about what would be the level of effort to get an accurate skybox suitable for use with lunar data? Is there any issue to track that? It might also make sense to provide a method like |
First off this is awesome! Very excited to have this land 😄
Wayyyy out-of-scope for this issue, but just want to flag that transitioning between different planets will also need some way to dynamically load in different approximateTerrainHeights, once terrain and ground primitives are involved. We work with quite a few planetary bodies and I have yet found a way to seamlessly support viewing them all within one packaged application. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Other than a few small comments, some of which we've already discussed in person, I think this is looking good from a code perspective. from basic testing it seems ok too but i'm not confident I know enough to fully evaluate that but @angrycat9000 seems to have that covered
@@ -2625,6 +2625,7 @@ function parse(loader, gltf, supportedImageFormats, frameState) { | |||
|
|||
if (defined(cesiumRtcExtension)) { | |||
// CESIUM_RTC is almost always WGS84 coordinates so no axis conversion needed | |||
// TODO: Ellipsoids |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TODO?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Double checked, no changes needed here.
Might also be a nice change to set the globe base color to a grey instead of blue when using the moon ellipsoid. |
Not yet. I'll open an issue to track follow up changes. I'm not actually sure what all went into generating the default starmap. |
For now, I think it's best to leave this up to the app developer. We'll keep the blue default in the API, as I don't think realism was the driving factor for the color choice. 😆 |
@jjspace This should be ready for another look. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks good to me now, most of my comments were minor code and docs anyway. @angrycat9000 is there anything else you want to check or add from your testing?
This good from my end |
Thanks all! |
Description
This PR is designed to make the API for setting an alternative ellipsoid throughout the API more streamlined. There are some additional changes needed for 3D Tiles, but that is coming in a follow-up PR.
The main addition is
Ellipsoid.default
, which is now used throughout the API as the default ellipsoid rather thanEllipsoid.WGS84
directly. That means instead of having to doCartographic.fromCartesian(0, 1, 3, myEllipsoid)
everywhere, you can now setEllipsoid.default = myEllipsoid
once.There were a few places which assumed WGS84 even before instantiation, so setting
Ellipsoid.default
modifies a few other classes. This is counterintuitive, but done to avoid circular dependencies (ie.Ellipsoid
needs to depend onCartesian3
, soCartesian3
can't depend onEllipsoid
).Furthermore, we make a few Earth-centric assumptions throughout the API.We now disable them when the ellipsoid is set to something other than
Ellipsoid.WGS84
or use a default proportionate to the selected ellipsoid. This includes:In particular, I had to make some configuration changes to the base layer picker to 1) Ensure the WGS84 ellipsoid was always used when relevant, and 2) not override when you set the viewer's ellipsoid to something other than the WGS84 ellipsoid
Last, but not least, there were some instances of naming things with
WGS84
when we just mean any arbitrary ellipsoid. These have been changed, and where needed functions have been renamed and the old versions deprecated.Issue number and link
Fixes #4245
Fixes #3543
Fixes #11231
Testing plan
Testing Sandcastle
Additionally to test this, I iterated through many Sandcastle examples, setting
Cesium.Ellipsoid.default = Cesium.Ellipsoid.MOON;
or another arbitrary ellipsoid as the first line.Cesium.Ellipsoid.default = Cesium.Ellipsoid.UNIT_SPHERE;
is also a possibility, and while nothing should crash, there is some weirdness purely due to the size disparity.Author checklist
CONTRIBUTORS.md
CHANGES.md
with a short summary of my changes