findContentMetadata.js 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. import ContentMetadata from "./ContentMetadata.js";
  2. import defined from "../Core/defined.js";
  3. import hasExtension from "./hasExtension.js";
  4. /**
  5. * Check if a content has metadata, either defined in its metadata field (3D Tiles 1.1) or in
  6. * the <code>3DTILES_metadata</code> extension. If defined, get the content metadata
  7. * with the corresponding class.
  8. *
  9. * @function
  10. *
  11. * @param {Cesium3DTileset} tileset The tileset to query for content metadata
  12. * @param {Object} contentHeader the JSON header for a {@link Cesium3DTileContent}
  13. * @return {ContentMetadata} the content metadata, or <code>undefined</code> if not found
  14. * @private
  15. * @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.
  16. */
  17. export default function findContentMetadata(tileset, contentHeader) {
  18. const metadataJson = hasExtension(contentHeader, "3DTILES_metadata")
  19. ? contentHeader.extensions["3DTILES_metadata"]
  20. : contentHeader.metadata;
  21. if (!defined(metadataJson)) {
  22. return undefined;
  23. }
  24. const classes = tileset.schema.classes;
  25. if (defined(metadataJson.class)) {
  26. const contentClass = classes[metadataJson.class];
  27. return new ContentMetadata({
  28. content: metadataJson,
  29. class: contentClass,
  30. });
  31. }
  32. return undefined;
  33. }