- Sean Lilley, Cesium
- Peter Gagliardi, Cesium
- Marco Hutter, Cesium
- Don McCurdy, Independent
- Sam Suhag, Cesium
- Bao Tran, Cesium
- Patrick Cozzi, Cesium
Draft
Written against the 3D Tiles 1.0 specification.
Optionally, this extension may be used with 3DTILES_implicit_tiling
, providing class definitions for tile and content metadata in implicit tiling subtrees.
Optionally, this extension may be used with 3DTILES_multiple_contents
, organizing tile contents into groups and providing metadata for each.
Disambiguation: This extension does not interact with the Batch Table feature used by the Batched 3D Model, Instanced 3D Model, and Point Cloud formats. Instead, glTF 2.0 assets may be referenced with
3DTILES_content_gltf
. Metadata within these assets is enabled with the glTF extension,EXT_structural_metadata
using the same schema format and conventions defined here.
Disambiguation: This extension does not interact with the
properties
object in tileset JSON, which is an alternative way of including small amounts of metadata associated with the tileset as a whole.
This extension is optional, meaning it should be placed in the tileset JSON extensionsUsed
list, but not in the extensionsRequired
list.
This extension defines a means of including structured metadata ("properties") in 3D Tiles, extending the format with semantically-rich data that may be used for inspection, analysis, styling, or other purposes. Properties are structured according to declared templates ("schema"), and associated with specific objects within a tileset ("entities") at various levels of granularity. Metadata is supported on the following 3D Tiles entity types:
- Tileset - Tileset as a whole may be associated with global metadata, such as the year of publication.
- Tile - Tiles may be individually associated with more specific metadata, such as the timestamp when a tile was last updated or the maximum height of the tile.
- Groups - Tile contents may be organized into groups (see: Groups) with shared metadata.
- Content - Tile contents may be individually associated with more specific metadata, such as a list of attribution strings.
Implementation note: Certain subcomponents of tile content ("features") may also have associated metadata. See Content Feature Properties.
Concepts and terminology used throughout this document refer to the 3D Metadata Specification, which should be considered a normative reference for definitions and requirements. This document provides inline definitions of terms where appropriate.
The figure below shows the relationship between entities (tilesets, tiles, contents, and groups) in 3D Tiles:
This section is non-normative
Metadata in 3D Tiles enables additional use cases and functionality for the format:
- Inspection: Applications displaying a tileset within a user interface (UI) may allow users to click or hover over specific tiles or tile contents, showing informative metadata about a selected entity in the UI.
- Collections: Tile content groups may be used to define collections (similar to map layers), such that each collection may be shown, hidden, or visually styled with effects synchronized across many tiles.
- Structured Data: Metadata supports both embedded and externally-referenced schemas, such that tileset authors may define new data models for common domains (e.g. for AEC or scientific datasets) or fully customized, application-specific data (e.g. for a particular video game).
- Optimization: Per-content metadata may include properties with performance-related semantics, enabling engines to optimize traversal and streaming algorithms significantly.
Properties describe attributes or characteristics of an Entity (tileset, tile, group, or content). Classes, provided by Schemas, are templates defining the data types and meanings of properties. Each entity is a single instance of that class with specific values. Additionally, Statistics may provide aggregate information about the distribution of property values within a particular class, and Semantics may define usage and meaning of particular properties.
Defined in schema.schema.json.
A schema defines a set of classes and enums used in a tileset. Classes serve as templates for entities - they provide a list of properties and the type information for those properties. Enums define the allowable values for enum properties. 3DTILES_metadata
implements the 3D Metadata Specification, which describes the metadata format and property definitions in full detail.
Schemas may be embedded in tilesets with the schema
property, or referenced externally by the schemaUri
property. Multiple tilesets and glTF contents may refer to the same schema to avoid duplication.
Example: Schema with a
building
class having three properties, "height", "owners", and "buildingType". The "buildingType" property refers to thebuildingType
enum as its data type, also defined in the schema. Later examples show how entities declare their class and supply values for their properties.{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "building": { "properties": { "height": { "type": "SCALAR", "componentType": "FLOAT32" }, "owners": { "type": "STRING", "array": true, "description": "Names of owners." }, "buildingType": { "type": "ENUM", "enumType": "buildingType" } } } }, "enums": { "buildingType": { "values": [ {"value": 0, "name": "Residential"}, {"value": 1, "name": "Commercial"}, {"value": 2, "name": "Other"} ] } } } } } }
Example: External schema referenced by a URI.
{ "extensions": { "3DTILES_metadata": { "schemaUri": "https://example.com/metadata/buildings/1.0/schema.json" } } }
Defined in class.schema.json.
Template for entities. Classes provide a list of property definitions. Every entity must be associated with a class, and the entity's properties must conform to the class's property definitions. Entities whose properties conform to a class are considered instances of that class.
Classes are defined as entries in the schema.classes
dictionary, indexed by class ID. Class IDs must be identifiers as defined in the 3D Metadata Specification.
Defined in class.property.schema.json.
Properties are defined abstractly in a class, and are instantiated in an entity with specific values conforming to that definition. Properties support a rich variety of data types, defined by property.type
.
Allowed values for type
:
"SCALAR"
"VEC2"
"VEC3"
"VEC4"
"MAT2"
"MAT3"
"MAT4"
"STRING"
"BOOLEAN"
"ENUM"
Scalar, vector, and matrix types further define property.componentType
.
Allowed values for componentType
:
"INT8"
"UINT8"
"INT16"
"UINT16"
"INT32"
"UINT32"
"INT64"
"UINT64"
"FLOAT32"
"FLOAT64"
Class properties are defined as entries in the class.properties
dictionary, indexed by property ID. Property IDs must be identifiers as defined in the 3D Metadata Specification.
By default, properties do not have any inherent meaning. A property may be assigned a semantic, an identifier that describes a property's meaning, for higher-level type information, runtime behavior, or other interpretation. The list of built-in semantics can be found in the 3D Metadata Semantic Reference. Tileset authors may define their own application- or domain-specific semantics separately, and should follow the naming conventions in the Semantic Reference.
Example: Schema defining a "building" class. The class's properties use two built-in semantics,
NAME
andID
, and one custom semantic,_HEIGHT
.{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "building": { "properties": { "name": { "type": "STRING", "semantic": "NAME" }, "id": { "type": "STRING", "semantic": "ID" }, "height": { "type": "SCALAR", "componentType": "FLOAT32", "semantic": "_HEIGHT" } } } } } } } }
Defined in enum.schema.json.
Set of categorical types, defined as (name, value)
pairs. Enum properties use an enum as their type.
Enums are defined as entries in the schema.enums
dictionary, indexed by enum ID. Enum IDs must be identifiers as defined in the 3D Metadata Specification.
Example: A "quality" enum defining quality level of data within a tile. An "Unspecified" enum value is optional, but when provided as the
noData
value for a property (see: 3D Metadata → No Data Values) may be helpful to identify missing data.{ "extensions": { "3DTILES_metadata": { "schema": { "enums": { "quality": { "name": "Quality", "description": "An example enum defining expected quality of data within a tile.", "values": [ {"name": "Unspecified", "value": 0}, {"name": "Low", "value": 1}, {"name": "Moderate", "value": 2}, {"name": "High", "value": 3} ] } } } } } }
Defined in enum.value.schema.json.
Pairs of (name, value)
entries representing possible values of an enum property.
Enum values are defined as entries in the enum.values
array. Duplicate names or duplicate integer values are not allowed.
Defined in statistics.class.property.schema.json.
Statistics provide aggregate information about the distribution of property values, summarized over all instances of a class within a tileset. For example, statistics may include the minimum/maximum values of a numeric property, or the number of occurrences for specific enum values.
These summary statistics allow applications to analyze or display metadata, e.g. with the declarative styling language, without first having to process the complete dataset to identify bounds for color ramps and histograms. Statistics are provided on a per-class basis, so that applications can provide styling or context based on the tileset as a whole, while only needing to download and process a subset of its tiles.
count
is the number of entities of a class occurring within the tilesetproperties
contains summary statistics about properties of a class occurring within the tileset
Properties may include the following built-in statistics:
Name | Description | Type |
---|---|---|
minimum |
The minimum property value | Scalars, vector, matrices |
maximum |
The maximum property value | ... |
mean |
The arithmetic mean of the property values | ... |
median |
The median of the property values | ... |
standardDeviation |
The standard deviation of the property values | ... |
variance |
The variance of the property values | ... |
sum |
The sum of the property values | ... |
occurrences |
Frequencies of value occurrences | Object in which keys are property values (for enums, the enum name), and values are the number of occurrences of that property value |
Tileset authors may define their own additional statistics, like _mode
in the example below. Application-specific statistics should use an underscore prefix (_*
) and lowerCamelCase for consistency and to avoid conflicting with future built-in statistics.
Example: Definition of a "building" class, with three properties. Summary statistics provide a minimum, maximum, and (application-specific) "_mode" for the numerical "height" property. The enum "buildingType" property is summarized by the number of distinct enum value occurrences.
{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "building": { "properties": { "height": { "type": "SCALAR", "componentType": "FLOAT32" }, "owners": { "type": "STRING", "array": true }, "buildingType": { "type": "ENUM", "enumType": "buildingType" } } } }, "enums": { "buildingType": { "valueType": "UINT16", "values": [ {"name": "Residential", "value": 0}, {"name": "Commercial", "value": 1}, {"name": "Hospital", "value": 2}, {"name": "Other", "value": 3} ] } } }, "statistics": { "classes": { "building": { "count": 100000, "properties": { "height": { "minimum": 3.9, "maximum": 341.7, "_mode": 5.0 }, "buildingType": { "occurrences": { "Residential": 50000, "Commercial": 40950, "Hospital": 50 } } } } } } } } }
While classes within a schema define the data types and meanings of properties, properties do not take on particular values until a metadata is assigned (i.e. the class is "instantiated") as a particular metadata entity within the 3D Tiles hierarchy. Each metadata entity contains the name of the class that it is an instance of, as well as a dictionary of property values that correspond to the properties of that class. This common structure is defined in metadataEntity.schema.json.
Each property value assigned must be defined by a class property with the same property ID, with values matching the data type of the class property. An entity may provide values for only a subset of the properties of its class, but class properties marked required: true
must not be omitted.
Most property values are encoded as JSON within the entity. One notable exception is metadata assigned to implicit tiles and contents, stored in a more compact binary form. See Implicit Tiling - Metadata.
Defined in tileset.schema.json and metadataEntity.schema.json.
Properties assigned to tilesets provide metadata about the tileset as a whole. Common examples might include year of collection, author details, or other general context for the tileset contents.
The tileset
object within a tileset's 3DTILES_metadata
extension must specify its class (class
). Within a properties
dictionary, values for properties are given, encoded as JSON types according to the JSON Format specification.
Example: The example below defines properties of a tileset, with the tileset being an instance of a "city" class. Required properties "dateFounded" and "population" are given; optional property "country" is omitted.
{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "city": { "properties": { "name": { "type": "STRING", "semantic": "NAME", "required": true }, "dateFounded": { "type": "STRING", "required": true }, "population": { "type": "SCALAR", "componentType": "UINT32", "required": true }, "country": { "type": "STRING" } } } } }, "tileset": { "class": "city", "properties": { "name": "Philadelphia", "dateFounded": "October 27, 1682", "population": 1579000 } } } } }
Defined in tile.3DTILES_metadata.schema.json and metadataEntity.schema.json.
Property values may be assigned to individual tiles, including (for example) spatial hints to optimize traversal algorithms. The example below uses the built-in semantic TILE_MAXIMUM_HEIGHT
from the 3D Metadata Semantic Reference.
A 3DTILES_metadata
extension on a tile object must specify its class (class
). Within a properties
dictionary, values for properties are given, encoded as JSON types according to the JSON Format specification.
Metadata assigned to implicit tiles is stored in a more compact binary form. See Implicit Tiling - Metadata.
Example:
{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "tile": { "properties": { "maximumHeight": { "semantic": "TILE_MAXIMUM_HEIGHT", "type": "SCALAR", "componentType": "FLOAT32" }, "countries": { "description": "Countries a tile intersects.", "type": "STRING", "array": true } } } } } } }, "root": { "extensions": { "3DTILES_metadata": { "class": "tile", "properties": { "maximumHeight": 4418, "countries": ["United States", "Canada", "Mexico"] } } }, "content": { ... }, ... } }
Defined in group.schema.json, metadataEntity.schema.json, and tileset.3DTILES_metadata.schema.json.
Tiles may contain more than one content (see: 3DTILES_multiple_contents
), or multiple tiles may reference content sharing the same metadata. In these cases, metadata assigned to the tile would be inadequate or inefficient for describing tile contents. This extension allows content to be organized into collections, or "groups", and metadata may be associated with each group. Groups are useful for supporting metadata on only a subset of a tile's content, or for working with collections of contents as layers, e.g. to manage visibility or visual styling.
The tileset's root 3DTILES_metadata
extension must define a list of available groups, if any, under its groups
property. Each group definition must specify its class (class
) and an identifier (id
) that uniquely identifies this group in the tileset. Within a properties
dictionary, values for properties are given, encoded as JSON types according to the JSON Format specification.
Tile contents are assigned to groups, representing collections of content, by attaching a 3DTILES_metadata
extension to the content object and specifying its group
property to be the index of the group in the list of groups that was defined for the tileset. Each content entity may be assigned only to a single group, but a single group may have any number of tile contents assigned to it.
Example: The example below defines a custom "layer" class, where each of its two groups ("buildings" and "trees") are instances of the "layer" class associated with different "name", "color", and "priority" property values. The root tile defines two contents using
3DTILES_multiple_contents
, one content item belonging to each group.{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "layer": { "properties": { "name": { "type": "STRING", "semantic": "NAME", "required": true }, "color": { "type": "VEC3", "componentType": "UINT8" }, "priority": { "type": "SCALAR", "componentType": "UINT32" } } } } }, "groups": [ { "id": "buildings", "class": "layer", "properties": { "name": "Buildings Layer", "color": [128, 128, 128], "priority": 0 } }, { "id": "trees", "class": "layer", "properties": { "name": "Trees Layer", "color": [10, 240, 30], "priority": 1 } } ] } }, "root": { "extensions": { "3DTILES_multiple_contents": { "contents": [ { "uri": "buildings.glb", "extensions": {"3DTILES_metadata": {"group": 0 }} }, { "uri": "trees.glb", "extensions": {"3DTILES_metadata": {"group": 1 }} } ] } }, ... } }
Defined in content.3DTILES_metadata.schema.json and metadataEntity.schema.json.
Property values may be assigned to individual tile contents, including (for example) attribution strings. The example below uses the built-in semantic ATTRIBUTION_STRING
from the 3D Metadata Semantic Reference.
A 3DTILES_metadata
extension on a content object must specify its class (class
). Within a properties
dictionary, values for properties are given, encoded as JSON types according to the JSON Format specification.
Metadata assigned to implicit tile content is stored in a more compact binary form. See Implicit Tiling - Metadata.
Example:
{ "extensions": { "3DTILES_metadata": { "schema": { "classes": { "content": { "properties": { "attributionStrings": { "semantic": "ATTRIBUTION_STRINGS", "type": "STRING", "array": true }, "triangleCount": { "description": "The number of triangles in the glTF content", "type": "SCALAR", "componentType": "UINT32" } } } } } } }, "root": { "content": { "uri": "tile.glb", "extensions": { "3DTILES_metadata": { "class": "content", "properties": { "attributionStrings": ["Source A", "Source B"], "triangleCount": 65000 } } } } ... } }
This section is non-normative
Certain kinds of tile content may contain meaningful subcomponents ("features"), which may themselves be associated with metadata through more granular properties. Schemas may be embedded in these content types, but unused classes in a 3DTILES_metadata
schema are allowed, and may hint to an application that tile content might include entities instantiating those classes.
Assigning properties to tile content is not within the scope of this extension, but may be defined by other specifications. One such example is the glTF extension, EXT_mesh_features
, which supports definitions of conceptual features within geometry and textures, and EXT_structural_metadata
for associated metadata. glTF 2.0 assets with feature metadata may be included as tile contents with the 3DTILES_content_gltf
extension.
While 3DTILES_metadata
and EXT_mesh_features
are defined independently, both conform to the 3D Metadata Specification and share the same representation of metadata as schema and properties.