|
|
@ -12,14 +12,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
namespace MWMechanics
|
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
{
|
|
|
|
void ActiveSpells::update() const
|
|
|
|
void ActiveSpells::update(float duration) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
bool rebuild = false;
|
|
|
|
bool rebuild = false;
|
|
|
|
|
|
|
|
|
|
|
|
MWWorld::TimeStamp now = MWBase::Environment::get().getWorld()->getTimeStamp();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Erase no longer active spells and effects
|
|
|
|
// Erase no longer active spells and effects
|
|
|
|
if (mLastUpdate!=now)
|
|
|
|
if (duration > 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
TContainer::iterator iter (mSpells.begin());
|
|
|
|
TContainer::iterator iter (mSpells.begin());
|
|
|
|
while (iter!=mSpells.end())
|
|
|
|
while (iter!=mSpells.end())
|
|
|
@ -34,21 +32,20 @@ namespace MWMechanics
|
|
|
|
std::vector<ActiveEffect>& effects = iter->second.mEffects;
|
|
|
|
std::vector<ActiveEffect>& effects = iter->second.mEffects;
|
|
|
|
for (std::vector<ActiveEffect>::iterator effectIt = effects.begin(); effectIt != effects.end();)
|
|
|
|
for (std::vector<ActiveEffect>::iterator effectIt = effects.begin(); effectIt != effects.end();)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::TimeStamp start = iter->second.mTimeStamp;
|
|
|
|
if (effectIt->mTimeLeft <= 0)
|
|
|
|
MWWorld::TimeStamp end = start + static_cast<double>(effectIt->mDuration)*MWBase::Environment::get().getWorld()->getTimeScaleFactor()/(60*60);
|
|
|
|
|
|
|
|
if (end <= now)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
effectIt = effects.erase(effectIt);
|
|
|
|
effectIt = effects.erase(effectIt);
|
|
|
|
rebuild = true;
|
|
|
|
rebuild = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
effectIt->mTimeLeft -= duration;
|
|
|
|
++effectIt;
|
|
|
|
++effectIt;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
++iter;
|
|
|
|
++iter;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mLastUpdate = now;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (mSpellsChanged)
|
|
|
|
if (mSpellsChanged)
|
|
|
@ -63,24 +60,15 @@ namespace MWMechanics
|
|
|
|
|
|
|
|
|
|
|
|
void ActiveSpells::rebuildEffects() const
|
|
|
|
void ActiveSpells::rebuildEffects() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::TimeStamp now = MWBase::Environment::get().getWorld()->getTimeStamp();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mEffects = MagicEffects();
|
|
|
|
mEffects = MagicEffects();
|
|
|
|
|
|
|
|
|
|
|
|
for (TIterator iter (begin()); iter!=end(); ++iter)
|
|
|
|
for (TIterator iter (begin()); iter!=end(); ++iter)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const MWWorld::TimeStamp& start = iter->second.mTimeStamp;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const std::vector<ActiveEffect>& effects = iter->second.mEffects;
|
|
|
|
const std::vector<ActiveEffect>& effects = iter->second.mEffects;
|
|
|
|
|
|
|
|
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator effectIt = effects.begin(); effectIt != effects.end(); ++effectIt)
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator effectIt = effects.begin(); effectIt != effects.end(); ++effectIt)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
double duration = effectIt->mDuration;
|
|
|
|
if (effectIt->mTimeLeft > 0)
|
|
|
|
MWWorld::TimeStamp end = start;
|
|
|
|
|
|
|
|
end += duration *
|
|
|
|
|
|
|
|
MWBase::Environment::get().getWorld()->getTimeScaleFactor()/(60*60);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (end>now)
|
|
|
|
|
|
|
|
mEffects.add(MWMechanics::EffectKey(effectIt->mEffectId, effectIt->mArg), MWMechanics::EffectParam(effectIt->mMagnitude));
|
|
|
|
mEffects.add(MWMechanics::EffectKey(effectIt->mEffectId, effectIt->mArg), MWMechanics::EffectParam(effectIt->mMagnitude));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -88,12 +76,11 @@ namespace MWMechanics
|
|
|
|
|
|
|
|
|
|
|
|
ActiveSpells::ActiveSpells()
|
|
|
|
ActiveSpells::ActiveSpells()
|
|
|
|
: mSpellsChanged (false)
|
|
|
|
: mSpellsChanged (false)
|
|
|
|
, mLastUpdate (MWBase::Environment::get().getWorld()->getTimeStamp())
|
|
|
|
|
|
|
|
{}
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
const MagicEffects& ActiveSpells::getMagicEffects() const
|
|
|
|
const MagicEffects& ActiveSpells::getMagicEffects() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
update();
|
|
|
|
update(0.f);
|
|
|
|
return mEffects;
|
|
|
|
return mEffects;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -116,19 +103,14 @@ namespace MWMechanics
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator iter (effects.begin());
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator iter (effects.begin());
|
|
|
|
iter!=effects.end(); ++iter)
|
|
|
|
iter!=effects.end(); ++iter)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (iter->mDuration > duration)
|
|
|
|
if (iter->mTimeLeft > duration)
|
|
|
|
duration = iter->mDuration;
|
|
|
|
duration = iter->mTimeLeft;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
double scaledDuration = duration *
|
|
|
|
if (duration < 0)
|
|
|
|
MWBase::Environment::get().getWorld()->getTimeScaleFactor()/(60*60);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
double usedUp = MWBase::Environment::get().getWorld()->getTimeStamp() - iterator->second.mTimeStamp;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (usedUp>=scaledDuration)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
|
|
return scaledDuration-usedUp;
|
|
|
|
return duration;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool ActiveSpells::isSpellActive(const std::string& id) const
|
|
|
|
bool ActiveSpells::isSpellActive(const std::string& id) const
|
|
|
@ -152,7 +134,6 @@ namespace MWMechanics
|
|
|
|
TContainer::iterator it(mSpells.find(id));
|
|
|
|
TContainer::iterator it(mSpells.find(id));
|
|
|
|
|
|
|
|
|
|
|
|
ActiveSpellParams params;
|
|
|
|
ActiveSpellParams params;
|
|
|
|
params.mTimeStamp = MWBase::Environment::get().getWorld()->getTimeStamp();
|
|
|
|
|
|
|
|
params.mEffects = effects;
|
|
|
|
params.mEffects = effects;
|
|
|
|
params.mDisplayName = displayName;
|
|
|
|
params.mDisplayName = displayName;
|
|
|
|
params.mCasterActorId = casterActorId;
|
|
|
|
params.mCasterActorId = casterActorId;
|
|
|
@ -211,19 +192,15 @@ namespace MWMechanics
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for (TContainer::const_iterator it = begin(); it != end(); ++it)
|
|
|
|
for (TContainer::const_iterator it = begin(); it != end(); ++it)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
float timeScale = MWBase::Environment::get().getWorld()->getTimeScaleFactor();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator effectIt = it->second.mEffects.begin();
|
|
|
|
for (std::vector<ActiveEffect>::const_iterator effectIt = it->second.mEffects.begin();
|
|
|
|
effectIt != it->second.mEffects.end(); ++effectIt)
|
|
|
|
effectIt != it->second.mEffects.end(); ++effectIt)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::string name = it->second.mDisplayName;
|
|
|
|
std::string name = it->second.mDisplayName;
|
|
|
|
|
|
|
|
|
|
|
|
float remainingTime = effectIt->mDuration +
|
|
|
|
|
|
|
|
static_cast<float>(it->second.mTimeStamp - MWBase::Environment::get().getWorld()->getTimeStamp())*3600/timeScale;
|
|
|
|
|
|
|
|
float magnitude = effectIt->mMagnitude;
|
|
|
|
float magnitude = effectIt->mMagnitude;
|
|
|
|
|
|
|
|
|
|
|
|
if (magnitude)
|
|
|
|
if (magnitude)
|
|
|
|
visitor.visit(MWMechanics::EffectKey(effectIt->mEffectId, effectIt->mArg), name, it->first, it->second.mCasterActorId, magnitude, remainingTime, effectIt->mDuration);
|
|
|
|
visitor.visit(MWMechanics::EffectKey(effectIt->mEffectId, effectIt->mArg), name, it->first, it->second.mCasterActorId, magnitude, effectIt->mTimeLeft, effectIt->mDuration);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -316,7 +293,6 @@ namespace MWMechanics
|
|
|
|
params.mEffects = it->second.mEffects;
|
|
|
|
params.mEffects = it->second.mEffects;
|
|
|
|
params.mCasterActorId = it->second.mCasterActorId;
|
|
|
|
params.mCasterActorId = it->second.mCasterActorId;
|
|
|
|
params.mDisplayName = it->second.mDisplayName;
|
|
|
|
params.mDisplayName = it->second.mDisplayName;
|
|
|
|
params.mTimeStamp = it->second.mTimeStamp.toEsm();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
state.mSpells.insert (std::make_pair(it->first, params));
|
|
|
|
state.mSpells.insert (std::make_pair(it->first, params));
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -331,7 +307,6 @@ namespace MWMechanics
|
|
|
|
params.mEffects = it->second.mEffects;
|
|
|
|
params.mEffects = it->second.mEffects;
|
|
|
|
params.mCasterActorId = it->second.mCasterActorId;
|
|
|
|
params.mCasterActorId = it->second.mCasterActorId;
|
|
|
|
params.mDisplayName = it->second.mDisplayName;
|
|
|
|
params.mDisplayName = it->second.mDisplayName;
|
|
|
|
params.mTimeStamp = MWWorld::TimeStamp(it->second.mTimeStamp);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mSpells.insert (std::make_pair(it->first, params));
|
|
|
|
mSpells.insert (std::make_pair(it->first, params));
|
|
|
|
mSpellsChanged = true;
|
|
|
|
mSpellsChanged = true;
|
|
|
|