Skip to content
This repository has been archived by the owner on Jan 14, 2025. It is now read-only.

Commit

Permalink
feat: publish loading progress via cloudxr
Browse files Browse the repository at this point in the history
  • Loading branch information
burnedikt committed Dec 24, 2024
1 parent bf201d7 commit 514be3d
Showing 1 changed file with 42 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,48 @@ def _set_active_camera_in_viewport(self, camera_path):
f"Failed to set active camera in the viewport '{camera_path}': {str(e)}"
)

def _on_tick(self, _event):
"""
Handler for the Update Loop event.
"""
# carb.log_info(f"Update Loop event: {event.type} => {event.payload}")

if self.is_loading:
# check how many files have been loaded on stage
_loading_message, num_loaded_files, num_total_files = (
omni.usd.get_context().get_stage_loading_status()
)

is_loading = num_loaded_files or num_total_files

if not is_loading:
carb.log_verbose("Finished loading.")
self.is_loading = False
self.send_loading_progress(1)
return

# carb.log_info(
# f"TICK: Loading message: {loading_message[:10]}... ({num_loaded_files}/{num_total_files})"
# )

# calculate the progress
progress = num_loaded_files / num_total_files
self.send_loading_progress(progress)

def send_loading_progress(self, progress: float):
"""
Sends the loading progress to the client.
Args:
progress (float): The progress value to send.
"""
carb.log_info(f"Sending loading progress: {progress}")
message = {
# XXX: For some reason, the CXR team chose to use "Type" instead of "type" in the message
"Type": "fileLoadingProgress",
"progress": progress,
}
self.send_cloudxr_message(message)

def _on_stage_event(self, event):
if event.type == int(omni.usd.StageEventType.OMNIGRAPH_START_PLAY):
# notify client that playback has started
Expand Down

0 comments on commit 514be3d

Please sign in to comment.