|
|
@ -324,6 +324,7 @@ Ogre::String NIFMaterialLoader::getMaterial(const Nif::ShapeData *shapedata,
|
|
|
|
instance->setProperty("normalMap", sh::makeProperty(texName[Nif::NiTexturingProperty::BumpTexture]));
|
|
|
|
instance->setProperty("normalMap", sh::makeProperty(texName[Nif::NiTexturingProperty::BumpTexture]));
|
|
|
|
instance->setProperty("detailMap", sh::makeProperty(texName[Nif::NiTexturingProperty::DetailTexture]));
|
|
|
|
instance->setProperty("detailMap", sh::makeProperty(texName[Nif::NiTexturingProperty::DetailTexture]));
|
|
|
|
instance->setProperty("emissiveMap", sh::makeProperty(texName[Nif::NiTexturingProperty::GlowTexture]));
|
|
|
|
instance->setProperty("emissiveMap", sh::makeProperty(texName[Nif::NiTexturingProperty::GlowTexture]));
|
|
|
|
|
|
|
|
instance->setProperty("darkMap", sh::makeProperty(texName[Nif::NiTexturingProperty::DarkTexture]));
|
|
|
|
if (!texName[Nif::NiTexturingProperty::BaseTexture].empty())
|
|
|
|
if (!texName[Nif::NiTexturingProperty::BaseTexture].empty())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
instance->setProperty("use_diffuse_map", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
instance->setProperty("use_diffuse_map", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
@ -339,6 +340,11 @@ Ogre::String NIFMaterialLoader::getMaterial(const Nif::ShapeData *shapedata,
|
|
|
|
instance->setProperty("use_detail_map", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
instance->setProperty("use_detail_map", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
instance->setProperty("detailMapUVSet", sh::makeProperty(new sh::IntValue(texprop->textures[Nif::NiTexturingProperty::DetailTexture].uvSet)));
|
|
|
|
instance->setProperty("detailMapUVSet", sh::makeProperty(new sh::IntValue(texprop->textures[Nif::NiTexturingProperty::DetailTexture].uvSet)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!texName[Nif::NiTexturingProperty::DarkTexture].empty())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
instance->setProperty("use_dark_map", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
|
|
|
|
instance->setProperty("darkMapUVSet", sh::makeProperty(new sh::IntValue(texprop->textures[Nif::NiTexturingProperty::DarkTexture].uvSet)));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool useParallax = !texName[Nif::NiTexturingProperty::BumpTexture].empty()
|
|
|
|
bool useParallax = !texName[Nif::NiTexturingProperty::BumpTexture].empty()
|
|
|
|
&& texName[Nif::NiTexturingProperty::BumpTexture].find("_nh.") != std::string::npos;
|
|
|
|
&& texName[Nif::NiTexturingProperty::BumpTexture].find("_nh.") != std::string::npos;
|
|
|
@ -348,6 +354,7 @@ Ogre::String NIFMaterialLoader::getMaterial(const Nif::ShapeData *shapedata,
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(i == Nif::NiTexturingProperty::BaseTexture ||
|
|
|
|
if(i == Nif::NiTexturingProperty::BaseTexture ||
|
|
|
|
i == Nif::NiTexturingProperty::DetailTexture ||
|
|
|
|
i == Nif::NiTexturingProperty::DetailTexture ||
|
|
|
|
|
|
|
|
i == Nif::NiTexturingProperty::DarkTexture ||
|
|
|
|
i == Nif::NiTexturingProperty::BumpTexture ||
|
|
|
|
i == Nif::NiTexturingProperty::BumpTexture ||
|
|
|
|
i == Nif::NiTexturingProperty::GlowTexture)
|
|
|
|
i == Nif::NiTexturingProperty::GlowTexture)
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
@ -358,15 +365,19 @@ Ogre::String NIFMaterialLoader::getMaterial(const Nif::ShapeData *shapedata,
|
|
|
|
if (vertexColour)
|
|
|
|
if (vertexColour)
|
|
|
|
instance->setProperty("has_vertex_colour", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
instance->setProperty("has_vertex_colour", sh::makeProperty(new sh::BooleanValue(true)));
|
|
|
|
|
|
|
|
|
|
|
|
// Add transparency if NiAlphaProperty was present
|
|
|
|
// Override alpha flags based on our override list (transparency-overrides.cfg)
|
|
|
|
NifOverrides::TransparencyResult result = NifOverrides::Overrides::getTransparencyOverride(texName[0]);
|
|
|
|
if (!texName[0].empty())
|
|
|
|
if (result.first)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
alphaFlags = (1<<9) | (6<<10); /* alpha_rejection enabled, greater_equal */
|
|
|
|
NifOverrides::TransparencyResult result = NifOverrides::Overrides::getTransparencyOverride(texName[0]);
|
|
|
|
alphaTest = result.second;
|
|
|
|
if (result.first)
|
|
|
|
depthFlags = (1<<0) | (1<<1); // depth_write on, depth_check on
|
|
|
|
{
|
|
|
|
|
|
|
|
alphaFlags = (1<<9) | (6<<10); /* alpha_rejection enabled, greater_equal */
|
|
|
|
|
|
|
|
alphaTest = result.second;
|
|
|
|
|
|
|
|
depthFlags = (1<<0) | (1<<1); // depth_write on, depth_check on
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Add transparency if NiAlphaProperty was present
|
|
|
|
if((alphaFlags&1))
|
|
|
|
if((alphaFlags&1))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::string blend_mode;
|
|
|
|
std::string blend_mode;
|
|
|
|