/* * The ManaPlus Client * Copyright (C) 2004-2009 The Mana World Development Team * Copyright (C) 2009-2010 The Mana Developers * Copyright (C) 2011-2013 The ManaPlus Developers * * This file is part of The ManaPlus Client. * * This program 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. * * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "resources/beinginfo.h" #include "configuration.h" #include "logger.h" #include "utils/dtor.h" #include "utils/gettext.h" #include "debug.h" BeingInfo *BeingInfo::unknown = nullptr; Attack *BeingInfo::empty = new Attack(SpriteAction::ATTACK, -1, -1, -1, -1, std::string()); BeingInfo::BeingInfo() : mDisplay(), mName(_("unnamed")), mTargetCursorSize(ActorSprite::TC_MEDIUM), mHoverCursor(Cursor::CURSOR_POINTER), mSounds(), mAttacks(), mWalkMask(Map::BLOCKMASK_WALL | Map::BLOCKMASK_CHARACTER | Map::BLOCKMASK_MONSTER | Map::BLOCKMASK_AIR | Map::BLOCKMASK_WATER), mBlockType(Map::BLOCKTYPE_CHARACTER), mTargetOffsetX(0), mTargetOffsetY(0), mMaxHP(0), mStaticMaxHP(false), mTargetSelection(true), mSortOffsetY(0), mDeadSortOffsetY(31), mAvatarId(0) { SpriteDisplay display; display.sprites.push_back(SpriteReference::Empty); setDisplay(display); } BeingInfo::~BeingInfo() { delete_all(mSounds); delete_all(mAttacks); mSounds.clear(); delete_all(mDisplay.sprites); } void BeingInfo::setDisplay(SpriteDisplay display) { mDisplay = display; } void BeingInfo::setTargetCursorSize(const std::string &size) { if (size == "small") { setTargetCursorSize(ActorSprite::TC_SMALL); } else if (size == "medium") { setTargetCursorSize(ActorSprite::TC_MEDIUM); } else if (size == "large") { setTargetCursorSize(ActorSprite::TC_LARGE); } else { logger->log("Unknown target cursor type \"%s\" for %s - using medium " "sized one", size.c_str(), getName().c_str()); setTargetCursorSize(ActorSprite::TC_MEDIUM); } } void BeingInfo::addSound(const SoundEvent event, const std::string &filename, const int delay) { if (mSounds.find(event) == mSounds.end()) mSounds[event] = new SoundInfoVect; if (mSounds[event]) mSounds[event]->push_back(SoundInfo("sfx/" + filename, delay)); } const SoundInfo &BeingInfo::getSound(const SoundEvent event) const { static SoundInfo emptySound("", 0); const SoundEvents::const_iterator i = mSounds.find(event); return (i == mSounds.end() || !i->second) ? emptySound : i->second->at(rand() % i->second->size()); } const Attack *BeingInfo::getAttack(const int id) const { const Attacks::const_iterator i = mAttacks.find(id); return (i == mAttacks.end()) ? empty : (*i).second; } void BeingInfo::addAttack(const int id, std::string action, const int effectId, const int hitEffectId, const int criticalHitEffectId, const int missEffectId, const std::string &missileParticle) { delete mAttacks[id]; mAttacks[id] = new Attack(action, effectId, hitEffectId, criticalHitEffectId, missEffectId, missileParticle); } void BeingInfo::clear() { delete unknown; unknown = nullptr; delete empty; empty = nullptr; } void BeingInfo::init() { if (empty) { empty->mEffectId = paths.getIntValue("effectId"); empty->mHitEffectId = paths.getIntValue("hitEffectId"); empty->mCriticalHitEffectId = paths.getIntValue("criticalHitEffectId"); empty->mMissEffectId = paths.getIntValue("missEffectId"); } }