/*
* The Mana World
* Copyright 2004 The Mana World Development Team
*
* This file is part of The Mana World.
*
* The Mana World is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* The Mana World is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with The Mana World; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* $Id$
*/
#ifndef _TMW_ITEMINFO_H_
#define _TMW_ITEMINFO_H_
#include <map>
#include <string>
#include <vector>
#include "spritedef.h"
enum EquipmentSoundEvent
{
EQUIP_EVENT_STRIKE,
EQUIP_EVENT_HIT
};
/**
* Enumeration of available Item types.
*/
enum ItemType
{
ITEM_UNUSABLE = 0,
ITEM_USABLE, // 1
ITEM_EQUIPMENT_ONE_HAND_WEAPON, // 2
ITEM_EQUIPMENT_TWO_HANDS_WEAPON,// 3
ITEM_EQUIPMENT_TORSO,// 4
ITEM_EQUIPMENT_ARMS,// 5
ITEM_EQUIPMENT_HEAD,// 6
ITEM_EQUIPMENT_LEGS,// 7
ITEM_EQUIPMENT_SHIELD,// 8
ITEM_EQUIPMENT_RING,// 9
ITEM_EQUIPMENT_NECKLACE,// 10
ITEM_EQUIPMENT_FEET,// 11
ITEM_EQUIPMENT_AMMO// 12
};
/**
* Enumeration of available weapon's types.
*/
enum WeaponType
{
WPNTYPE_NONE = 0,
WPNTYPE_KNIFE,// 1
WPNTYPE_SWORD,// 2
WPNTYPE_POLEARM,// 3
WPNTYPE_JAVELIN,// 4
WPNTYPE_STAFF,// 5
WPNTYPE_WHIP,// 6
WPNTYPE_BOOMERANG,// 7
WPNTYPE_BOW,// 8
WPNTYPE_SICKLE,// 9
WPNTYPE_CROSSBOW,// 10
WPNTYPE_MACE,// 11
WPNTYPE_AXE,// 12
WPNTYPE_THROWN// 13
};
/**
* Defines a class for storing item infos. This includes information used when
* the item is equipped.
*/
class ItemInfo
{
public:
/**
* Constructor.
*/
ItemInfo():
mType(ITEM_UNUSABLE),
mWeight(0),
mView(0),
mAttackType(ACTION_DEFAULT)
{
}
void setName(const std::string &name)
{ mName = name; }
const std::string& getName() const
{ return mName; }
void setImageName(const std::string &imageName)
{ mImageName = imageName; }
const std::string& getImageName() const
{ return mImageName; }
void setDescription(const std::string &description)
{ mDescription = description; }
const std::string& getDescription() const
{ return mDescription; }
void setEffect(const std::string &effect)
{ mEffect = effect; }
const std::string&
getEffect() const { return mEffect; }
void setType(short type)
{ mType = type; }
short getType() const
{ return mType; }
void setWeight(short weight)
{ mWeight = weight; }
short getWeight() const
{ return mWeight; }
void setView(int view)
{ mView = view; }
void setSprite(const std::string &animationFile, int gender)
{ mAnimationFiles[gender] = animationFile; }
const std::string& getSprite(int gender) const;
void setWeaponType(int);
SpriteAction getAttackType() const
{ return mAttackType; }
void addSound(EquipmentSoundEvent event, const std::string &filename);
const std::string& getSound(EquipmentSoundEvent event) const;
protected:
std::string mImageName; /**< The filename of the icon image. */
std::string mName;
std::string mDescription; /**< Short description. */
std::string mEffect; /**< Description of effects. */
char mType; /**< Item type. */
short mWeight; /**< Weight in grams. */
int mView; /**< Item ID of how this item looks. */
// Equipment related members
SpriteAction mAttackType; /**< Attack type, in case of weapon. */
/** Maps gender to sprite filenames. */
std::map<int, std::string> mAnimationFiles;
/** Stores the names of sounds to be played at certain event. */
std::map< EquipmentSoundEvent, std::vector<std::string> > mSounds;
};
#endif