| 123456789101112131415161718192021222324252627282930313233343536373839 | import defined from "../Core/defined.js";import hasExtension from "./hasExtension.js";import TileMetadata from "./TileMetadata.js";/** * Check if a tile has metadata, either defined in its metadata field (3D Tiles 1.1) * or in the <code>3DTILES_metadata</code> extension. If defined, get the tile metadata * with the corresponding class. * <p> * This assumes that tileset.metadata has been created before any tiles are constructed. * </p> * @function * * @param {Cesium3DTileset} tileset The tileset to query for tile metadata * @param {Object} tileHeader the JSON header for a {@link Cesium3DTile} * @return {TileMetadata} the tile 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 findTileMetadata(tileset, tileHeader) {  const metadataJson = hasExtension(tileHeader, "3DTILES_metadata")    ? tileHeader.extensions["3DTILES_metadata"]    : tileHeader.metadata;  if (!defined(metadataJson)) {    return undefined;  }  const classes = tileset.schema.classes;  if (defined(metadataJson.class)) {    const tileClass = classes[metadataJson.class];    return new TileMetadata({      tile: metadataJson,      class: tileClass,    });  }  return undefined;}
 |