forked from blender/blender
MaterialX: split standard_surface into basic nodes #26
@ -291,11 +291,11 @@ NODE_SHADER_MATERIALX_BEGIN
|
|||||||
/* TODO: implement for BSDF and EDF */
|
/* TODO: implement for BSDF and EDF */
|
||||||
return empty();
|
return empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
NodeItem base_color = get_input_value("Base Color", NodeItem::Type::Color3);
|
NodeItem base_color = get_input_value("Base Color", NodeItem::Type::Color3);
|
||||||
|
|
||||||
NodeItem subsurface = get_input_value("Subsurface", NodeItem::Type::Float);
|
NodeItem subsurface = get_input_value("Subsurface", NodeItem::Type::Float);
|
||||||
NodeItem subsurface_radius = get_input_value("Subsurface Radius", NodeItem::Type::Color3);
|
NodeItem subsurface_radius = get_input_value("Subsurface Radius", NodeItem::Type::Vector3);
|
||||||
NodeItem subsurface_scale = get_input_value("Subsurface Scale", NodeItem::Type::Float);
|
NodeItem subsurface_scale = get_input_value("Subsurface Scale", NodeItem::Type::Float);
|
||||||
|
|
||||||
NodeItem metallic = get_input_value("Metallic", NodeItem::Type::Float);
|
NodeItem metallic = get_input_value("Metallic", NodeItem::Type::Float);
|
||||||
@ -329,7 +329,7 @@ NODE_SHADER_MATERIALX_BEGIN
|
|||||||
NodeItem tangent = get_input_link("Tangent", NodeItem::Type::Vector3);
|
NodeItem tangent = get_input_link("Tangent", NodeItem::Type::Vector3);
|
||||||
|
|
||||||
subsurface_radius = subsurface_radius * subsurface_scale;
|
subsurface_radius = subsurface_radius * subsurface_scale;
|
||||||
|
# if 0
|
||||||
/* Creating standard_surface */
|
/* Creating standard_surface */
|
||||||
NodeItem res = create_node("standard_surface", NodeItem::Type::SurfaceShader);
|
NodeItem res = create_node("standard_surface", NodeItem::Type::SurfaceShader);
|
||||||
res.set_input("base", val(1.0f));
|
res.set_input("base", val(1.0f));
|
||||||
@ -377,6 +377,213 @@ NODE_SHADER_MATERIALX_BEGIN
|
|||||||
res.set_input("emission_color", emission);
|
res.set_input("emission_color", emission);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
#else
|
||||||
|
|
||||||
|
NodeItem res = create_node("surface", NodeItem::Type::SurfaceShader);
|
||||||
|
|
||||||
|
NodeItem n_opacity_luminance = create_node("luminance", NodeItem::Type::Color3);
|
||||||
|
n_opacity_luminance.set_input("in", val(MaterialX::Color3(1.0f, 1.0f, 1.0f)));
|
||||||
|
res.set_input("opacity", n_opacity_luminance.extract(0));
|
||||||
|
|
||||||
|
NodeItem n_emission_edf = create_node("uniform_edf", NodeItem::Type::EDF);
|
||||||
|
n_emission_edf.set_input("color", emission * emission_strength);
|
||||||
|
res.set_input("edf", n_emission_edf);
|
||||||
|
|
||||||
|
NodeItem n_coat_layer = create_node("layer", NodeItem::Type::BSDF);
|
||||||
|
NodeItem n_coat_attenuation = create_node("mix", NodeItem::Type::Color3);
|
||||||
|
n_coat_attenuation.set_input("fg", base_color);
|
||||||
|
n_coat_attenuation.set_input("bg", val(MaterialX::Color3(1.0f, 1.0f, 1.0f)));
|
||||||
|
n_coat_attenuation.set_input("mix", coat);
|
||||||
|
|
||||||
|
NodeItem n_metalness_mix = create_node("mix", NodeItem::Type::BSDF);
|
||||||
|
n_metalness_mix.set_input("mix", metallic);
|
||||||
|
|
||||||
|
NodeItem n_specular_layer = create_node("layer", NodeItem::Type::BSDF);
|
||||||
|
NodeItem n_transmission_mix = create_node("mix", NodeItem::Type::BSDF);
|
||||||
|
n_transmission_mix.set_input("mix", transmission);
|
||||||
|
|
||||||
|
NodeItem n_sheen_layer = create_node("layer", NodeItem::Type::BSDF);
|
||||||
|
NodeItem n_subsurface_mix = create_node("mix", NodeItem::Type::BSDF);
|
||||||
|
n_subsurface_mix.set_input("mix", subsurface);
|
||||||
|
|
||||||
|
NodeItem n_diffuse_bsdf = create_node("oren_nayar_diffuse_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_diffuse_bsdf.set_input("roughness", roughness);
|
||||||
|
n_diffuse_bsdf.set_input("weight", val(1.0f));
|
||||||
|
if (normal) {
|
||||||
|
n_diffuse_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
NodeItem n_coat_gamma = coat.clamp(0.0f, 1.0f) * val(0.0f) + val(1.0f);
|
||||||
|
n_diffuse_bsdf.set_input("color", base_color.max(val(0.0f)) ^ n_coat_gamma);
|
||||||
|
|
||||||
|
n_subsurface_mix.set_input("bg", n_diffuse_bsdf);
|
||||||
|
|
||||||
|
NodeItem n_selected_subsurface_bsdf = create_node("mix", NodeItem::Type::BSDF);
|
||||||
|
n_selected_subsurface_bsdf.set_input("mix", val(0.0f));
|
||||||
|
|
||||||
|
NodeItem n_subsurface_bsdf = create_node("subsurface_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_subsurface_bsdf.set_input("radius", subsurface_radius);
|
||||||
|
n_subsurface_bsdf.set_input("anisotropy", anisotropic);
|
||||||
|
if (normal) {
|
||||||
|
n_subsurface_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
NodeItem n_coat_affected_subsurface_color = base_color.max(val(0.0f)) ^ n_coat_gamma;
|
||||||
|
n_subsurface_bsdf.set_input("color", n_coat_affected_subsurface_color);
|
||||||
|
|
||||||
|
n_selected_subsurface_bsdf.set_input("bg", n_subsurface_bsdf);
|
||||||
|
|
||||||
|
NodeItem n_translucent_bsdf = create_node("translucent_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_translucent_bsdf.set_input("color", n_coat_affected_subsurface_color);
|
||||||
|
if (normal) {
|
||||||
|
n_translucent_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
n_selected_subsurface_bsdf.set_input("fg", n_translucent_bsdf);
|
||||||
|
|
||||||
|
n_subsurface_mix.set_input("fg", n_selected_subsurface_bsdf);
|
||||||
|
|
||||||
|
n_sheen_layer.set_input("base", n_subsurface_mix);
|
||||||
|
|
||||||
|
NodeItem n_sheen_bsdf = create_node("sheen_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_sheen_bsdf.set_input("weight", sheen);
|
||||||
|
n_sheen_bsdf.set_input("color", base_color);
|
||||||
|
n_sheen_bsdf.set_input("roughness", roughness);
|
||||||
|
if (normal) {
|
||||||
|
n_translucent_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
n_sheen_layer.set_input("top", n_sheen_bsdf);
|
||||||
|
|
||||||
|
n_transmission_mix.set_input("bg", n_sheen_layer);
|
||||||
|
|
||||||
|
NodeItem n_transmission_bsdf = create_node("dielectric_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_transmission_bsdf.set_input("tint", base_color);
|
||||||
|
n_transmission_bsdf.set_input("ior", ior);
|
||||||
|
if (normal) {
|
||||||
|
n_transmission_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
|
||||||
|
NodeItem n_transmission_roughness = create_node("roughness_anisotropy", NodeItem::Type::Vector2);
|
||||||
|
NodeItem n_coat_affected_transmission_roughness = create_node("mix",
|
||||||
|
NodeItem::Type::Float);
|
||||||
|
n_coat_affected_transmission_roughness.set_input("fg", val(1.0f));
|
||||||
|
n_coat_affected_transmission_roughness.set_input("bg", (roughness + roughness).clamp(0.0f, 1.0f));
|
||||||
|
|
||||||
|
NodeItem n_coat_affect_roughness_multiply2 = coat * val(0.0f) * roughness;
|
||||||
|
|
||||||
|
n_coat_affected_transmission_roughness.set_input("mix", n_coat_affect_roughness_multiply2);
|
||||||
|
n_transmission_roughness.set_input("roughness", n_coat_affected_transmission_roughness);
|
||||||
|
n_transmission_roughness.set_input("anisotropy", anisotropic);
|
||||||
|
n_transmission_bsdf.set_input("roughness", n_transmission_roughness);
|
||||||
|
|
||||||
|
NodeItem n_main_tangent = empty();
|
||||||
|
|
||||||
|
if (tangent) {
|
||||||
|
NodeItem n_tangent_rotate = create_node("rotate3d", NodeItem::Type::Vector3);
|
||||||
|
n_tangent_rotate.set_input("in", tangent);
|
||||||
|
n_tangent_rotate.set_input("amount", anisotropic_rotation * val(360.0f));
|
||||||
|
n_tangent_rotate.set_input("axis", normal);
|
||||||
|
|
||||||
|
NodeItem n_tangent_rotate_normalize = create_node("normalize", NodeItem::Type::Vector3);
|
||||||
|
n_tangent_rotate.set_input("in", n_tangent_rotate);
|
||||||
|
|
||||||
|
n_main_tangent = anisotropic.if_else(
|
||||||
|
NodeItem::CompareOp::Greater, val(0.0f), n_tangent_rotate_normalize, tangent);
|
||||||
|
}
|
||||||
|
if (n_main_tangent) {
|
||||||
|
n_transmission_bsdf.set_input("tangent", n_main_tangent);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
n_transmission_mix.set_input("fg", n_transmission_bsdf);
|
||||||
|
n_specular_layer.set_input("base", n_transmission_mix);
|
||||||
|
|
||||||
|
NodeItem n_specular_bsdf = create_node("dielectric_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_specular_bsdf.set_input("weight", specular);
|
||||||
|
n_specular_bsdf.set_input("tint", base_color);
|
||||||
|
n_specular_bsdf.set_input("ior", ior);
|
||||||
|
n_specular_bsdf.set_input("scatter_mode", val(std::string("R")));
|
||||||
|
if (n_main_tangent) {
|
||||||
|
n_specular_bsdf.set_input("tangent", n_main_tangent);
|
||||||
|
}
|
||||||
|
NodeItem n_main_roughness = create_node("roughness_anisotropy", NodeItem::Type::Vector2);
|
||||||
|
NodeItem n_coat_affected_roughness = create_node("mix", NodeItem::Type::Float);
|
||||||
|
n_coat_affected_roughness.set_input("fg", val(1.0f));
|
||||||
|
n_coat_affected_roughness.set_input("bg", roughness);
|
||||||
|
n_coat_affected_roughness.set_input("mix", n_coat_affect_roughness_multiply2);
|
||||||
|
|
||||||
|
n_main_roughness.set_input("roughness", n_coat_affected_roughness);
|
||||||
|
n_main_roughness.set_input("anisotropy", anisotropic);
|
||||||
|
|
||||||
|
n_specular_bsdf.set_input("roughness", n_main_roughness);
|
||||||
|
|
||||||
DagerD marked this conversation as resolved
Outdated
|
|||||||
|
n_specular_layer.set_input("top", n_specular_bsdf);
|
||||||
|
|
||||||
|
n_metalness_mix.set_input("bg", n_specular_layer);
|
||||||
|
|
||||||
|
NodeItem n_metal_bsdf = create_node("conductor_bsdf", NodeItem::Type::BSDF);
|
||||||
|
if (normal) {
|
||||||
|
n_metal_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
if (n_main_tangent) {
|
||||||
|
n_metal_bsdf.set_input("tangent", n_main_tangent);
|
||||||
|
}
|
||||||
|
NodeItem n_artistic_ior = create_node("artistic_ior", NodeItem::Type::Multioutput);
|
||||||
|
n_artistic_ior.set_input("reflectivity", base_color * val(1.0f));
|
||||||
|
n_artistic_ior.set_input("edge_color", base_color * specular);
|
||||||
|
NodeItem n_ior_out = n_artistic_ior.add_output("ior", NodeItem::Type::Color3);
|
||||||
|
NodeItem n_extinction_out = n_artistic_ior.add_output("extinction", NodeItem::Type::Color3);
|
||||||
|
n_metal_bsdf.set_input("ior", n_ior_out);
|
||||||
|
n_metal_bsdf.set_input("extinction", n_extinction_out);
|
||||||
|
|
||||||
|
n_metalness_mix.set_input("fg", n_metal_bsdf);
|
||||||
|
|
||||||
|
NodeItem n_thin_film_layer = create_node("layer", NodeItem::Type::BSDF);
|
||||||
|
n_thin_film_layer.set_input("base", n_metalness_mix);
|
||||||
|
|
||||||
|
NodeItem n_thin_film_bsdf = create_node("thin_film_bsdf", NodeItem::Type::BSDF);
|
||||||
|
n_thin_film_bsdf.set_input("thickness", val(0.0f));
|
||||||
|
n_thin_film_bsdf.set_input("ior", val(1.5f));
|
||||||
|
|
||||||
|
n_thin_film_layer.set_input("top", n_thin_film_bsdf);
|
||||||
|
|
||||||
|
n_coat_layer.set_input("base", n_thin_film_layer * n_coat_attenuation);
|
||||||
|
|
||||||
|
NodeItem n_coat_bsdf = create_node("dielectric_bsdf", NodeItem::Type::BSDF);
|
||||||
|
if (normal) {
|
||||||
|
n_coat_bsdf.set_input("normal", normal);
|
||||||
|
}
|
||||||
|
n_coat_bsdf.set_input("weight", coat);
|
||||||
|
n_coat_bsdf.set_input("tint", val(MaterialX::Color3(1.0f, 1.0f, 1.0f)));
|
||||||
|
n_coat_bsdf.set_input("ior", ior);
|
||||||
|
n_coat_bsdf.set_input("scatter_mode", val(std::string("R")));
|
||||||
|
|
||||||
|
NodeItem n_coat_roughness_vector = create_node("roughness_anisotropy", NodeItem::Type::Vector2);
|
||||||
|
n_coat_roughness_vector.set_input("roughness", roughness);
|
||||||
|
n_coat_roughness_vector.set_input("anisotropy", anisotropic);
|
||||||
|
|
||||||
|
n_coat_bsdf.set_input("roughness", n_coat_roughness_vector);
|
||||||
|
|
||||||
|
if (tangent) {
|
||||||
|
NodeItem n_coat_tangent_rotate = create_node("rotate3d", NodeItem::Type::Vector3);
|
||||||
|
n_coat_tangent_rotate.set_input("in", tangent);
|
||||||
|
n_coat_tangent_rotate.set_input("amount", anisotropic_rotation * val(360.0f));
|
||||||
|
n_coat_tangent_rotate.set_input("axis", normal);
|
||||||
|
|
||||||
|
NodeItem n_coat_tangent_rotate_normalize = create_node("normalize", NodeItem::Type::Vector3);
|
||||||
|
n_coat_tangent_rotate_normalize.set_input("in", n_coat_tangent_rotate);
|
||||||
|
|
||||||
|
NodeItem n_coat_tangent = anisotropic.if_else(
|
||||||
|
NodeItem::CompareOp::Greater, val(0.0f), n_coat_tangent_rotate_normalize, tangent);
|
||||||
|
|
||||||
|
n_coat_bsdf.set_input("tangent", n_coat_tangent);
|
||||||
|
}
|
||||||
|
n_coat_layer.set_input("top", n_coat_bsdf);
|
||||||
|
|
||||||
|
res.set_input("bsdf", n_coat_layer);
|
||||||
|
# endif
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
NODE_SHADER_MATERIALX_END
|
NODE_SHADER_MATERIALX_END
|
||||||
|
Loading…
Reference in New Issue
Block a user
This node is created in MaterialOutput.
Should be: