1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 09:35:28 +00:00
OpenMW/apps/openmw/mwclass/clothing.hpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

80 lines
3.5 KiB
C++
Raw Normal View History

2010-08-03 15:24:44 +02:00
#ifndef GAME_MWCLASS_CLOTHING_H
#define GAME_MWCLASS_CLOTHING_H
2022-04-04 02:44:53 +02:00
#include "../mwworld/registeredclass.hpp"
2010-08-03 15:24:44 +02:00
namespace MWClass
{
2022-04-04 02:44:53 +02:00
class Clothing : public MWWorld::RegisteredClass<Clothing>
2010-08-03 15:24:44 +02:00
{
2022-04-04 02:44:53 +02:00
friend MWWorld::RegisteredClass<Clothing>;
Clothing();
MWWorld::Ptr copyToCellImpl(const MWWorld::ConstPtr& ptr, MWWorld::CellStore& cell) const override;
2010-08-03 15:24:44 +02:00
public:
void insertObjectRendering(const MWWorld::Ptr& ptr, const std::string& model,
MWRender::RenderingInterface& renderingInterface) const override;
///< Add reference into a cell for rendering
2010-08-03 15:24:44 +02:00
std::string_view getName(const MWWorld::ConstPtr& ptr) const override;
///< \return name or ID; can return an empty string.
2022-08-16 21:15:03 +02:00
std::unique_ptr<MWWorld::Action> activate(const MWWorld::Ptr& ptr, const MWWorld::Ptr& actor) const override;
///< Generate action for activation
2010-08-03 15:24:44 +02:00
std::string_view getScript(const MWWorld::ConstPtr& ptr) const override;
2010-08-07 20:25:17 +02:00
///< Return name of the script attached to ptr
2022-08-11 22:51:55 +02:00
std::pair<std::vector<int>, bool> getEquipmentSlots(const MWWorld::ConstPtr& ptr) const override;
///< \return first: Return IDs of the slot this object can be equipped in; second: can object
/// stay stacked when equipped?
int getEquipmentSkill(const MWWorld::ConstPtr& ptr) const override;
/// Return the index of the skill this item corresponds to when equipped or -1, if there is
/// no such skill.
MWGui::ToolTipInfo getToolTipInfo(const MWWorld::ConstPtr& ptr, int count) const override;
2015-12-19 15:50:13 +01:00
///< @return the content of the tool tip to be displayed. raises exception if the object has no tooltip.
int getValue(const MWWorld::ConstPtr& ptr) const override;
///< Return trade value of the object. Throws an exception, if the object can't be traded.
std::string_view getUpSoundId(const MWWorld::ConstPtr& ptr) const override;
///< Return the pick up sound Id
std::string_view getDownSoundId(const MWWorld::ConstPtr& ptr) const override;
///< Return the put down sound Id
const std::string& getInventoryIcon(const MWWorld::ConstPtr& ptr) const override;
///< Return name of inventory icon.
2012-04-15 17:52:39 +02:00
2022-08-22 16:55:53 +02:00
std::string_view getEnchantment(const MWWorld::ConstPtr& ptr) const override;
2012-04-15 17:52:39 +02:00
///< @return the enchantment ID if the object is enchanted, otherwise an empty string
2022-08-22 16:55:53 +02:00
const std::string& applyEnchantment(const MWWorld::ConstPtr& ptr, const std::string& enchId, int enchCharge,
const std::string& newName) const override;
2012-05-12 16:17:03 +02:00
///< Creates a new record using \a ptr as template, with the given name and the given enchantment applied to it.
2022-08-22 16:55:53 +02:00
std::pair<int, std::string_view> canBeEquipped(
const MWWorld::ConstPtr& ptr, const MWWorld::Ptr& npc) const override;
///< Return 0 if player cannot equip item. 1 if can equip. 2 if it's twohanded weapon. 3 if twohanded weapon
///< conflicts with that.
/// Second item in the pair specifies the error message
2013-03-28 17:41:00 +01:00
std::unique_ptr<MWWorld::Action> use(const MWWorld::Ptr& ptr, bool force = false) const override;
///< Generate action for using via inventory menu
2013-04-05 15:42:05 +02:00
std::string getModel(const MWWorld::ConstPtr& ptr) const override;
2012-07-24 20:22:11 +04:00
int getEnchantmentPoints(const MWWorld::ConstPtr& ptr) const override;
2013-03-16 19:00:14 +01:00
float getWeight(const MWWorld::ConstPtr& ptr) const override;
bool canSell(const MWWorld::ConstPtr& item, int npcServices) const override;
2010-08-03 15:24:44 +02:00
};
}
#endif