1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-25 16:56:38 +00:00

Physics working

This commit is contained in:
Jason Hooks 2011-11-17 19:38:52 -05:00
parent b3e1044699
commit 15fcdc8b72
21 changed files with 32 additions and 27 deletions

View file

@ -36,7 +36,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -37,7 +37,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -34,7 +34,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -49,7 +49,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertActorPhysics(ptr); physics.insertActorPhysics(ptr, "meshes\\" + model);
}*/ }*/
} }

View file

@ -43,7 +43,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -39,7 +39,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -47,7 +47,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -37,7 +37,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -37,7 +37,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -58,7 +58,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertActorPhysics(ptr); physics.insertActorPhysics(ptr, "meshes\\" + model);
}*/ }*/
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -37,7 +37,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -33,7 +33,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -38,7 +38,7 @@ namespace MWClass
const std::string &model = ref->base->model; const std::string &model = ref->base->model;
assert (ref->base != NULL); assert (ref->base != NULL);
if(!model.empty()){ if(!model.empty()){
physics.insertObjectPhysics(ptr); physics.insertObjectPhysics(ptr, "meshes\\" + model);
} }
} }

View file

@ -183,15 +183,15 @@ namespace MWWorld
throw std::logic_error ("can't find player"); throw std::logic_error ("can't find player");
} }
void PhysicsSystem::insertObjectPhysics(const MWWorld::Ptr& ptr){ void PhysicsSystem::insertObjectPhysics(const MWWorld::Ptr& ptr, const std::string model){
Ogre::SceneNode* node = ptr.getRefData().getBaseNode(); Ogre::SceneNode* node = ptr.getRefData().getBaseNode();
addObject (node->getName(), node->getName(), node->getOrientation(), addObject (node->getName(), model, node->getOrientation(),
node->getScale().x, node->getPosition()); node->getScale().x, node->getPosition());
} }
void PhysicsSystem::insertActorPhysics(const MWWorld::Ptr& ptr){ void PhysicsSystem::insertActorPhysics(const MWWorld::Ptr& ptr, const std::string model){
Ogre::SceneNode* node = ptr.getRefData().getBaseNode(); Ogre::SceneNode* node = ptr.getRefData().getBaseNode();
addActor (node->getName(), node->getName(), node->getPosition()); addActor (node->getName(), model, node->getPosition());
} }
} }

View file

@ -35,9 +35,9 @@ namespace MWWorld
bool toggleCollisionMode(); bool toggleCollisionMode();
std::pair<std::string, float> getFacedHandle (MWWorld::World& world); std::pair<std::string, float> getFacedHandle (MWWorld::World& world);
void insertObjectPhysics(const MWWorld::Ptr& ptr); void insertObjectPhysics(const MWWorld::Ptr& ptr, std::string model);
void insertActorPhysics(const MWWorld::Ptr& ptr); void insertActorPhysics(const MWWorld::Ptr&, std::string model);
private: private:
OEngine::Render::OgreRenderer &mRender; OEngine::Render::OgreRenderer &mRender;

View file

@ -57,7 +57,6 @@ void insertCellRefList(MWRender::RenderingManager& rendering, MWWorld::Environme
try try
{ {
rendering.addObject(ptr); rendering.addObject(ptr);
class_.insertObject(ptr, physics, environment); class_.insertObject(ptr, physics, environment);
class_.enable (ptr, environment); class_.enable (ptr, environment);
@ -101,14 +100,17 @@ namespace MWWorld
void Scene::loadCell (Ptr::CellStore *cell) void Scene::loadCell (Ptr::CellStore *cell)
{ {
std::cout << "Start load\n";
// register local scripts // register local scripts
mWorld->getLocalScripts().addCell (cell); mWorld->getLocalScripts().addCell (cell);
// This connects the cell data with the rendering scene. // This connects the cell data with the rendering scene.
mActiveCells.insert(cell); mActiveCells.insert(cell);
std::cout << "Before static\n";
mRendering.getObjects().buildStaticGeometry(*cell);
insertCell(*cell, mEnvironment); insertCell(*cell, mEnvironment);
mRendering.getObjects().buildStaticGeometry(*cell);
std::cout << "Done loading cell\n";
} }
@ -228,6 +230,7 @@ namespace MWWorld
void Scene::changeToInteriorCell (const std::string& cellName, const ESM::Position& position) void Scene::changeToInteriorCell (const std::string& cellName, const ESM::Position& position)
{ {
std::cout << "Changing to interior\n";
// remove active // remove active
CellStoreCollection::iterator active = mActiveCells.begin(); CellStoreCollection::iterator active = mActiveCells.begin();
@ -309,7 +312,9 @@ void Scene::insertCell(ESMS::CellStore<MWWorld::RefData> &cell,
MWWorld::Environment& environment) MWWorld::Environment& environment)
{ {
// Loop through all references in the cell // Loop through all references in the cell
std::cout << "Reflist1\n";
insertCellRefList(mRendering, environment, cell.activators, cell, *mPhysics); insertCellRefList(mRendering, environment, cell.activators, cell, *mPhysics);
std::cout << "Reflist2\n";
insertCellRefList(mRendering, environment, cell.potions, cell, *mPhysics); insertCellRefList(mRendering, environment, cell.potions, cell, *mPhysics);
insertCellRefList(mRendering, environment, cell.appas, cell, *mPhysics); insertCellRefList(mRendering, environment, cell.appas, cell, *mPhysics);
insertCellRefList(mRendering, environment, cell.armors, cell, *mPhysics); insertCellRefList(mRendering, environment, cell.armors, cell, *mPhysics);