Port EffectManager
parent
fcc7aa02ab
commit
68f93294da
@ -1,102 +1,83 @@
|
|||||||
#include "effectmanager.hpp"
|
#include "effectmanager.hpp"
|
||||||
|
|
||||||
|
#include <osg/PositionAttitudeTransform>
|
||||||
|
|
||||||
#include <components/misc/resourcehelpers.hpp>
|
#include <components/misc/resourcehelpers.hpp>
|
||||||
|
|
||||||
#include <OgreSceneManager.h>
|
#include <components/resource/resourcesystem.hpp>
|
||||||
#include <OgreParticleSystem.h>
|
#include <components/resource/scenemanager.hpp>
|
||||||
#include <OgreSceneNode.h>
|
|
||||||
#include <OgreTechnique.h>
|
#include <components/sceneutil/controller.hpp>
|
||||||
|
|
||||||
#include "animation.hpp"
|
#include "animation.hpp"
|
||||||
#include "renderconst.hpp"
|
#include "vismask.hpp"
|
||||||
|
#include "util.hpp"
|
||||||
|
|
||||||
namespace MWRender
|
namespace MWRender
|
||||||
{
|
{
|
||||||
|
|
||||||
EffectManager::EffectManager(Ogre::SceneManager *sceneMgr)
|
EffectManager::EffectManager(osg::ref_ptr<osg::Group> parent, Resource::ResourceSystem* resourceSystem)
|
||||||
: mSceneMgr(sceneMgr)
|
: mParentNode(parent)
|
||||||
|
, mResourceSystem(resourceSystem)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void EffectManager::addEffect(const std::string &model, std::string textureOverride, const Ogre::Vector3 &worldPosition, float scale)
|
EffectManager::~EffectManager()
|
||||||
{
|
{
|
||||||
Ogre::SceneNode* sceneNode = mSceneMgr->getRootSceneNode()->createChildSceneNode(worldPosition);
|
clear();
|
||||||
sceneNode->setScale(scale,scale,scale);
|
}
|
||||||
|
|
||||||
NifOgre::ObjectScenePtr scene = NifOgre::Loader::createObjects(sceneNode, model);
|
void EffectManager::addEffect(const std::string &model, const std::string& textureOverride, const osg::Vec3f &worldPosition, float scale)
|
||||||
|
{
|
||||||
|
osg::ref_ptr<osg::Node> node = mResourceSystem->getSceneManager()->createInstance(model);
|
||||||
|
|
||||||
MWRender::Animation::setRenderProperties(scene, RV_Effects,
|
node->setNodeMask(Mask_Effect);
|
||||||
RQG_Main, RQG_Alpha, 0.f, false, NULL);
|
|
||||||
|
|
||||||
for(size_t i = 0;i < scene->mControllers.size();i++)
|
Effect effect;
|
||||||
{
|
effect.mAnimTime.reset(new EffectAnimationTime);
|
||||||
if(scene->mControllers[i].getSource().isNull())
|
|
||||||
scene->mControllers[i].setSource(Ogre::SharedPtr<EffectAnimationTime> (new EffectAnimationTime()));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!textureOverride.empty())
|
SceneUtil::FindMaxControllerLengthVisitor findMaxLengthVisitor;
|
||||||
{
|
node->accept(findMaxLengthVisitor);
|
||||||
std::string correctedTexture = Misc::ResourceHelpers::correctTexturePath(textureOverride);
|
effect.mMaxControllerLength = findMaxLengthVisitor.getMaxLength();
|
||||||
for(size_t i = 0;i < scene->mParticles.size(); ++i)
|
|
||||||
{
|
|
||||||
Ogre::ParticleSystem* partSys = scene->mParticles[i];
|
|
||||||
|
|
||||||
Ogre::MaterialPtr mat = scene->mMaterialControllerMgr.getWritableMaterial(partSys);
|
osg::ref_ptr<osg::PositionAttitudeTransform> trans = new osg::PositionAttitudeTransform;
|
||||||
|
trans->setPosition(worldPosition);
|
||||||
|
trans->setScale(osg::Vec3f(scale, scale, scale));
|
||||||
|
trans->addChild(node);
|
||||||
|
|
||||||
for (int t=0; t<mat->getNumTechniques(); ++t)
|
SceneUtil::AssignControllerSourcesVisitor assignVisitor(effect.mAnimTime);
|
||||||
{
|
node->accept(assignVisitor);
|
||||||
Ogre::Technique* tech = mat->getTechnique(t);
|
|
||||||
for (int p=0; p<tech->getNumPasses(); ++p)
|
|
||||||
{
|
|
||||||
Ogre::Pass* pass = tech->getPass(p);
|
|
||||||
for (int tex=0; tex<pass->getNumTextureUnitStates(); ++tex)
|
|
||||||
{
|
|
||||||
Ogre::TextureUnitState* tus = pass->getTextureUnitState(tex);
|
|
||||||
tus->setTextureName(correctedTexture);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
mEffects.push_back(std::make_pair(sceneNode, scene));
|
overrideTexture(textureOverride, mResourceSystem, node);
|
||||||
|
|
||||||
|
mParentNode->addChild(trans);
|
||||||
|
|
||||||
|
mEffects[trans] = effect;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EffectManager::update(float dt, Ogre::Camera* camera)
|
void EffectManager::update(float dt)
|
||||||
{
|
|
||||||
for (std::vector<std::pair<Ogre::SceneNode*, NifOgre::ObjectScenePtr> >::iterator it = mEffects.begin(); it != mEffects.end(); )
|
|
||||||
{
|
{
|
||||||
NifOgre::ObjectScenePtr objects = it->second;
|
for (EffectMap::iterator it = mEffects.begin(); it != mEffects.end(); )
|
||||||
for(size_t i = 0; i < objects->mControllers.size() ;i++)
|
|
||||||
{
|
{
|
||||||
EffectAnimationTime* value = dynamic_cast<EffectAnimationTime*>(objects->mControllers[i].getSource().get());
|
it->second.mAnimTime->addTime(dt);
|
||||||
if (value)
|
|
||||||
value->addTime(dt);
|
|
||||||
|
|
||||||
objects->mControllers[i].update();
|
|
||||||
}
|
|
||||||
objects->rotateBillboardNodes(camera);
|
|
||||||
|
|
||||||
// Finished playing?
|
if (it->second.mAnimTime->getTime() >= it->second.mMaxControllerLength)
|
||||||
if (objects->mControllers[0].getSource()->getValue() >= objects->mMaxControllerLength)
|
|
||||||
{
|
{
|
||||||
Ogre::SceneNode* node = it->first;
|
mParentNode->removeChild(it->first);
|
||||||
it = mEffects.erase(it);
|
mEffects.erase(it++);
|
||||||
mSceneMgr->destroySceneNode(node);
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
++it;
|
++it;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void EffectManager::clear()
|
void EffectManager::clear()
|
||||||
{
|
{
|
||||||
for (std::vector<std::pair<Ogre::SceneNode*, NifOgre::ObjectScenePtr> >::iterator it = mEffects.begin(); it != mEffects.end(); )
|
for (EffectMap::iterator it = mEffects.begin(); it != mEffects.end(); ++it)
|
||||||
{
|
{
|
||||||
Ogre::SceneNode* node = it->first;
|
mParentNode->removeChild(it->first);
|
||||||
it = mEffects.erase(it);
|
|
||||||
mSceneMgr->destroySceneNode(node);
|
|
||||||
}
|
}
|
||||||
|
mEffects.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,31 @@
|
|||||||
|
#include "util.hpp"
|
||||||
|
|
||||||
|
#include <osg/Node>
|
||||||
|
|
||||||
|
#include <components/resource/resourcesystem.hpp>
|
||||||
|
#include <components/resource/texturemanager.hpp>
|
||||||
|
#include <components/misc/resourcehelpers.hpp>
|
||||||
|
|
||||||
|
namespace MWRender
|
||||||
|
{
|
||||||
|
|
||||||
|
void overrideTexture(const std::string &texture, Resource::ResourceSystem *resourceSystem, osg::ref_ptr<osg::Node> node)
|
||||||
|
{
|
||||||
|
if (texture.empty())
|
||||||
|
return;
|
||||||
|
std::string correctedTexture = Misc::ResourceHelpers::correctTexturePath(texture, resourceSystem->getVFS());
|
||||||
|
// Not sure if wrap settings should be pulled from the overridden texture?
|
||||||
|
osg::ref_ptr<osg::Texture2D> tex = resourceSystem->getTextureManager()->getTexture2D(correctedTexture, osg::Texture2D::CLAMP,
|
||||||
|
osg::Texture2D::CLAMP);
|
||||||
|
osg::ref_ptr<osg::StateSet> stateset;
|
||||||
|
if (node->getStateSet())
|
||||||
|
stateset = static_cast<osg::StateSet*>(node->getStateSet()->clone(osg::CopyOp::SHALLOW_COPY));
|
||||||
|
else
|
||||||
|
stateset = new osg::StateSet;
|
||||||
|
|
||||||
|
stateset->setTextureAttribute(0, tex, osg::StateAttribute::OVERRIDE);
|
||||||
|
|
||||||
|
node->setStateSet(stateset);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
#ifndef OPENMW_MWRENDER_UTIL_H
|
||||||
|
#define OPENMW_MWRENDER_UTIL_H
|
||||||
|
|
||||||
|
#include <osg/ref_ptr>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
namespace osg
|
||||||
|
{
|
||||||
|
class Node;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Resource
|
||||||
|
{
|
||||||
|
class ResourceSystem;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace MWRender
|
||||||
|
{
|
||||||
|
|
||||||
|
void overrideTexture(const std::string& texture, Resource::ResourceSystem* resourceSystem, osg::ref_ptr<osg::Node> node);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue