findGroupMetadata.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. import defined from "../Core/defined.js";
  2. import hasExtension from "./hasExtension.js";
  3. /**
  4. * Check if a content has metadata, either defined in its metadata field (3D Tiles 1.1)
  5. * or in the <code>3DTILES_metadata</code> extension. If so, look up the group with the
  6. * corresponding ID.
  7. *
  8. * @function
  9. *
  10. * @param {Cesium3DTileset} tileset The tileset to query for group metadata
  11. * @param {Object} contentHeader the JSON header for a {@link Cesium3DTileContent}
  12. * @return {GroupMetadata} the group metadata, or <code>undefined</code> if not found
  13. * @private
  14. * @experimental This feature is using part of the 3D Tiles spec that is not final and is subject to change without Cesium's standard deprecation policy.
  15. */
  16. export default function findGroupMetadata(tileset, contentHeader) {
  17. const metadataExtension = tileset.metadataExtension;
  18. if (!defined(metadataExtension)) {
  19. return undefined;
  20. }
  21. const groups = metadataExtension.groups;
  22. const group = hasExtension(contentHeader, "3DTILES_metadata")
  23. ? contentHeader.extensions["3DTILES_metadata"].group
  24. : contentHeader.group;
  25. if (typeof group === "number") {
  26. return groups[group];
  27. }
  28. const index = metadataExtension.groupIds.findIndex(function (id) {
  29. return id === group;
  30. });
  31. return index >= 0 ? groups[index] : undefined;
  32. }