actorid
scrawl 13 years ago
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…
Cancel
Save