mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 18:35:20 +00:00
Merge remote-tracking branch 'jordan-ayers/bugfix/2400'
This commit is contained in:
commit
a77fbdc965
@ -2832,6 +2832,10 @@ namespace MWWorld
|
|||||||
|
|
||||||
MWWorld::Ptr World::getClosestMarker( const MWWorld::Ptr &ptr, const std::string &id )
|
MWWorld::Ptr World::getClosestMarker( const MWWorld::Ptr &ptr, const std::string &id )
|
||||||
{
|
{
|
||||||
|
if ( ptr.getCell()->isExterior() ) {
|
||||||
|
return getClosestMarkerFromExteriorPosition(mPlayer->getLastKnownExteriorPosition(), id);
|
||||||
|
}
|
||||||
|
|
||||||
// Search for a 'nearest' marker, counting each cell between the starting
|
// Search for a 'nearest' marker, counting each cell between the starting
|
||||||
// cell and the exterior as a distance of 1. If an exterior is found, jump
|
// cell and the exterior as a distance of 1. If an exterior is found, jump
|
||||||
// to the nearest exterior marker, without further interior searching.
|
// to the nearest exterior marker, without further interior searching.
|
||||||
@ -2868,25 +2872,7 @@ namespace MWWorld
|
|||||||
if (ref.mRef.getDestCell().empty())
|
if (ref.mRef.getDestCell().empty())
|
||||||
{
|
{
|
||||||
Ogre::Vector3 worldPos = Ogre::Vector3(ref.mRef.getDoorDest().pos);
|
Ogre::Vector3 worldPos = Ogre::Vector3(ref.mRef.getDoorDest().pos);
|
||||||
float closestDistance = FLT_MAX;
|
return getClosestMarkerFromExteriorPosition(worldPos, id);
|
||||||
|
|
||||||
MWWorld::Ptr closestMarker;
|
|
||||||
std::vector<MWWorld::Ptr> markers;
|
|
||||||
mCells.getExteriorPtrs(id, markers);
|
|
||||||
for (std::vector<MWWorld::Ptr>::iterator it2 = markers.begin(); it2 != markers.end(); ++it2)
|
|
||||||
{
|
|
||||||
ESM::Position pos = it2->getRefData().getPosition();
|
|
||||||
Ogre::Vector3 markerPos = Ogre::Vector3(pos.pos);
|
|
||||||
float distance = worldPos.squaredDistance(markerPos);
|
|
||||||
if (distance < closestDistance)
|
|
||||||
{
|
|
||||||
closestDistance = distance;
|
|
||||||
closestMarker = *it2;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return closestMarker;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2901,6 +2887,29 @@ namespace MWWorld
|
|||||||
return MWWorld::Ptr();
|
return MWWorld::Ptr();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MWWorld::Ptr World::getClosestMarkerFromExteriorPosition( const Ogre::Vector3 worldPos, const std::string &id ) {
|
||||||
|
MWWorld::Ptr closestMarker;
|
||||||
|
float closestDistance = FLT_MAX;
|
||||||
|
|
||||||
|
std::vector<MWWorld::Ptr> markers;
|
||||||
|
mCells.getExteriorPtrs(id, markers);
|
||||||
|
for (std::vector<MWWorld::Ptr>::iterator it2 = markers.begin(); it2 != markers.end(); ++it2)
|
||||||
|
{
|
||||||
|
ESM::Position pos = it2->getRefData().getPosition();
|
||||||
|
Ogre::Vector3 markerPos = Ogre::Vector3(pos.pos);
|
||||||
|
float distance = worldPos.squaredDistance(markerPos);
|
||||||
|
if (distance < closestDistance)
|
||||||
|
{
|
||||||
|
closestDistance = distance;
|
||||||
|
closestMarker = *it2;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return closestMarker;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void World::teleportToClosestMarker (const MWWorld::Ptr& ptr,
|
void World::teleportToClosestMarker (const MWWorld::Ptr& ptr,
|
||||||
const std::string& id)
|
const std::string& id)
|
||||||
{
|
{
|
||||||
@ -3066,6 +3075,11 @@ namespace MWWorld
|
|||||||
void World::confiscateStolenItems(const Ptr &ptr)
|
void World::confiscateStolenItems(const Ptr &ptr)
|
||||||
{
|
{
|
||||||
MWWorld::Ptr prisonMarker = getClosestMarker( ptr, "prisonmarker" );
|
MWWorld::Ptr prisonMarker = getClosestMarker( ptr, "prisonmarker" );
|
||||||
|
if ( prisonMarker.isEmpty() )
|
||||||
|
{
|
||||||
|
std::cerr << "Failed to confiscate items: no closest prison marker found." << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
std::string prisonName = prisonMarker.mRef->mRef.getDestCell();
|
std::string prisonName = prisonMarker.mRef->mRef.getDestCell();
|
||||||
if ( prisonName.empty() )
|
if ( prisonName.empty() )
|
||||||
{
|
{
|
||||||
|
@ -151,6 +151,7 @@ namespace MWWorld
|
|||||||
float feetToGameUnits(float feet);
|
float feetToGameUnits(float feet);
|
||||||
|
|
||||||
MWWorld::Ptr getClosestMarker( const MWWorld::Ptr &ptr, const std::string &id );
|
MWWorld::Ptr getClosestMarker( const MWWorld::Ptr &ptr, const std::string &id );
|
||||||
|
MWWorld::Ptr getClosestMarkerFromExteriorPosition( const Ogre::Vector3 worldPos, const std::string &id );
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user