3#include <CesiumGltf/AccessorView.h>
4#include <CesiumGltf/PropertyAttributeProperty.h>
5#include <CesiumGltf/PropertyTransformations.h>
6#include <CesiumGltf/PropertyTypeTraits.h>
7#include <CesiumGltf/PropertyView.h>
8#include <CesiumUtility/Assert.h>
103template <
typename ElementType,
bool Normalized = false>
117template <
typename ElementType>
125 :
PropertyView<ElementType, false>(), _accessor{}, _size{0} {}
136 "An empty property view should not be constructed with a valid status");
151 int64_t size) noexcept
159 if (!classProperty.defaultProperty) {
186 _accessor{accessorView},
189 ? accessorView.size()
207 std::optional<ElementType>
get(int64_t index)
const noexcept {
210 return this->defaultValue();
213 ElementType value = getRaw(index);
215 if (value == this->noData()) {
216 return this->defaultValue();
232 ElementType
getRaw(int64_t index)
const noexcept {
235 "Check the status() first to make sure view is valid");
238 "Check the size() of the view to make sure it's not empty");
239 CESIUM_ASSERT(index >= 0 &&
"index must be non-negative");
240 CESIUM_ASSERT(index < size() &&
"index must be less than size");
242 return _accessor[index];
252 int64_t
size() const noexcept {
return _size; }
270template <
typename ElementType>
281 :
PropertyView<ElementType, true>(), _accessor{}, _size{0} {}
292 "An empty property view should not be constructed with a valid status");
306 int64_t size) noexcept
314 if (!classProperty.defaultProperty) {
341 _accessor{accessorView},
344 ? accessorView.size()
362 std::optional<NormalizedType>
get(int64_t index)
const noexcept {
365 return this->defaultValue();
368 ElementType value = getRaw(index);
370 if (value == this->noData()) {
371 return this->defaultValue();
382 constexpr glm::length_t N = ElementType::length();
383 using T =
typename ElementType::value_type;
384 using NormalizedT =
typename NormalizedType::value_type;
392 constexpr glm::length_t N = ElementType::length();
393 using T =
typename ElementType::value_type;
394 using NormalizedT =
typename NormalizedType::value_type;
412 ElementType
getRaw(int64_t index)
const noexcept {
415 "Check the status() first to make sure view is valid");
418 "Check the size() of the view to make sure it's not empty");
419 CESIUM_ASSERT(index >= 0 &&
"index must be non-negative");
420 CESIUM_ASSERT(index < size() &&
"index must be less than size");
422 return _accessor[index];
432 int64_t
size() const noexcept {
return _size; }
A view on the data of one accessor of a glTF asset.
Indicates the status of a property attribute property view.
static const int ErrorInvalidBufferView
This property view uses an accessor that does not have a valid buffer view index.
static const int ErrorInvalidBuffer
This property view uses a buffer view that does not have a valid buffer index.
static const int ErrorAccessorNormalizationMismatch
This property view's normalization does not match the normalization of the accessor it uses.
static const int ErrorInvalidAccessor
This property view's attribute does not have a valid accessor index.
static const int ErrorMissingAttribute
This property view was initialized with a primitive that does not contain the specified attribute.
static const int ErrorAccessorComponentTypeMismatch
This property view's component type does not match the type of the accessor it uses.
static const int ErrorUnsupportedProperty
This property view is associated with a ClassProperty of an unsupported type.
static const int ErrorAccessorTypeMismatch
This property view's type does not match the type of the accessor it uses.
static const int ErrorInvalidPropertyAttribute
This property view was initialized from an invalid PropertyAttribute.
static const PropertyViewStatusType ErrorAccessorOutOfBounds
This property view uses an accessor that points outside the bounds of its target buffer view.
static const PropertyViewStatusType ErrorBufferViewOutOfBounds
This property view uses a buffer view that points outside the bounds of its target buffer.
std::optional< ElementType > get(int64_t index) const noexcept
Gets the value of the property for the given vertex index with all value transforms applied....
PropertyAttributePropertyView(PropertyViewStatusType status) noexcept
Constructs an invalid instance for an erroneous property.
ElementType getRaw(int64_t index) const noexcept
Gets the raw value of the property for the given vertex index.
PropertyAttributePropertyView() noexcept
Constructs an invalid instance for a non-existent property.
PropertyAttributePropertyView(const ClassProperty &classProperty, int64_t size) noexcept
Constructs an instance of an empty property that specifies a default value. Although this property ha...
int64_t size() const noexcept
Get the number of elements in this PropertyAttributePropertyView. If the view is valid,...
PropertyAttributePropertyView(const PropertyAttributeProperty &property, const ClassProperty &classProperty, const AccessorView< ElementType > &accessorView) noexcept
Construct a view of the data specified by a PropertyAttributeProperty.
ElementType getRaw(int64_t index) const noexcept
Gets the raw value of the property for the given vertex index.
PropertyAttributePropertyView(const PropertyAttributeProperty &property, const ClassProperty &classProperty, const AccessorView< ElementType > &accessorView) noexcept
Construct a view of the data specified by a PropertyAttributeProperty.
int64_t size() const noexcept
Get the number of elements in this PropertyAttributePropertyView. If the view is valid,...
std::optional< NormalizedType > get(int64_t index) const noexcept
Gets the value of the property for the given vertex index with all value transforms applied....
PropertyAttributePropertyView(PropertyViewStatusType status) noexcept
Constructs an invalid instance for an erroneous property.
PropertyAttributePropertyView() noexcept
Constructs an invalid instance for a non-existent property.
PropertyAttributePropertyView(const ClassProperty &classProperty, int64_t size) noexcept
Constructs an instance of an empty property that specifies a default value. Although this property ha...
A view of the data specified by a PropertyAttributeProperty.
Indicates the status of a property view.
static const PropertyViewStatusType Valid
This property view is valid and ready to use.
static const PropertyViewStatusType ErrorNonexistentProperty
This property view is trying to view a property that does not exist.
static const PropertyViewStatusType EmptyPropertyWithDefault
This property view does not contain any data, but specifies a default value. This happens when a clas...
Represents a metadata property in EXT_structural_metadata.
Classes for working with glTF models.
T transformValue(const T &value, const std::optional< T > &offset, const std::optional< T > &scale)
Transforms the value by optional offset and scale factors.
double normalize(T value)
Normalizes the given value between [0, 1] if unsigned or [-1, 1] if signed, based on the type's maxim...
int32_t PropertyViewStatusType
The type used for fields of PropertyViewStatus.
An attribute containing property values.
Convert an integer numeric type to the corresponding representation as a double type....