mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 08:56:39 +00:00
fix to the "drop object on ground" feature. still crashes for gold.
This commit is contained in:
parent
6d34e61dbd
commit
f73d3ad33f
2 changed files with 96 additions and 19 deletions
|
@ -328,41 +328,96 @@ namespace MWWorld
|
||||||
|
|
||||||
void Scene::insertObject(MWWorld::Ptr ptr, Ptr::CellStore* cell)
|
void Scene::insertObject(MWWorld::Ptr ptr, Ptr::CellStore* cell)
|
||||||
{
|
{
|
||||||
ptr.mCell = cell;
|
|
||||||
|
|
||||||
mRendering.addObject(ptr);
|
|
||||||
MWWorld::Class::get(ptr).insertObject(ptr, *mPhysics);
|
|
||||||
MWWorld::Class::get(ptr).enable(ptr);
|
|
||||||
|
|
||||||
std::string type = ptr.getTypeName();
|
std::string type = ptr.getTypeName();
|
||||||
|
|
||||||
|
MWWorld::Ptr newPtr;
|
||||||
|
|
||||||
// insert into the correct CellRefList
|
// insert into the correct CellRefList
|
||||||
if (type == typeid(ESM::Potion).name())
|
if (type == typeid(ESM::Potion).name())
|
||||||
cell->potions.list.push_back( *ptr.get<ESM::Potion>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Potion, MWWorld::RefData>* ref = ptr.get<ESM::Potion>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->potions.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Apparatus).name())
|
else if (type == typeid(ESM::Apparatus).name())
|
||||||
cell->appas.list.push_back( *ptr.get<ESM::Apparatus>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Apparatus, MWWorld::RefData>* ref = ptr.get<ESM::Apparatus>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->appas.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Armor).name())
|
else if (type == typeid(ESM::Armor).name())
|
||||||
cell->armors.list.push_back( *ptr.get<ESM::Armor>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Armor, MWWorld::RefData>* ref = ptr.get<ESM::Armor>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->armors.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Book).name())
|
else if (type == typeid(ESM::Book).name())
|
||||||
cell->books.list.push_back( *ptr.get<ESM::Book>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Book, MWWorld::RefData>* ref = ptr.get<ESM::Book>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->books.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Clothing).name())
|
else if (type == typeid(ESM::Clothing).name())
|
||||||
cell->clothes.list.push_back( *ptr.get<ESM::Clothing>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Clothing, MWWorld::RefData>* ref = ptr.get<ESM::Clothing>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->clothes.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Ingredient).name())
|
else if (type == typeid(ESM::Ingredient).name())
|
||||||
cell->ingreds.list.push_back( *ptr.get<ESM::Ingredient>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Ingredient, MWWorld::RefData>* ref = ptr.get<ESM::Ingredient>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->ingreds.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Light).name())
|
else if (type == typeid(ESM::Light).name())
|
||||||
cell->lights.list.push_back( *ptr.get<ESM::Light>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Light, MWWorld::RefData>* ref = ptr.get<ESM::Light>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->lights.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Tool).name())
|
else if (type == typeid(ESM::Tool).name())
|
||||||
cell->lockpicks.list.push_back( *ptr.get<ESM::Tool>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Tool, MWWorld::RefData>* ref = ptr.get<ESM::Tool>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->lockpicks.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Repair).name())
|
else if (type == typeid(ESM::Repair).name())
|
||||||
cell->repairs.list.push_back( *ptr.get<ESM::Repair>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Repair, MWWorld::RefData>* ref = ptr.get<ESM::Repair>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->repairs.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Probe).name())
|
else if (type == typeid(ESM::Probe).name())
|
||||||
cell->probes.list.push_back( *ptr.get<ESM::Probe>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData>* ref = ptr.get<ESM::Probe>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->probes.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Weapon).name())
|
else if (type == typeid(ESM::Weapon).name())
|
||||||
cell->weapons.list.push_back( *ptr.get<ESM::Weapon>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData>* ref = ptr.get<ESM::Weapon>();
|
||||||
|
newPtr = MWWorld::Ptr(ref, cell);
|
||||||
|
cell->weapons.list.push_back( *ref );
|
||||||
|
}
|
||||||
else if (type == typeid(ESM::Miscellaneous).name())
|
else if (type == typeid(ESM::Miscellaneous).name())
|
||||||
cell->miscItems.list.push_back( *ptr.get<ESM::Miscellaneous>() );
|
{
|
||||||
|
ESMS::LiveCellRef<ESM::Miscellaneous, MWWorld::RefData>* ref = ptr.get<ESM::Miscellaneous>();
|
||||||
|
cell->miscItems.list.push_back( *ref );
|
||||||
|
newPtr = MWWorld::Ptr(&cell->miscItems.list.back(), cell);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
throw std::runtime_error("Trying to insert object of unhandled type");
|
throw std::runtime_error("Trying to insert object of unhandled type");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
newPtr.getRefData().setCount(ptr.getRefData().getCount());
|
||||||
|
ptr.getRefData().setCount(0);
|
||||||
|
newPtr.getRefData().enable();
|
||||||
|
|
||||||
|
mRendering.addObject(newPtr);
|
||||||
|
MWWorld::Class::get(newPtr).insertObject(newPtr, *mPhysics);
|
||||||
|
MWWorld::Class::get(newPtr).enable(newPtr);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
#include "class.hpp"
|
#include "class.hpp"
|
||||||
#include "player.hpp"
|
#include "player.hpp"
|
||||||
#include "weather.hpp"
|
#include "weather.hpp"
|
||||||
|
#include "manualref.hpp"
|
||||||
#include "refdata.hpp"
|
#include "refdata.hpp"
|
||||||
#include "globals.hpp"
|
#include "globals.hpp"
|
||||||
#include "cellfunctors.hpp"
|
#include "cellfunctors.hpp"
|
||||||
|
@ -982,6 +982,28 @@ namespace MWWorld
|
||||||
else
|
else
|
||||||
cell = getPlayer().getPlayer().getCell();
|
cell = getPlayer().getPlayer().getCell();
|
||||||
|
|
||||||
|
// if this is gold, we need to fetch the correct mesh depending on the amount of gold.
|
||||||
|
if (MWWorld::Class::get(object).getName(object) == getStore().gameSettings.search("sGold")->str)
|
||||||
|
{
|
||||||
|
int goldAmount = object.getRefData().getCount();
|
||||||
|
|
||||||
|
std::string base = "Gold_001";
|
||||||
|
if (goldAmount >= 5)
|
||||||
|
base = "Gold_005";
|
||||||
|
else if (goldAmount >= 10)
|
||||||
|
base = "Gold_010";
|
||||||
|
else if (goldAmount >= 25)
|
||||||
|
base = "Gold_025";
|
||||||
|
else if (goldAmount >= 100)
|
||||||
|
base = "Gold_100";
|
||||||
|
|
||||||
|
std::cout << "using " << base << std::endl;
|
||||||
|
MWWorld::ManualRef newRef (getStore(), base);
|
||||||
|
object = newRef.getPtr();
|
||||||
|
object.getRefData().setCount(goldAmount);
|
||||||
|
object.mCell = cell;
|
||||||
|
}
|
||||||
|
|
||||||
ESM::Position& pos = object.getRefData().getPosition();
|
ESM::Position& pos = object.getRefData().getPosition();
|
||||||
pos.pos[0] = result.second[0];
|
pos.pos[0] = result.second[0];
|
||||||
pos.pos[1] = -result.second[2];
|
pos.pos[1] = -result.second[2];
|
||||||
|
|
Loading…
Reference in a new issue