12345678910111213141516171819202122232425262728293031323334353637 |
- import ContentMetadata from "./ContentMetadata.js";
- import defined from "../Core/defined.js";
- import hasExtension from "./hasExtension.js";
- /**
- * Check if a content has metadata, either defined in its metadata field (3D Tiles 1.1) or in
- * the <code>3DTILES_metadata</code> extension. If defined, get the content metadata
- * with the corresponding class.
- *
- * @function
- *
- * @param {Cesium3DTileset} tileset The tileset to query for content metadata
- * @param {Object} contentHeader the JSON header for a {@link Cesium3DTileContent}
- * @return {ContentMetadata} the content metadata, or <code>undefined</code> if not found
- * @private
- * @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.
- */
- export default function findContentMetadata(tileset, contentHeader) {
- const metadataJson = hasExtension(contentHeader, "3DTILES_metadata")
- ? contentHeader.extensions["3DTILES_metadata"]
- : contentHeader.metadata;
- if (!defined(metadataJson)) {
- return undefined;
- }
- const classes = tileset.schema.classes;
- if (defined(metadataJson.class)) {
- const contentClass = classes[metadataJson.class];
- return new ContentMetadata({
- content: metadataJson,
- class: contentClass,
- });
- }
- return undefined;
- }
|