mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-27 21:35:24 +00:00
merge
This commit is contained in:
parent
7d5b94709d
commit
d41050fb79
@ -212,23 +212,23 @@ void NIFLoader::createMaterial(const Ogre::String &name,
|
|||||||
const Ogre::Vector3 &emissive,
|
const Ogre::Vector3 &emissive,
|
||||||
float glossiness, float alpha,
|
float glossiness, float alpha,
|
||||||
int alphaFlags, float alphaTest,
|
int alphaFlags, float alphaTest,
|
||||||
const String &texName, bool vertexColor)
|
const Ogre::String &texName, bool vertexColor)
|
||||||
{
|
{
|
||||||
if (texName.empty())
|
if (texName.empty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
sh::MaterialInstance* instance = sh::Factory::getInstance ().createMaterialInstance (name, "openmw_objects_base");
|
sh::MaterialInstance* instance = sh::Factory::getInstance ().createMaterialInstance (name, "openmw_objects_base");
|
||||||
instance->setProperty ("ambient", sh::makeProperty<sh::Vector3> (
|
instance->setProperty ("ambient", sh::makeProperty<sh::Vector3> (
|
||||||
new sh::Vector3(ambient.array[0], ambient.array[1], ambient.array[2])));
|
new sh::Vector3(ambient.x, ambient.y, ambient.z)));
|
||||||
|
|
||||||
instance->setProperty ("diffuse", sh::makeProperty<sh::Vector4> (
|
instance->setProperty ("diffuse", sh::makeProperty<sh::Vector4> (
|
||||||
new sh::Vector4(diffuse.array[0], diffuse.array[1], diffuse.array[2], alpha)));
|
new sh::Vector4(diffuse.x, diffuse.y, diffuse.z, alpha)));
|
||||||
|
|
||||||
instance->setProperty ("specular", sh::makeProperty<sh::Vector4> (
|
instance->setProperty ("specular", sh::makeProperty<sh::Vector4> (
|
||||||
new sh::Vector4(specular.array[0], specular.array[1], specular.array[2], glossiness)));
|
new sh::Vector4(specular.x, specular.y, specular.z, glossiness)));
|
||||||
|
|
||||||
instance->setProperty ("emissive", sh::makeProperty<sh::Vector3> (
|
instance->setProperty ("emissive", sh::makeProperty<sh::Vector3> (
|
||||||
new sh::Vector3(emissive.array[0], emissive.array[1], emissive.array[2])));
|
new sh::Vector3(emissive.x, emissive.y, emissive.z)));
|
||||||
|
|
||||||
instance->setProperty ("diffuseMap", sh::makeProperty(texName));
|
instance->setProperty ("diffuseMap", sh::makeProperty(texName));
|
||||||
|
|
||||||
@ -679,7 +679,7 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
|||||||
{
|
{
|
||||||
//std::cout << "new";
|
//std::cout << "new";
|
||||||
createMaterial(material, d->ambient, d->diffuse, d->specular, d->emissive,
|
createMaterial(material, d->ambient, d->diffuse, d->specular, d->emissive,
|
||||||
d->glossiness, d->alpha, alphaFlags, alphaTest, texName, shape->data->colors.length != 0);
|
d->glossiness, d->alpha, alphaFlags, alphaTest, texName, shape->data->colors.size() != 0);
|
||||||
MaterialMap.insert(std::make_pair(texName,material));
|
MaterialMap.insert(std::make_pair(texName,material));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -689,7 +689,7 @@ void NIFLoader::handleNiTriShape(NiTriShape *shape, int flags, BoundsFinder &bou
|
|||||||
// material for it.
|
// material for it.
|
||||||
const Ogre::Vector3 zero(0.0f), one(1.0f);
|
const Ogre::Vector3 zero(0.0f), one(1.0f);
|
||||||
createMaterial(material, one, one, zero, zero, 0.0f, 1.0f,
|
createMaterial(material, one, one, zero, zero, 0.0f, 1.0f,
|
||||||
alphaFlags, alphaTest, texName, shape->data->colors.length != 0);
|
alphaFlags, alphaTest, texName, shape->data->colors.size() != 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // End of material block, if(!hidden) ...
|
} // End of material block, if(!hidden) ...
|
||||||
|
Loading…
x
Reference in New Issue
Block a user