mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-21 09:23:51 +00:00
Add DarkTexture and DetailTexture
This commit is contained in:
parent
c54ee16748
commit
6c8613ae35
1 changed files with 47 additions and 2 deletions
|
@ -26,6 +26,8 @@
|
||||||
#include <osg/Stencil>
|
#include <osg/Stencil>
|
||||||
#include <osg/Material>
|
#include <osg/Material>
|
||||||
#include <osg/Texture2D>
|
#include <osg/Texture2D>
|
||||||
|
#include <osg/TexEnv>
|
||||||
|
#include <osg/TexEnvCombine>
|
||||||
|
|
||||||
#include <components/nif/node.hpp>
|
#include <components/nif/node.hpp>
|
||||||
|
|
||||||
|
@ -668,10 +670,17 @@ namespace NifOsg
|
||||||
const Nif::NiTexturingProperty* texprop = static_cast<const Nif::NiTexturingProperty*>(property);
|
const Nif::NiTexturingProperty* texprop = static_cast<const Nif::NiTexturingProperty*>(property);
|
||||||
for (int i=0; i<Nif::NiTexturingProperty::NumTextures; ++i)
|
for (int i=0; i<Nif::NiTexturingProperty::NumTextures; ++i)
|
||||||
{
|
{
|
||||||
if (i != Nif::NiTexturingProperty::BaseTexture)
|
|
||||||
continue; // FIXME: implement other textures
|
|
||||||
if (texprop->textures[i].inUse)
|
if (texprop->textures[i].inUse)
|
||||||
{
|
{
|
||||||
|
if (i != Nif::NiTexturingProperty::BaseTexture
|
||||||
|
&& i != Nif::NiTexturingProperty::GlowTexture
|
||||||
|
&& i != Nif::NiTexturingProperty::DarkTexture
|
||||||
|
&& i != Nif::NiTexturingProperty::DetailTexture)
|
||||||
|
{
|
||||||
|
std::cerr << "Warning: unhandled texture stage " << i << std::endl;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
const Nif::NiTexturingProperty::Texture& tex = texprop->textures[i];
|
const Nif::NiTexturingProperty::Texture& tex = texprop->textures[i];
|
||||||
if(tex.texture.empty())
|
if(tex.texture.empty())
|
||||||
{
|
{
|
||||||
|
@ -679,6 +688,11 @@ namespace NifOsg
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
const Nif::NiSourceTexture *st = tex.texture.getPtr();
|
const Nif::NiSourceTexture *st = tex.texture.getPtr();
|
||||||
|
if (!st->external)
|
||||||
|
{
|
||||||
|
std::cerr << "Warning: unhandled internal texture " << std::endl;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
std::string filename (st->filename);
|
std::string filename (st->filename);
|
||||||
Misc::StringUtils::toLower(filename);
|
Misc::StringUtils::toLower(filename);
|
||||||
filename = "textures\\" + filename;
|
filename = "textures\\" + filename;
|
||||||
|
@ -706,6 +720,37 @@ namespace NifOsg
|
||||||
|
|
||||||
stateset->setTextureAttributeAndModes(i, texture2d, osg::StateAttribute::ON);
|
stateset->setTextureAttributeAndModes(i, texture2d, osg::StateAttribute::ON);
|
||||||
|
|
||||||
|
if (i == Nif::NiTexturingProperty::GlowTexture)
|
||||||
|
{
|
||||||
|
osg::TexEnv* texEnv = new osg::TexEnv;
|
||||||
|
texEnv->setMode(osg::TexEnv::ADD);
|
||||||
|
stateset->setTextureAttributeAndModes(i, texEnv, osg::StateAttribute::ON);
|
||||||
|
}
|
||||||
|
else if (i == Nif::NiTexturingProperty::DarkTexture)
|
||||||
|
{
|
||||||
|
// untested
|
||||||
|
osg::TexEnv* texEnv = new osg::TexEnv;
|
||||||
|
texEnv->setMode(osg::TexEnv::MODULATE);
|
||||||
|
stateset->setTextureAttributeAndModes(i, texEnv, osg::StateAttribute::ON);
|
||||||
|
}
|
||||||
|
else if (i == Nif::NiTexturingProperty::DetailTexture)
|
||||||
|
{
|
||||||
|
// untested
|
||||||
|
osg::TexEnvCombine* texEnv = new osg::TexEnvCombine;
|
||||||
|
texEnv->setScale_RGB(2.f);
|
||||||
|
texEnv->setCombine_Alpha(GL_MODULATE);
|
||||||
|
texEnv->setOperand0_Alpha(GL_SRC_ALPHA);
|
||||||
|
texEnv->setOperand1_Alpha(GL_SRC_ALPHA);
|
||||||
|
texEnv->setSource0_Alpha(GL_PREVIOUS);
|
||||||
|
texEnv->setSource1_Alpha(GL_TEXTURE);
|
||||||
|
texEnv->setCombine_RGB(GL_MODULATE);
|
||||||
|
texEnv->setOperand0_RGB(GL_SRC_COLOR);
|
||||||
|
texEnv->setOperand1_RGB(GL_SRC_COLOR);
|
||||||
|
texEnv->setSource0_RGB(GL_PREVIOUS);
|
||||||
|
texEnv->setSource1_RGB(GL_TEXTURE);
|
||||||
|
stateset->setTextureAttributeAndModes(i, texEnv, osg::StateAttribute::ON);
|
||||||
|
}
|
||||||
|
|
||||||
boundTextures[i] = tex.uvSet;
|
boundTextures[i] = tex.uvSet;
|
||||||
}
|
}
|
||||||
else if (boundTextures.find(i) != boundTextures.end())
|
else if (boundTextures.find(i) != boundTextures.end())
|
||||||
|
|
Loading…
Reference in a new issue