normalmap, bumpmap: throw an error message when used with 'bitmap' and no gamma value is specified. also added documentation for normalmap

metadata
Wenzel Jakob 2014-05-19 17:26:14 +02:00
parent 4805fc570e
commit 868b0ea866
8 changed files with 41 additions and 8 deletions

View File

@ -24,7 +24,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*! \plugin{blendbsdf}{Blended material} /*! \plugin{blendbsdf}{Blended material}
* \order{16} * \order{17}
* \parameters{ * \parameters{
* \parameter{weight}{\Float\Or\Texture}{A floating point value or texture * \parameter{weight}{\Float\Or\Texture}{A floating point value or texture
* with values between zero and one. The extreme values zero and one activate the * with values between zero and one. The extreme values zero and one activate the

View File

@ -113,6 +113,11 @@ public:
} else if (child->getClass()->derivesFrom(MTS_CLASS(Texture))) { } else if (child->getClass()->derivesFrom(MTS_CLASS(Texture))) {
if (m_displacement != NULL) if (m_displacement != NULL)
Log(EError, "Only a single displacement texture can be specified!"); Log(EError, "Only a single displacement texture can be specified!");
const Properties &props = child->getProperties();
if (props.getPluginName() == "bitmap" && !props.hasProperty("gamma"))
Log(EError, "When using a bitmap texture as a bump map, please explicitly specify "
"the 'gamma' parameter of the bitmap plugin. In most cases the following is the correct choice: "
"<float name=\"gamma\" value=\"1.0\"/>");
m_displacement = static_cast<Texture *>(child); m_displacement = static_cast<Texture *>(child);
} else { } else {
BSDF::addChild(name, child); BSDF::addChild(name, child);

View File

@ -22,7 +22,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*!\plugin{mask}{Opacity mask} /*!\plugin{mask}{Opacity mask}
* \order{17} * \order{18}
* \parameters{ * \parameters{
* \parameter{opacity}{\Spectrum\Or\Texture}{ * \parameter{opacity}{\Spectrum\Or\Texture}{
* Specifies the per-channel opacity (where $1=$ completely opaque)\default{0.5}. * Specifies the per-channel opacity (where $1=$ completely opaque)\default{0.5}.

View File

@ -23,7 +23,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*! \plugin{mixturebsdf}{Mixture material} /*! \plugin{mixturebsdf}{Mixture material}
* \order{15} * \order{16}
* \parameters{ * \parameters{
* \parameter{weights}{\String}{A comma-separated list of BSDF weights} * \parameter{weights}{\String}{A comma-separated list of BSDF weights}
* \parameter{\Unnamed}{\BSDF}{Multiple BSDF instances that should be * \parameter{\Unnamed}{\BSDF}{Multiple BSDF instances that should be

View File

@ -21,6 +21,29 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*! \plugin{normalmap}{Normal map modifier}
* \order{13}
* \icon{bsdf_bumpmap}
*
* \parameters{
* \parameter{\Unnamed}{\Texture}{
* The color values of this texture specify the perturbed
* normals relative in the local surface coordinate system.
* }
* \parameter{\Unnamed}{\BSDF}{A BSDF model that should
* be affected by the normal map}
* }
*
* This plugin is conceptually similar to the \pluginref{bump} map plugin
* but uses a normal map instead of a bump map. A normal map is a RGB texture, whose color channels
* encode the XYZ coordinates of the desired surface normals.
* These are specified \emph{relative} to the local shading frame,
* which means that a normal map with a value of $(0,0,1)$ everywhere
* causes no changes to the surface.
* To turn the 3D normal directions into (nonnegative) color values
* suitable for this plugin, the
* mapping $x \mapsto (x+1)/2$ must be applied to each component.
*/
class NormalMap : public BSDF { class NormalMap : public BSDF {
public: public:
NormalMap(const Properties &props) : BSDF(props) { } NormalMap(const Properties &props) : BSDF(props) { }
@ -61,7 +84,12 @@ public:
m_nested = static_cast<BSDF *>(child); m_nested = static_cast<BSDF *>(child);
} else if (child->getClass()->derivesFrom(MTS_CLASS(Texture))) { } else if (child->getClass()->derivesFrom(MTS_CLASS(Texture))) {
if (m_normals != NULL) if (m_normals != NULL)
Log(EError, "Only a single normals texture can be specified!"); Log(EError, "Only a single normal texture can be specified!");
const Properties &props = child->getProperties();
if (props.getPluginName() == "bitmap" && !props.hasProperty("gamma"))
Log(EError, "When using a bitmap texture as a normal map, please explicitly specify "
"the 'gamma' parameter of the bitmap plugin. In most cases the following is the correct choice: "
"<float name=\"gamma\" value=\"1.0\"/>");
m_normals = static_cast<Texture *>(child); m_normals = static_cast<Texture *>(child);
} else { } else {
BSDF::addChild(name, child); BSDF::addChild(name, child);
@ -192,7 +220,7 @@ protected:
// ================ Hardware shader implementation ================ // ================ Hardware shader implementation ================
/** /**
* This is a quite approximate version of the bump map model -- it likely * This is a quite approximate version of the normal map model -- it likely
* won't match the reference exactly, but it should be good enough for * won't match the reference exactly, but it should be good enough for
* preview purposes * preview purposes
*/ */

View File

@ -23,7 +23,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*!\plugin{phong}{Modified Phong BRDF} /*!\plugin{phong}{Modified Phong BRDF}
* \order{13} * \order{14}
* \parameters{ * \parameters{
* \parameter{exponent}{\Float\Or\Texture}{ * \parameter{exponent}{\Float\Or\Texture}{
* Specifies the Phong exponent \default{30}. * Specifies the Phong exponent \default{30}.

View File

@ -23,7 +23,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*!\plugin{twosided}{Two-sided BRDF adapter} /*!\plugin{twosided}{Two-sided BRDF adapter}
* \order{18} * \order{19}
* \parameters{ * \parameters{
* \parameter{\Unnamed}{\BSDF}{A nested BRDF that should * \parameter{\Unnamed}{\BSDF}{A nested BRDF that should
* be turned into a two-sided scattering model. If two BRDFs * be turned into a two-sided scattering model. If two BRDFs

View File

@ -24,7 +24,7 @@
MTS_NAMESPACE_BEGIN MTS_NAMESPACE_BEGIN
/*!\plugin{ward}{Anisotropic Ward BRDF} /*!\plugin{ward}{Anisotropic Ward BRDF}
* \order{14} * \order{15}
* \parameters{ * \parameters{
* \parameter{variant}{\String}{ * \parameter{variant}{\String}{
* Determines the variant of the Ward model to use: * Determines the variant of the Ward model to use: