23 #include "sdf/sdf_config.h"
29 inline namespace SDF_VERSION_NAMESPACE {
33 class PbrWorkflowPrivate;
191 public:
void SetLightMap(
const std::string &_map,
unsigned int _uvSet = 0u);
256 private: PbrWorkflowPrivate *dataPtr =
nullptr;
309 private: PbrPrivate *dataPtr =
nullptr;
This class contains Physically-Based-Rendering (PBR) workflow properties.
Definition: Pbr.hh:61
~PbrWorkflow()
Destructor.
void SetNormalMap(const std::string &_map, NormalMapSpace _space=NormalMapSpace::TANGENT)
Set the normal map filename.
PbrWorkflow & operator=(const PbrWorkflow &_workflow)
Assignment operator.
bool operator==(const PbrWorkflow &_workflow) const
Return true if both PbrWorkflow objects contain the same values.
void SetMetalness(const double _value)
Set the metalness value of the material for metal workflow.
NormalMapSpace NormalMapType() const
Get the normal map type, either tangent or object space.
void SetGlossiness(const double _value)
Set the glossiness value of the material for specular workflow.
double Metalness() const
Get the metalness value of the material for metal workflow.
void SetMetalnessMap(const std::string &_map)
Set the metalness map filename for metal workflow.
std::string NormalMap() const
Get the normal map filename.
void SetRoughnessMap(const std::string &_map)
Set the roughness map filename for metal workflow.
double Roughness() const
Get the roughness value of the material for metal workflow.
void SetAlbedoMap(const std::string &_map)
Set the albedo map filename.
void SetEnvironmentMap(const std::string &_map)
Set the environment map filename.
std::string LightMap() const
Get the light map filename.
PbrWorkflowType Type() const
Get the workflow type.
std::string RoughnessMap() const
Get the roughness map filename for metal workflow.
void SetGlossinessMap(const std::string &_map)
Set the glossiness map filename for specular workflow.
void SetLightMap(const std::string &_map, unsigned int _uvSet=0u)
Set the light map filename.
std::string AlbedoMap() const
Get the albedo map filename.
std::string EnvironmentMap() const
Get the environment map filename.
void SetEmissiveMap(const std::string &_map)
Set the emissive map filename.
std::string SpecularMap() const
Get the specular map filename for specular workflow.
std::string GlossinessMap() const
Get the glossiness map filename for specular workflow.
PbrWorkflow(PbrWorkflow &&_workflow) noexcept
Move constructor.
PbrWorkflow & operator=(PbrWorkflow &&_workflow)
Move assignment operator.
bool operator!=(const PbrWorkflow &_workflow) const
Return true this PbrWorkflow object does not contain the same values as the passed in parameter.
std::string AmbientOcclusionMap() const
Get the ambient occlusion map filename.
void SetSpecularMap(const std::string &_map)
Set the specular map filename for specular workflow.
std::string MetalnessMap() const
Get the metalness map filename for metal workflow.
void SetType(PbrWorkflowType _type)
Set the PBR workflow to use.
PbrWorkflow()
Default constructor.
Errors Load(ElementPtr _sdf)
Load the pbr workflow based on an element pointer.
void SetAmbientOcclusionMap(const std::string &_map)
Set the ambient occlusion map filename.
PbrWorkflow(const PbrWorkflow &_workflow)
Copy constructor.
sdf::ElementPtr Element() const
Get a pointer to the SDF element that was used during load.
std::string EmissiveMap() const
Get the emissive map filename.
void SetRoughness(const double _value)
Set the roughness value of the material for metal workflow.
double Glossiness() const
Get the glossiness value of the material for specular workflow.
unsigned int LightMapTexCoordSet() const
Get the light map texture coordinate set.
This class provides access to Physically-Based-Rendering (PBR) material workflows.
Definition: Pbr.hh:262
Pbr()
Default constructor.
PbrWorkflow * Workflow(PbrWorkflowType _type) const
Get a PBR workflow by type.
void SetWorkflow(PbrWorkflowType _type, const PbrWorkflow &_workflow)
Set a PBR workflow by type.
Pbr(Pbr &&_pbr) noexcept
Move constructor.
Pbr(const Pbr &_pbr)
Copy constructor.
Pbr & operator=(const Pbr &_pbr)
Assignment operator.
Errors Load(ElementPtr _sdf)
Load the pbr based on an element pointer.
Pbr & operator=(Pbr &&_pbr)
Move assignment operator.
NormalMapSpace
Space the normal map is defined in.
Definition: Pbr.hh:50
PbrWorkflowType
Type of PBR workflow.
Definition: Pbr.hh:37
std::vector< Error > Errors
A vector of Error.
Definition: Types.hh:89
std::shared_ptr< Element > ElementPtr
Definition: Element.hh:53
namespace for Simulation Description Format parser
Definition: Actor.hh:33
#define SDFORMAT_VISIBLE
Use to represent "symbol visible" if supported.
Definition: system_util.hh:48