// Ryzom - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
#ifndef CL_ITEM_SHEET_H
#define CL_ITEM_SHEET_H
/////////////
// INCLUDE //
/////////////
#include "client_sheets.h"
// misc
#include "nel/misc/types_nl.h"
// client
#include "entity_sheet.h"
#include "item_fx_sheet.h"
// Game share
#include "game_share/slot_types.h"
#include "game_share/item_family.h"
#include "game_share/item_type.h"
#include "game_share/skills.h"
#include "game_share/armor_types.h"
#include "game_share/weapon_types.h"
#include "game_share/damage_types.h"
#include "game_share/ecosystem.h"
#include "game_share/mp_category.h"
#include "game_share/item_origin.h"
#include "game_share/shield_types.h"
#include "game_share/crafting_tool_type.h"
#include "game_share/rm_family.h"
#include "game_share/range_weapon_type.h"
#include "game_share/characteristics.h"
#include "game_share/teleport_types.h"
#include "game_share/gender.h"
#include "game_share/characteristics.h"
// std
#include
///////////
// USING //
///////////
///////////
// CLASS //
///////////
namespace NLGEORGES
{
class UFormElm;
class UFormLoader;
}
// ***************************************************************************
/**
* Class to manage an item sheet.
* \author Stephane Coutelas
* \author Nevrax France
* \date 2001
*/
class CItemSheet : public CEntitySheet
{
public:
struct CCosmetic
{
uint32 VPValue;
GSGENDER::EGender Gender;
void serial(NLMISC::IStream &f)
{
f.serial(VPValue);
f.serialEnum(Gender);
}
};
struct CArmor
{
ARMORTYPE::EArmorType ArmorType;
void serial(NLMISC::IStream &f)
{
f.serialEnum(ArmorType);
}
};
struct CMeleeWeapon
{
WEAPONTYPE::EWeaponType WeaponType;
SKILLS::ESkills Skill;
DMGTYPE::EDamageType DamageType;
sint32 MeleeRange;
void serial(NLMISC::IStream &f)
{
f.serialEnum(WeaponType);
f.serialEnum(Skill);
f.serialEnum(DamageType);
f.serial(MeleeRange);
}
};
struct CRangeWeapon
{
WEAPONTYPE::EWeaponType WeaponType;
RANGE_WEAPON_TYPE::TRangeWeaponType RangeWeaponType;
SKILLS::ESkills Skill;
void serial(NLMISC::IStream &f)
{
f.serialEnum(WeaponType);
f.serialEnum(Skill);
f.serialEnum(RangeWeaponType);
}
};
struct CAmmo
{
SKILLS::ESkills Skill;
DMGTYPE::EDamageType DamageType;
sint32 Magazine;
void serial(NLMISC::IStream &f)
{
f.serialEnum(Skill);
f.serialEnum(DamageType);
f.serial(Magazine);
}
};
// Info on a itemPart which can be build by this MP
struct CMpItemPart
{
// The origin filter. It is actually a ITEM_ORIGIN::EItemOrigin
uint8 OriginFilter;
// The differents stats for this itemPart
uint8 Stats[RM_FABER_STAT_TYPE::NumRMStatType];
CMpItemPart()
{
OriginFilter = 0;
std::fill( Stats, Stats + RM_FABER_STAT_TYPE::NumRMStatType, 0 );
}
void serial(NLMISC::IStream &f)
{
f.serial(OriginFilter);
// must change sheet version
nlctassert(RM_FABER_STAT_TYPE::NumRMStatType==34);
for(uint i=0;i Properties;
void serial(NLMISC::IStream &f)
{
f.serial(OverdoseTimer);
f.serial(ConsumptionTime);
f.serialCont(Properties);
}
};
public:
/// shape file name
NLMISC::TSStringId IdShape;
/// Female shape file name
NLMISC::TSStringId IdShapeFemale;
/// Equipment slot. This is a bitField matching each bit to SLOTTYPE::TSlotType
uint64 SlotBF;
/// texture variant.
uint32 MapVariant;
/// Item Family
ITEMFAMILY::EItemFamily Family;
/// Item Type
ITEM_TYPE::TItemType ItemType;
/// icon file name for race type
NLMISC::TSStringId IdIconBack;
/// icon file name for main icon type
NLMISC::TSStringId IdIconMain;
/// icon file name for overlay
NLMISC::TSStringId IdIconOver;
/// icon file name for overlay2
NLMISC::TSStringId IdIconOver2;
// Special Color to modulate with
NLMISC::CRGBA IconColor;
NLMISC::CRGBA IconBackColor;
NLMISC::CRGBA IconOverColor;
NLMISC::CRGBA IconOver2Color;
/// icon Special Text (raw materials)
NLMISC::TSStringId IdIconText;
/// Part of the animation set ot use with this item.
NLMISC::TSStringId IdAnimSet;
/// Item Color. Special Enum for armours
sint8 Color;
/// has fx
bool HasFx;
// Does the player can sell the item ?
bool DropOrSell;
// Item is not persistent to a disconnection ?
bool IsItemNoRent;
/// item max stack size
uint32 Stackable;
/// is item consumable
bool IsConsumable;
/// Bulk.
float Bulk;
/// Equip Time
uint32 EquipTime;
/// true if this item can be hidden when equipped
bool NeverHideWhenEquipped;
// FX
CItemFXSheet FX;
// item special effects
NLMISC::TSStringId IdEffect1;
NLMISC::TSStringId IdEffect2;
NLMISC::TSStringId IdEffect3;
NLMISC::TSStringId IdEffect4;
// Only used for Mp
std::vector MpItemParts;
// item requirements
CHARACTERISTICS::TCharacteristics RequiredCharac;
uint16 RequiredCharacLevel;
SKILLS::ESkills RequiredSkill;
uint16 RequiredSkillLevel;
/// if craftable, the craft plan
NLMISC::CSheetId CraftPlan;
/// \name Help Infos
// @{
// Basics
ITEM_ORIGIN::EItemOrigin ItemOrigin;
// Different according to Family
union
{
CCosmetic Cosmetic;
CArmor Armor;
CMeleeWeapon MeleeWeapon;
CRangeWeapon RangeWeapon;
CAmmo Ammo;
CMp Mp;
CShield Shield;
CTool Tool;
CGuildOption GuildOption;
CPet Pet;
CTeleport Teleport;
};
CScroll Scroll;
CConsumable Consumable;
// @}
/**
* Constructor
*/
CItemSheet();
std::string getShape() const { return ClientSheetsStrings.get(IdShape); }
std::string getShapeFemale() const { return ClientSheetsStrings.get(IdShapeFemale); }
std::string getIconBack() const { return ClientSheetsStrings.get(IdIconBack); }
std::string getIconMain() const { return ClientSheetsStrings.get(IdIconMain); }
std::string getIconOver() const { return ClientSheetsStrings.get(IdIconOver); }
std::string getIconOver2() const { return ClientSheetsStrings.get(IdIconOver2); }
std::string getIconText() const { return ClientSheetsStrings.get(IdIconText); }
std::string getAnimSet() const { return ClientSheetsStrings.get(IdAnimSet); }
std::string getEffect1() const { return ClientSheetsStrings.get(IdEffect1); }
std::string getEffect2() const { return ClientSheetsStrings.get(IdEffect2); }
std::string getEffect3() const { return ClientSheetsStrings.get(IdEffect3); }
std::string getEffect4() const { return ClientSheetsStrings.get(IdEffect4); }
/// Build the sheet from an external script.
virtual void build(const NLGEORGES::UFormElm &item);
/// Serialize character sheet into binary data file.
virtual void serial(class NLMISC::IStream &f) throw(NLMISC::EStream);
/// true if the item can put in the slot e
bool hasSlot(SLOTTYPE::TSlotType e) const {return (SlotBF&(SINT64_CONSTANT(1)<= caracValue
bool hasCharacRequirement(uint itemLevel, CHARACTERISTICS::TCharacteristics &caracType, float &caracValue) const;
// return if canDrop (player exchange or BotChat Gift)
bool canExchangeOrGive(bool botChatGift) const;
// MP only. return translated text of all item part this MP can build. empty, if can't build anything
void getItemPartListAsText(ucstring &ipList) const;
// get craft plan
const NLMISC::CSheetId &getCraftPlan() const { return CraftPlan; }
};
#endif // CL_ITEM_SHEET_H
/* End of item_sheet.h */