cesium-native 0.43.0
Loading...
Searching...
No Matches
CesiumGltf::PropertyTableProperty Struct Referencefinal

An array of binary property values. More...

#include <CesiumGltf/PropertyTableProperty.h>

Inheritance diagram for CesiumGltf::PropertyTableProperty:
CesiumUtility::ExtensibleObject

Classes

struct  ArrayOffsetType
 Known values for The type of values in arrayOffsets. More...
 
struct  StringOffsetType
 Known values for The type of values in stringOffsets. More...
 

Public Member Functions

int64_t getSizeBytes () const
 Calculates the size in bytes of this object, including the contents of all collections, pointers, and strings. This will NOT include the size of any extensions attached to the object. Calling this method may be slow as it requires traversing the object's entire structure.
 
- Public Member Functions inherited from CesiumUtility::ExtensibleObject
template<typename T >
bool hasExtension () const noexcept
 Checks if an extension exists given its static type.
 
template<typename T >
const T * getExtension () const noexcept
 Gets an extension given its static type.
 
template<typename T >
T * getExtension () noexcept
 Gets an extension given its static type.
 
const JsonValuegetGenericExtension (const std::string &extensionName) const noexcept
 Gets a generic extension with the given name as a CesiumUtility::JsonValue.
 
JsonValuegetGenericExtension (const std::string &extensionName) noexcept
 Gets a generic extension with the given name as a CesiumUtility::JsonValue.
 
template<typename T , typename... ConstructorArgumentTypes>
T & addExtension (ConstructorArgumentTypes &&... constructorArguments)
 Adds a statically-typed extension to this object.
 
template<typename T >
void removeExtension ()
 Removes a statically-typed extension from this object.
 
int64_t getSizeBytes () const
 Calculates the size in bytes of this ExtensibleObject, including all of its extras but NOT including its extensions. Calling this method may be slow as it requires traversing the entire object.
 

Public Attributes

int32_t values = -1
 The index of the buffer view containing property values. The data type of property values is determined by the property definition: When type is BOOLEAN values are packed into a bitstream. When type is STRING values are stored as byte sequences and decoded as UTF-8 strings. When type is SCALAR, VECN, or MATN the values are stored as the provided componentType and the buffer view byteOffset must be aligned to a multiple of the componentType size. When type is ENUM values are stored as the enum's valueType and the buffer view byteOffset must be aligned to a multiple of the valueType size. Each enum value in the array must match one of the allowed values in the enum definition. arrayOffsets is required for variable-length arrays and stringOffsets is required for strings (for variable-length arrays of strings, both are required).
 
int32_t arrayOffsets = -1
 The index of the buffer view containing offsets for variable-length arrays. The number of offsets is equal to the property table count plus one. The offsets represent the start positions of each array, with the last offset representing the position after the last array. The array length is computed using the difference between the subsequent offset and the current offset. If type is STRING the offsets index into the string offsets array (stored in stringOffsets), otherwise they index into the property array (stored in values). The data type of these offsets is determined by arrayOffsetType. The buffer view byteOffset must be aligned to a multiple of the arrayOffsetType size.
 
int32_t stringOffsets = -1
 The index of the buffer view containing offsets for strings. The number of offsets is equal to the number of string elements plus one. The offsets represent the byte offsets of each string in the property array (stored in values), with the last offset representing the byte offset after the last string. The string byte length is computed using the difference between the subsequent offset and the current offset. The data type of these offsets is determined by stringOffsetType. The buffer view byteOffset must be aligned to a multiple of the stringOffsetType size.
 
std::string arrayOffsetType = ArrayOffsetType::UINT32
 The type of values in arrayOffsets.
 
std::string stringOffsetType = StringOffsetType::UINT32
 The type of values in stringOffsets.
 
std::optional< CesiumUtility::JsonValueoffset
 An offset to apply to property values. Only applicable when the component type is FLOAT32 or FLOAT64, or when the property is normalized. Overrides the class property's offset if both are defined.
 
std::optional< CesiumUtility::JsonValuescale
 A scale to apply to property values. Only applicable when the component type is FLOAT32 or FLOAT64, or when the property is normalized. Overrides the class property's scale if both are defined.
 
std::optional< CesiumUtility::JsonValuemax
 Maximum value present in the property values. Only applicable to SCALAR, VECN, and MATN types. This is the maximum of all property values, after the transforms based on the normalized, offset, and scale properties have been applied.
 
std::optional< CesiumUtility::JsonValuemin
 Minimum value present in the property values. Only applicable to SCALAR, VECN, and MATN types. This is the minimum of all property values, after the transforms based on the normalized, offset, and scale properties have been applied.
 
- Public Attributes inherited from CesiumUtility::ExtensibleObject
std::unordered_map< std::string, std::any > extensions
 The extensions attached to this object.
 
JsonValue::Object extras
 Application-specific data.
 
JsonValue::Object unknownProperties
 Unknown properties that exist on this object but do not have any representation in the statically-typed classes.
 

Static Public Attributes

static constexpr const char * TypeName = "PropertyTableProperty"
 The original name of this type.
 

Detailed Description

An array of binary property values.

Definition at line 17 of file PropertyTableProperty.h.

Member Function Documentation

◆ getSizeBytes()

int64_t CesiumGltf::PropertyTableProperty::getSizeBytes ( ) const
inline

Calculates the size in bytes of this object, including the contents of all collections, pointers, and strings. This will NOT include the size of any extensions attached to the object. Calling this method may be slow as it requires traversing the object's entire structure.

Definition at line 152 of file PropertyTableProperty.h.

Member Data Documentation

◆ arrayOffsets

int32_t CesiumGltf::PropertyTableProperty::arrayOffsets = -1

The index of the buffer view containing offsets for variable-length arrays. The number of offsets is equal to the property table count plus one. The offsets represent the start positions of each array, with the last offset representing the position after the last array. The array length is computed using the difference between the subsequent offset and the current offset. If type is STRING the offsets index into the string offsets array (stored in stringOffsets), otherwise they index into the property array (stored in values). The data type of these offsets is determined by arrayOffsetType. The buffer view byteOffset must be aligned to a multiple of the arrayOffsetType size.

Definition at line 86 of file PropertyTableProperty.h.

◆ arrayOffsetType

std::string CesiumGltf::PropertyTableProperty::arrayOffsetType = ArrayOffsetType::UINT32

The type of values in arrayOffsets.

Known values are defined in ArrayOffsetType.

Definition at line 106 of file PropertyTableProperty.h.

◆ max

std::optional<CesiumUtility::JsonValue> CesiumGltf::PropertyTableProperty::max

Maximum value present in the property values. Only applicable to SCALAR, VECN, and MATN types. This is the maximum of all property values, after the transforms based on the normalized, offset, and scale properties have been applied.

Definition at line 136 of file PropertyTableProperty.h.

◆ min

std::optional<CesiumUtility::JsonValue> CesiumGltf::PropertyTableProperty::min

Minimum value present in the property values. Only applicable to SCALAR, VECN, and MATN types. This is the minimum of all property values, after the transforms based on the normalized, offset, and scale properties have been applied.

Definition at line 144 of file PropertyTableProperty.h.

◆ offset

std::optional<CesiumUtility::JsonValue> CesiumGltf::PropertyTableProperty::offset

An offset to apply to property values. Only applicable when the component type is FLOAT32 or FLOAT64, or when the property is normalized. Overrides the class property's offset if both are defined.

Definition at line 121 of file PropertyTableProperty.h.

◆ scale

std::optional<CesiumUtility::JsonValue> CesiumGltf::PropertyTableProperty::scale

A scale to apply to property values. Only applicable when the component type is FLOAT32 or FLOAT64, or when the property is normalized. Overrides the class property's scale if both are defined.

Definition at line 128 of file PropertyTableProperty.h.

◆ stringOffsets

int32_t CesiumGltf::PropertyTableProperty::stringOffsets = -1

The index of the buffer view containing offsets for strings. The number of offsets is equal to the number of string elements plus one. The offsets represent the byte offsets of each string in the property array (stored in values), with the last offset representing the byte offset after the last string. The string byte length is computed using the difference between the subsequent offset and the current offset. The data type of these offsets is determined by stringOffsetType. The buffer view byteOffset must be aligned to a multiple of the stringOffsetType size.

Definition at line 98 of file PropertyTableProperty.h.

◆ stringOffsetType

std::string CesiumGltf::PropertyTableProperty::stringOffsetType = StringOffsetType::UINT32

The type of values in stringOffsets.

Known values are defined in StringOffsetType.

Definition at line 114 of file PropertyTableProperty.h.

◆ TypeName

const char* CesiumGltf::PropertyTableProperty::TypeName = "PropertyTableProperty"
staticconstexpr

The original name of this type.

Definition at line 22 of file PropertyTableProperty.h.

◆ values

int32_t CesiumGltf::PropertyTableProperty::values = -1

The index of the buffer view containing property values. The data type of property values is determined by the property definition: When type is BOOLEAN values are packed into a bitstream. When type is STRING values are stored as byte sequences and decoded as UTF-8 strings. When type is SCALAR, VECN, or MATN the values are stored as the provided componentType and the buffer view byteOffset must be aligned to a multiple of the componentType size. When type is ENUM values are stored as the enum's valueType and the buffer view byteOffset must be aligned to a multiple of the valueType size. Each enum value in the array must match one of the allowed values in the enum definition. arrayOffsets is required for variable-length arrays and stringOffsets is required for strings (for variable-length arrays of strings, both are required).

Definition at line 72 of file PropertyTableProperty.h.


The documentation for this struct was generated from the following file: