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

The material appearance of a primitive. More...

#include <CesiumGltf/Material.h>

Inheritance diagram for CesiumGltf::Material:
CesiumGltf::NamedObject CesiumUtility::ExtensibleObject

Classes

struct  AlphaMode
 Known values for The alpha rendering mode of the material. 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 CesiumGltf::NamedObject
int64_t getSizeBytes () const
 Calculates the size in bytes of this object, including the contents of all collections, pointers, and strings. 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

std::optional< CesiumGltf::MaterialPBRMetallicRoughnesspbrMetallicRoughness
 A set of parameter values that are used to define the metallic-roughness material model from Physically Based Rendering (PBR) methodology. When undefined, all the default values of pbrMetallicRoughness MUST apply.
 
std::optional< CesiumGltf::MaterialNormalTextureInfonormalTexture
 The tangent space normal texture.
 
std::optional< CesiumGltf::MaterialOcclusionTextureInfoocclusionTexture
 The occlusion texture.
 
std::optional< CesiumGltf::TextureInfoemissiveTexture
 The emissive texture.
 
std::vector< double > emissiveFactor = {0, 0, 0}
 The factors for the emissive color of the material.
 
std::string alphaMode = AlphaMode::OPAQUE
 The alpha rendering mode of the material.
 
double alphaCutoff = 0.5
 The alpha cutoff value of the material.
 
bool doubleSided = false
 Specifies whether the material is double sided.
 
- Public Attributes inherited from CesiumGltf::NamedObject
std::string name
 The user-defined name of this object.
 
- 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 = "Material"
 The original name of this type.
 

Detailed Description

The material appearance of a primitive.

Definition at line 20 of file Material.h.

Member Function Documentation

◆ getSizeBytes()

int64_t CesiumGltf::Material::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 135 of file Material.h.

Member Data Documentation

◆ alphaCutoff

double CesiumGltf::Material::alphaCutoff = 0.5

The alpha cutoff value of the material.

Specifies the cutoff threshold when in MASK alpha mode. If the alpha value is greater than or equal to this value then it is rendered as fully opaque, otherwise, it is rendered as fully transparent. A value greater than 1.0 will render the entire material as fully transparent. This value MUST be ignored for other alpha modes. When alphaMode is not defined, this value MUST NOT be defined.

Definition at line 117 of file Material.h.

◆ alphaMode

std::string CesiumGltf::Material::alphaMode = AlphaMode::OPAQUE

The alpha rendering mode of the material.

Known values are defined in AlphaMode.

The material's alpha rendering mode enumeration specifying the interpretation of the alpha value of the base color.

Definition at line 105 of file Material.h.

◆ doubleSided

bool CesiumGltf::Material::doubleSided = false

Specifies whether the material is double sided.

When this value is false, back-face culling is enabled. When this value is true, back-face culling is disabled and double-sided lighting is enabled. The back-face MUST have its normals reversed before the lighting equation is evaluated.

Definition at line 127 of file Material.h.

◆ emissiveFactor

std::vector<double> CesiumGltf::Material::emissiveFactor = {0, 0, 0}

The factors for the emissive color of the material.

This value defines linear multipliers for the sampled texels of the emissive texture.

Definition at line 94 of file Material.h.

◆ emissiveTexture

std::optional<CesiumGltf::TextureInfo> CesiumGltf::Material::emissiveTexture

The emissive texture.

It controls the color and intensity of the light being emitted by the material. This texture contains RGB components encoded with the sRGB transfer function. If a fourth component (A) is present, it MUST be ignored. When undefined, the texture MUST be sampled as having 1.0 in RGB components.

Definition at line 86 of file Material.h.

◆ normalTexture

std::optional<CesiumGltf::MaterialNormalTextureInfo> CesiumGltf::Material::normalTexture

The tangent space normal texture.

The texture encodes RGB components with linear transfer function. Each texel represents the XYZ components of a normal vector in tangent space. The normal vectors use the convention +X is right and +Y is up. +Z points toward the viewer. If a fourth component (A) is present, it MUST be ignored. When undefined, the material does not have a tangent space normal texture.

Definition at line 64 of file Material.h.

◆ occlusionTexture

std::optional<CesiumGltf::MaterialOcclusionTextureInfo> CesiumGltf::Material::occlusionTexture

The occlusion texture.

The occlusion values are linearly sampled from the R channel. Higher values indicate areas that receive full indirect lighting and lower values indicate no indirect lighting. If other channels are present (GBA), they MUST be ignored for occlusion calculations. When undefined, the material does not have an occlusion texture.

Definition at line 75 of file Material.h.

◆ pbrMetallicRoughness

std::optional<CesiumGltf::MaterialPBRMetallicRoughness> CesiumGltf::Material::pbrMetallicRoughness

A set of parameter values that are used to define the metallic-roughness material model from Physically Based Rendering (PBR) methodology. When undefined, all the default values of pbrMetallicRoughness MUST apply.

Definition at line 52 of file Material.h.

◆ TypeName

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

The original name of this type.

Definition at line 24 of file Material.h.


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