2012-03-30 14:18:58 +00:00
|
|
|
|
|
|
|
#include "actors.hpp"
|
|
|
|
|
2012-03-30 15:01:55 +00:00
|
|
|
#include <typeinfo>
|
|
|
|
|
2012-07-03 13:32:38 +00:00
|
|
|
#include <OgreVector3.h>
|
|
|
|
|
2012-03-30 15:01:55 +00:00
|
|
|
#include <components/esm/loadnpc.hpp>
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
#include "../mwworld/class.hpp"
|
2012-03-31 15:26:15 +00:00
|
|
|
#include "../mwworld/inventorystore.hpp"
|
2012-03-30 14:18:58 +00:00
|
|
|
|
2012-05-17 11:15:31 +00:00
|
|
|
#include "creaturestats.hpp"
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
namespace MWMechanics
|
|
|
|
{
|
2012-03-30 15:01:55 +00:00
|
|
|
void Actors::updateActor (const MWWorld::Ptr& ptr, float duration)
|
|
|
|
{
|
2012-05-17 11:21:49 +00:00
|
|
|
// magic effects
|
|
|
|
adjustMagicEffects (ptr);
|
2012-07-17 13:49:37 +00:00
|
|
|
calculateCreatureStatModifiers (ptr);
|
2012-07-17 14:44:55 +00:00
|
|
|
calculateDynamicStats (ptr);
|
2012-03-30 15:01:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Actors::updateNpc (const MWWorld::Ptr& ptr, float duration, bool paused)
|
|
|
|
{
|
2012-04-08 11:01:03 +00:00
|
|
|
if (!paused && ptr.getRefData().getHandle()!="player")
|
2012-03-31 15:26:15 +00:00
|
|
|
MWWorld::Class::get (ptr).getInventoryStore (ptr).autoEquip (
|
2012-04-23 13:27:03 +00:00
|
|
|
MWWorld::Class::get (ptr).getNpcStats (ptr));
|
2012-03-30 15:01:55 +00:00
|
|
|
}
|
|
|
|
|
2012-05-17 11:21:49 +00:00
|
|
|
void Actors::adjustMagicEffects (const MWWorld::Ptr& creature)
|
|
|
|
{
|
|
|
|
CreatureStats& creatureStats = MWWorld::Class::get (creature).getCreatureStats (creature);
|
|
|
|
|
|
|
|
MagicEffects now = creatureStats.mSpells.getMagicEffects();
|
|
|
|
|
2012-05-18 13:48:55 +00:00
|
|
|
if (creature.getTypeName()==typeid (ESM::NPC).name())
|
|
|
|
{
|
|
|
|
MWWorld::InventoryStore& store = MWWorld::Class::get (creature).getInventoryStore (creature);
|
|
|
|
now += store.getMagicEffects();
|
|
|
|
}
|
|
|
|
|
2012-05-19 13:01:07 +00:00
|
|
|
now += creatureStats.mActiveSpells.getMagicEffects();
|
2012-05-17 11:21:49 +00:00
|
|
|
|
|
|
|
MagicEffects diff = MagicEffects::diff (creatureStats.mMagicEffects, now);
|
|
|
|
|
|
|
|
creatureStats.mMagicEffects = now;
|
|
|
|
|
|
|
|
// TODO apply diff to other stats
|
|
|
|
}
|
|
|
|
|
2012-07-17 10:18:43 +00:00
|
|
|
void Actors::calculateDynamicStats (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
|
|
|
CreatureStats& creatureStats = MWWorld::Class::get (ptr).getCreatureStats (ptr);
|
|
|
|
|
|
|
|
int strength = creatureStats.mAttributes[0].getBase();
|
|
|
|
int intelligence = creatureStats.mAttributes[1].getBase();
|
|
|
|
int willpower = creatureStats.mAttributes[2].getBase();
|
|
|
|
int agility = creatureStats.mAttributes[3].getBase();
|
|
|
|
int endurance = creatureStats.mAttributes[5].getBase();
|
|
|
|
|
|
|
|
double magickaFactor = creatureStats.mMagicEffects.get (EffectKey (84)).mMagnitude*0.1 + 0.5;
|
|
|
|
|
|
|
|
creatureStats.mDynamic[0].setBase (static_cast<int> (0.5 * (strength + endurance)));
|
|
|
|
creatureStats.mDynamic[1].setBase (static_cast<int> (intelligence +
|
|
|
|
magickaFactor * intelligence));
|
|
|
|
creatureStats.mDynamic[2].setBase (strength+willpower+agility+endurance);
|
|
|
|
}
|
|
|
|
|
2012-07-17 13:49:37 +00:00
|
|
|
void Actors::calculateCreatureStatModifiers (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
|
|
|
CreatureStats& creatureStats = MWWorld::Class::get (ptr).getCreatureStats (ptr);
|
|
|
|
|
|
|
|
// attributes
|
|
|
|
for (int i=0; i<5; ++i)
|
|
|
|
{
|
|
|
|
int modifier = creatureStats.mMagicEffects.get (EffectKey (79, i)).mMagnitude
|
|
|
|
- creatureStats.mMagicEffects.get (EffectKey (17, i)).mMagnitude;
|
|
|
|
|
2012-07-17 14:44:55 +00:00
|
|
|
creatureStats.mAttributes[i].setModifier (modifier);
|
2012-07-17 13:49:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// dynamic stats
|
|
|
|
for (int i=0; i<3; ++i)
|
|
|
|
{
|
|
|
|
int modifier = creatureStats.mMagicEffects.get (EffectKey (80+i)).mMagnitude
|
|
|
|
- creatureStats.mMagicEffects.get (EffectKey (18+i)).mMagnitude;
|
|
|
|
|
2012-07-17 14:44:55 +00:00
|
|
|
creatureStats.mDynamic[i].setModifier (modifier);
|
2012-07-17 13:49:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-23 13:27:03 +00:00
|
|
|
Actors::Actors() : mDuration (0) {}
|
2012-03-30 14:18:58 +00:00
|
|
|
|
|
|
|
void Actors::addActor (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
|
|
|
mActors.insert (ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Actors::removeActor (const MWWorld::Ptr& ptr)
|
|
|
|
{
|
2012-05-24 11:21:52 +00:00
|
|
|
std::set<MWWorld::Ptr>::iterator iter = mActors.find (ptr);
|
|
|
|
|
|
|
|
if (iter!=mActors.end())
|
|
|
|
mActors.erase (iter);
|
2012-03-30 14:18:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void Actors::dropActors (const MWWorld::Ptr::CellStore *cellStore)
|
|
|
|
{
|
|
|
|
std::set<MWWorld::Ptr>::iterator iter = mActors.begin();
|
|
|
|
|
|
|
|
while (iter!=mActors.end())
|
|
|
|
if (iter->getCell()==cellStore)
|
|
|
|
{
|
|
|
|
mActors.erase (iter++);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
++iter;
|
|
|
|
}
|
|
|
|
|
2012-03-30 15:01:55 +00:00
|
|
|
void Actors::update (std::vector<std::pair<std::string, Ogre::Vector3> >& movement, float duration,
|
|
|
|
bool paused)
|
2012-03-30 14:18:58 +00:00
|
|
|
{
|
2012-03-30 15:01:55 +00:00
|
|
|
mDuration += duration;
|
|
|
|
|
|
|
|
if (mDuration>=0.25)
|
|
|
|
{
|
2012-07-17 16:37:20 +00:00
|
|
|
float totalDuration = mDuration;
|
|
|
|
mDuration = 0;
|
|
|
|
|
2012-03-30 15:01:55 +00:00
|
|
|
for (std::set<MWWorld::Ptr>::iterator iter (mActors.begin()); iter!=mActors.end(); ++iter)
|
|
|
|
{
|
2012-07-17 16:37:20 +00:00
|
|
|
updateActor (*iter, totalDuration);
|
2012-03-30 15:01:55 +00:00
|
|
|
|
|
|
|
if (iter->getTypeName()==typeid (ESM::NPC).name())
|
2012-07-17 16:37:20 +00:00
|
|
|
updateNpc (*iter, totalDuration, paused);
|
2012-03-30 15:01:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-30 14:18:58 +00:00
|
|
|
for (std::set<MWWorld::Ptr>::iterator iter (mActors.begin()); iter!=mActors.end();
|
|
|
|
++iter)
|
|
|
|
{
|
|
|
|
Ogre::Vector3 vector = MWWorld::Class::get (*iter).getMovementVector (*iter);
|
|
|
|
|
|
|
|
if (vector!=Ogre::Vector3::ZERO)
|
|
|
|
movement.push_back (std::make_pair (iter->getRefData().getHandle(), vector));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|