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

Add tile loading events for Voxels #12430

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
Open

Conversation

lukemckinstry
Copy link
Contributor

@lukemckinstry lukemckinstry commented Jan 10, 2025

Description

Takes the following events from Cesium3DTileset and adds them to VoxelPrimitive

  • allTilesLoaded
  • initialTilesLoaded
  • loadProgress
  • tileLoad
  • tileUnload

Also makes VoxelPrimitive use Cesium3DTilesetStatistics class, but only makes use of 2 of the stats in the class so far.

ToDo

  • Did not carry over these event types
  • Still need to add tests, but these look straighforward to carry over from Cesium3dTilesetSpec to VoxelPrimitiveSpec.
  • move code to call events out of VoxelTraversal.printDebugInformation.

Issue number and link

related to #12297

Testing plan

Many events currently fire inside of VoxelTraversal.printDebugInformation. Enable this but comment out the last line of the function which logs the debug output so you can read the output from listeners you set up to listen to the new events.

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

Copy link

Thank you for the pull request, @lukemckinstry!

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

@ggetz
Copy link
Contributor

ggetz commented Jan 14, 2025

@lukemckinstry

tileVisible - not sure is there is an equivalent to selectedTiles (from Cesium3DTileset) in VoxelPrimitive, if so I believe this would be simple.

There are definitely visibility checks for the tiles (nodes), it's just not in a neat array like selectedTiles are unfortunately. I believe all the visibility checks happen within generateOctree– Once the else condition is reached in buildOctree and the function no longer recurses, I think that is the highest resolution node which has been marked as renderable.

@lukemckinstry
Copy link
Contributor Author

lukemckinstry commented Jan 15, 2025

There are definitely visibility checks for the tiles
I see now where tileVisible would fire within the generateOctree function.

For Cesium3DTileset tileVisible, the Tile is passed to the event listener so the user can glean info and modify it before the next render. For VoxelPrimitive, the spatialNode is not part of the public API, so do we want to pass it to event listener in this same way?

If not, would we want to use this event, does it make sense to raise the tileVisible event without passing any info about the specific spatialNode? (I implemented this way for now fcd9a9c)

@ggetz
Copy link
Contributor

ggetz commented Jan 17, 2025

For Cesium3DTileset tileVisible, the Tile is passed to the event listener so the user can glean info and modify it before the next render. For VoxelPrimitive, the spatialNode is not part of the public API, so do we want to pass it to event listener in this same way?

It may be worth considering making the nodes part of the public API, and if they and Cesium3DTile should conform to some interface. Probably something worth noting in #12297, but a bit much to bite off in this PR. For now, I think it's fine not to pass anything.

@lukemckinstry
Copy link
Contributor Author

lukemckinstry commented Jan 17, 2025

This is ready for review. @ggetz @jjhembd
ToDo item

  • I do not have a unit test yet for the tileUnload event. There is an existing xited out spec covering the voxel unload process. This seems like it would be the right place to test the tileUnload event.

@lukemckinstry lukemckinstry marked this pull request as ready for review January 17, 2025 21:36
Copy link
Contributor

@ggetz ggetz left a comment

Choose a reason for hiding this comment

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

Looking good so far @lukemckinstry! A few comments, mostly around the inline documentation.

* </p>
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()

I don't think this should be needed. Strictly speaking, we should probably prevent the public API from reassigning this at all by providing only a public getter. But this can remain consistent with what we have over in Cesium3DTileset.

Comment on lines +462 to +464
* <p>
* The loaded tile is passed to the event listener.
* </p>
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* <p>
* The loaded tile is passed to the event listener.
* </p>

This is raised with no arguments since the nodes are still private API, correct?

* This event is fired during the traversal while the frame is being rendered.
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()

Same as above.

* </p>
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()

Comment on lines +499 to +501
* <p>
* If there are no event listeners, error messages will be logged to the console.
* </p>
Copy link
Contributor

Choose a reason for hiding this comment

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

Is this accurate? Please remove this line if not.

* @example
* voxelPrimitive.loadProgress.addEventListener(function(numberOfPendingRequests, numberOfTilesProcessing) {
* if ((numberOfPendingRequests === 0) && (numberOfTilesProcessing === 0)) {
* console.log('Stopped loading');
Copy link
Contributor

Choose a reason for hiding this comment

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

Nitpick:

Suggested change
* console.log('Stopped loading');
* console.log('Finished loading');

* </p>
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()

* </p>
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()

* </p>
*
* @type {Event}
* @default new Event()
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
* @default new Event()


if (defined(promise)) {
that._simultaneousRequestCount++;
keyframeNode.state = KeyframeNode.LoadState.RECEIVING;
promise.then(postRequestSuccess).catch(postRequestFailure);
} else {
keyframeNode.state = KeyframeNode.LoadState.FAILED;
that._primitive.tileFailed.raiseEvent();
Copy link
Contributor

Choose a reason for hiding this comment

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

This may be a question beyond the scope of this PR, but when a provider returns undefined instead of a promise, is that actually a failure state? Typically when undefined is returned from a function like this, it signals that the request couldn't be scheduled this frame and will be tried again next frame.

CC @jjhembd

@ggetz
Copy link
Contributor

ggetz commented Jan 23, 2025

@jjhembd Would you be able to provide any tips on testing the unload event since you were recently looking into that part of the code?

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.

2 participants