forked from teamnwah/openmw-tes3coop
PlaceAt count argument should spawn independent references (Fixes #2283)
This commit is contained in:
parent
7542fb5cd9
commit
7d76f1a113
1 changed files with 33 additions and 34 deletions
|
@ -518,42 +518,41 @@ namespace MWScript
|
||||||
if (count<0)
|
if (count<0)
|
||||||
throw std::runtime_error ("count must be non-negative");
|
throw std::runtime_error ("count must be non-negative");
|
||||||
|
|
||||||
// no-op
|
for (int i=0; i<count; ++i)
|
||||||
if (count == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
ESM::Position ipos = actor.getRefData().getPosition();
|
|
||||||
Ogre::Vector3 pos(ipos.pos[0],ipos.pos[1],ipos.pos[2]);
|
|
||||||
Ogre::Quaternion rot(Ogre::Radian(-ipos.rot[2]), Ogre::Vector3::UNIT_Z);
|
|
||||||
if(direction == 0) pos = pos + distance*rot.yAxis();
|
|
||||||
else if(direction == 1) pos = pos - distance*rot.yAxis();
|
|
||||||
else if(direction == 2) pos = pos - distance*rot.xAxis();
|
|
||||||
else if(direction == 3) pos = pos + distance*rot.xAxis();
|
|
||||||
else throw std::runtime_error ("direction must be 0,1,2 or 3");
|
|
||||||
|
|
||||||
ipos.pos[0] = pos.x;
|
|
||||||
ipos.pos[1] = pos.y;
|
|
||||||
ipos.pos[2] = pos.z;
|
|
||||||
|
|
||||||
if (actor.getClass().isActor())
|
|
||||||
{
|
{
|
||||||
// TODO: should this depend on the 'direction' parameter?
|
ESM::Position ipos = actor.getRefData().getPosition();
|
||||||
ipos.rot[0] = 0;
|
Ogre::Vector3 pos(ipos.pos[0],ipos.pos[1],ipos.pos[2]);
|
||||||
ipos.rot[1] = 0;
|
Ogre::Quaternion rot(Ogre::Radian(-ipos.rot[2]), Ogre::Vector3::UNIT_Z);
|
||||||
ipos.rot[2] = 0;
|
if(direction == 0) pos = pos + distance*rot.yAxis();
|
||||||
}
|
else if(direction == 1) pos = pos - distance*rot.yAxis();
|
||||||
else
|
else if(direction == 2) pos = pos - distance*rot.xAxis();
|
||||||
{
|
else if(direction == 3) pos = pos + distance*rot.xAxis();
|
||||||
ipos.rot[0] = actor.getRefData().getPosition().rot[0];
|
else throw std::runtime_error ("direction must be 0,1,2 or 3");
|
||||||
ipos.rot[1] = actor.getRefData().getPosition().rot[1];
|
|
||||||
ipos.rot[2] = actor.getRefData().getPosition().rot[2];
|
|
||||||
}
|
|
||||||
// create item
|
|
||||||
MWWorld::CellStore* store = actor.getCell();
|
|
||||||
MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(), itemID, count);
|
|
||||||
ref.getPtr().getCellRef().setPosition(ipos);
|
|
||||||
|
|
||||||
MWBase::Environment::get().getWorld()->safePlaceObject(ref.getPtr(),store,ipos);
|
ipos.pos[0] = pos.x;
|
||||||
|
ipos.pos[1] = pos.y;
|
||||||
|
ipos.pos[2] = pos.z;
|
||||||
|
|
||||||
|
if (actor.getClass().isActor())
|
||||||
|
{
|
||||||
|
// TODO: should this depend on the 'direction' parameter?
|
||||||
|
ipos.rot[0] = 0;
|
||||||
|
ipos.rot[1] = 0;
|
||||||
|
ipos.rot[2] = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ipos.rot[0] = actor.getRefData().getPosition().rot[0];
|
||||||
|
ipos.rot[1] = actor.getRefData().getPosition().rot[1];
|
||||||
|
ipos.rot[2] = actor.getRefData().getPosition().rot[2];
|
||||||
|
}
|
||||||
|
// create item
|
||||||
|
MWWorld::CellStore* store = actor.getCell();
|
||||||
|
MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(), itemID, 1);
|
||||||
|
ref.getPtr().getCellRef().setPosition(ipos);
|
||||||
|
|
||||||
|
MWBase::Environment::get().getWorld()->safePlaceObject(ref.getPtr(),store,ipos);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue