2010-08-03 13:24:44 +00:00
|
|
|
|
|
|
|
#include "probe.hpp"
|
|
|
|
|
|
|
|
#include <components/esm/loadlocks.hpp>
|
|
|
|
|
2010-08-03 15:11:41 +00:00
|
|
|
#include <components/esm_store/cell_store.hpp>
|
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
2010-08-07 18:25:17 +00:00
|
|
|
#include "../mwworld/actiontake.hpp"
|
2012-03-13 16:50:32 +00:00
|
|
|
#include "../mwworld/environment.hpp"
|
2012-03-13 14:35:06 +00:00
|
|
|
#include "../mwworld/inventorystore.hpp"
|
2012-04-16 20:58:16 +00:00
|
|
|
#include "../mwworld/world.hpp"
|
|
|
|
#include "../mwgui/window_manager.hpp"
|
|
|
|
#include "../mwgui/tooltips.hpp"
|
2010-08-03 15:11:41 +00:00
|
|
|
|
2011-11-17 02:15:49 +00:00
|
|
|
#include "../mwrender/objects.hpp"
|
2010-08-06 20:20:20 +00:00
|
|
|
|
2012-03-13 16:50:32 +00:00
|
|
|
#include "../mwsound/soundmanager.hpp"
|
|
|
|
|
2010-08-03 13:24:44 +00:00
|
|
|
namespace MWClass
|
|
|
|
{
|
2011-11-12 04:01:12 +00:00
|
|
|
void Probe::insertObjectRendering (const MWWorld::Ptr& ptr, MWRender::RenderingInterface& renderingInterface) const
|
2010-08-14 08:02:54 +00:00
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
assert (ref->base != NULL);
|
|
|
|
const std::string &model = ref->base->model;
|
2012-01-28 10:45:55 +00:00
|
|
|
|
2010-08-14 08:02:54 +00:00
|
|
|
if (!model.empty())
|
|
|
|
{
|
2011-11-19 06:01:19 +00:00
|
|
|
MWRender::Objects& objects = renderingInterface.getObjects();
|
2011-11-12 04:01:12 +00:00
|
|
|
objects.insertBegin(ptr, ptr.getRefData().isEnabled(), false);
|
|
|
|
objects.insertMesh(ptr, "meshes\\" + model);
|
2010-08-14 08:02:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-11-12 04:01:12 +00:00
|
|
|
void Probe::insertObject(const MWWorld::Ptr& ptr, MWWorld::PhysicsSystem& physics, MWWorld::Environment& environment) const
|
2010-08-03 15:11:41 +00:00
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
2011-11-12 04:01:12 +00:00
|
|
|
|
|
|
|
const std::string &model = ref->base->model;
|
|
|
|
assert (ref->base != NULL);
|
|
|
|
if(!model.empty()){
|
2011-11-18 00:38:52 +00:00
|
|
|
physics.insertObjectPhysics(ptr, "meshes\\" + model);
|
2011-11-12 04:01:12 +00:00
|
|
|
}
|
|
|
|
|
2010-08-03 15:11:41 +00:00
|
|
|
}
|
|
|
|
|
2011-11-17 02:15:49 +00:00
|
|
|
|
|
|
|
std::string Probe::getName (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
return ref->base->name;
|
|
|
|
}
|
2010-08-07 18:25:17 +00:00
|
|
|
boost::shared_ptr<MWWorld::Action> Probe::activate (const MWWorld::Ptr& ptr,
|
|
|
|
const MWWorld::Ptr& actor, const MWWorld::Environment& environment) const
|
|
|
|
{
|
2012-03-31 14:31:55 +00:00
|
|
|
environment.mSoundManager->playSound3D (ptr, getUpSoundId(ptr, environment), 1.0, 1.0, MWSound::Play_NoTrack);
|
2012-03-13 16:50:32 +00:00
|
|
|
|
2010-08-07 18:25:17 +00:00
|
|
|
return boost::shared_ptr<MWWorld::Action> (
|
|
|
|
new MWWorld::ActionTake (ptr));
|
|
|
|
}
|
|
|
|
|
2010-08-05 13:40:03 +00:00
|
|
|
std::string Probe::getScript (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
return ref->base->script;
|
|
|
|
}
|
|
|
|
|
2012-03-13 14:35:06 +00:00
|
|
|
std::pair<std::vector<int>, bool> Probe::getEquipmentSlots (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
std::vector<int> slots;
|
|
|
|
|
|
|
|
slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedRight));
|
|
|
|
|
|
|
|
return std::make_pair (slots, false);
|
|
|
|
}
|
|
|
|
|
2012-04-07 17:53:49 +00:00
|
|
|
int Probe::getValue (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
return ref->base->data.value;
|
|
|
|
}
|
|
|
|
|
2010-08-03 13:24:44 +00:00
|
|
|
void Probe::registerSelf()
|
|
|
|
{
|
|
|
|
boost::shared_ptr<Class> instance (new Probe);
|
|
|
|
|
|
|
|
registerClass (typeid (ESM::Probe).name(), instance);
|
|
|
|
}
|
2012-03-13 16:50:32 +00:00
|
|
|
|
2012-03-13 22:38:44 +00:00
|
|
|
std::string Probe::getUpSoundId (const MWWorld::Ptr& ptr, const MWWorld::Environment& environment) const
|
2012-03-13 16:50:32 +00:00
|
|
|
{
|
|
|
|
return std::string("Item Probe Up");
|
|
|
|
}
|
|
|
|
|
2012-03-13 22:38:44 +00:00
|
|
|
std::string Probe::getDownSoundId (const MWWorld::Ptr& ptr, const MWWorld::Environment& environment) const
|
2012-03-13 16:50:32 +00:00
|
|
|
{
|
|
|
|
return std::string("Item Probe Down");
|
|
|
|
}
|
2012-04-16 20:58:16 +00:00
|
|
|
|
|
|
|
bool Probe::hasToolTip (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
return (ref->base->name != "");
|
|
|
|
}
|
|
|
|
|
|
|
|
MWGui::ToolTipInfo Probe::getToolTipInfo (const MWWorld::Ptr& ptr, MWWorld::Environment& environment) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Probe, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Probe>();
|
|
|
|
|
|
|
|
MWGui::ToolTipInfo info;
|
|
|
|
info.caption = ref->base->name;
|
|
|
|
info.icon = ref->base->icon;
|
|
|
|
|
|
|
|
std::string text;
|
|
|
|
|
|
|
|
/// \todo store remaining uses somewhere
|
|
|
|
|
|
|
|
text += "\n" + environment.mWorld->getStore().gameSettings.search("sUses")->str + ": " + MWGui::ToolTips::toString(ref->base->data.uses);
|
|
|
|
text += "\n" + environment.mWorld->getStore().gameSettings.search("sQuality")->str + ": " + MWGui::ToolTips::toString(ref->base->data.quality);
|
|
|
|
text += "\n" + environment.mWorld->getStore().gameSettings.search("sWeight")->str + ": " + MWGui::ToolTips::toString(ref->base->data.weight);
|
|
|
|
text += MWGui::ToolTips::getValueString(ref->base->data.value, environment.mWorld->getStore().gameSettings.search("sValue")->str);
|
|
|
|
|
|
|
|
if (environment.mWindowManager->getFullHelp()) {
|
|
|
|
text += MWGui::ToolTips::getMiscString(ref->ref.owner, "Owner");
|
|
|
|
text += MWGui::ToolTips::getMiscString(ref->base->script, "Script");
|
|
|
|
}
|
|
|
|
|
|
|
|
info.text = text;
|
|
|
|
|
|
|
|
return info;
|
|
|
|
}
|
2010-08-03 13:24:44 +00:00
|
|
|
}
|