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

Change DataSourceDisplay ready state behavior for bounding sphere calculations #12429

Merged
merged 7 commits into from
Jan 14, 2025

Conversation

jjspace
Copy link
Contributor

@jjspace jjspace commented Jan 10, 2025

Description

Slightly reverting the change in #12230 and replacing PR #12322 in favor of changing the ready value to fix both #4647 and the newer issue #12303.

The core of this change is to make the DataSourceDisplay._ready boolean to remain true once it's set to true even if the internal datasources become "un-ready" due to transformations or loading.

Issue number and link

Alternative fix for #4647
Fixes #12303

Testing plan

  • Test this sandcastle which demonstrates the error when setting the viewer.selectedEntity
  • Test this sandcastle to test the original issue of a "flickering" entity when it moves (it should not flicker)
  • Test some other sandcastles that pertain to entities and selections to make sure selection and tracking still works as expected

Author checklist

  • I have submitted a Contributor License Agreement
  • I have added my name to CONTRIBUTORS.md
  • I have updated CHANGES.md with a short summary of my change
  • I have added or updated unit tests to ensure consistent code coverage
  • I have updated the inline documentation, and included code examples where relevant
  • I have performed a self-review of my code

@jjspace jjspace requested a review from ggetz January 10, 2025 20:01
Copy link

Thank you for the pull request, @jjspace!

✅ We can confirm we have a CLA on file for you.

##### Breaking Changes :mega:

- Changed behavior of `DataSourceDisplay.ready` to always stay `true` once it is initially set to `true`.

##### Fixes :wrench:

- Fixed error when resetting `Cesium3DTileset.modelMatrix` to its initial value. [#12409](https://github.com/CesiumGS/cesium/pull/12409)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't forget to add a link to the fixed issue as well. 😄

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was waiting to see the PR number, updated 😄

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, too soon 🏃‍♀️

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jjspace I don't see a link to the fixed issue (#12303). Can you please add it?

@jfayot
Copy link
Contributor

jfayot commented Jan 10, 2025

That looks good to me @jjspace ! Having different scratch objects seems so obvious now that I see it... Thanks

@jjspace
Copy link
Contributor Author

jjspace commented Jan 10, 2025

Awesome, thanks for taking a look @jfayot. The primary thing that helped was making sure the ready state stays true because it was flipping between ready and not ready as entities moved which caused the flicker before. The separate scratch variables is more of a sanity thing. They were interacting really weirdly because of how it's passed into and referenced in the EntityView and used in multiple locations that made it very hard to debug.

@Levi-Montgomery
Copy link

Awesome! I see what you did, much better. Thanks!

@ggetz
Copy link
Contributor

ggetz commented Jan 13, 2025

Thanks @jjspace! This looks good to go once https://github.com/CesiumGS/cesium/pull/12429/files#r1913711954 is addressed.

@jjspace
Copy link
Contributor Author

jjspace commented Jan 14, 2025

@ggetz should be got to go

@ggetz
Copy link
Contributor

ggetz commented Jan 14, 2025

Awesome, thanks @jjspace, @jfayot, and @Levi-Montgomery! Glad we got to the bottom of this.

@ggetz ggetz enabled auto-merge January 14, 2025 15:59
@ggetz ggetz added this pull request to the merge queue Jan 14, 2025
Merged via the queue into main with commit bace4a7 Jan 14, 2025
9 checks passed
@ggetz ggetz deleted the datasourcedisplay-ready-state branch January 14, 2025 15:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

TypeError on setting the Viewer selectedEntity
4 participants