temporarily removed statics from raycast test (makes object activation easier by removing inactive obstacles, that overlap the AABB of the object)

actorid
Marc Zinnschlag 15 years ago
parent 9e8251e6b4
commit bdb5749b57

@ -9,6 +9,10 @@
#include "OgreCamera.h" #include "OgreCamera.h"
#include "OgreTextureManager.h" #include "OgreTextureManager.h"
#include "../mwworld/world.hpp" // these includes can be removed once the static-hack is gone
#include "../mwworld/ptr.hpp"
#include <components/esm/loadstat.hpp>
using namespace MWRender; using namespace MWRender;
using namespace Ogre; using namespace Ogre;
@ -36,7 +40,7 @@ MWScene::MWScene(OEngine::Render::OgreRenderer &_rend)
mRaySceneQuery = rend.getScene()->createRayQuery(Ray()); mRaySceneQuery = rend.getScene()->createRayQuery(Ray());
} }
std::pair<std::string, float> MWScene::getFacedHandle() std::pair<std::string, float> MWScene::getFacedHandle (MWWorld::World& world)
{ {
std::string handle = ""; std::string handle = "";
float distance = -1; float distance = -1;
@ -57,10 +61,14 @@ std::pair<std::string, float> MWScene::getFacedHandle()
{ {
// there seem to be omnipresent objects like the caelum sky dom, // there seem to be omnipresent objects like the caelum sky dom,
// the distance of these objects is always 0 so this if excludes these // the distance of these objects is always 0 so this if excludes these
// TODO: Check if the object can be focused (ignore walls etc..
// in this state of openmw not possible)
if ( itr->movable && itr->distance >= 0.1) if ( itr->movable && itr->distance >= 0.1)
{ {
// horrible hack to exclude statics. this must be removed as soon as a replacement for the
// AABB raycasting is implemented (we should not ignore statics)
MWWorld::Ptr ptr = world.getPtrViaHandle (itr->movable->getParentSceneNode()->getName());
if (ptr.getType()==typeid (ESM::Static))
break;
if ( nearest == result.end() ) //if no object is set if ( nearest == result.end() ) //if no object is set
{ {
nearest = itr; nearest = itr;
@ -80,4 +88,3 @@ std::pair<std::string, float> MWScene::getFacedHandle()
return std::pair<std::string, float>(handle, distance); return std::pair<std::string, float>(handle, distance);
} }

@ -13,6 +13,11 @@ namespace Ogre
class RaySceneQuery; class RaySceneQuery;
} }
namespace MWWorld
{
class World;
}
namespace MWRender namespace MWRender
{ {
/** Class responsible for Morrowind-specific interfaces to OGRE. /** Class responsible for Morrowind-specific interfaces to OGRE.
@ -43,7 +48,7 @@ namespace MWRender
//pair<name, distance> //pair<name, distance>
//name is empty and distance = -1 if there is no object which //name is empty and distance = -1 if there is no object which
//can be faced //can be faced
std::pair<std::string, float> getFacedHandle(); std::pair<std::string, float> getFacedHandle (MWWorld::World& world);
}; };
} }

@ -648,7 +648,7 @@ namespace MWWorld
std::string World::getFacedHandle() std::string World::getFacedHandle()
{ {
std::pair<std::string, float> result = mScene.getFacedHandle(); std::pair<std::string, float> result = mScene.getFacedHandle (*this);
if (result.first.empty() || if (result.first.empty() ||
result.second>getStore().gameSettings.find ("iMaxActivateDist")->i) result.second>getStore().gameSettings.find ("iMaxActivateDist")->i)

Loading…
Cancel
Save