From f88506ac95b8ea9f02d22c35f81e59d4283151b6 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Mon, 20 Jun 2016 21:22:22 +0300 Subject: In Being replace mSpritesColor to using mSlots field. --- src/being/being.cpp | 29 ++++++++++------------------- src/being/being.h | 1 - src/resources/beingslot.h | 6 +++++- 3 files changed, 15 insertions(+), 21 deletions(-) (limited to 'src') diff --git a/src/being/being.cpp b/src/being/being.cpp index 69056cf44..9acf9fe57 100644 --- a/src/being/being.cpp +++ b/src/being/being.cpp @@ -168,7 +168,6 @@ Being::Being(const BeingId id, mText(nullptr), mTextColor(nullptr), mDest(), - mSpriteColors(), mSlots(), mSpriteParticles(), mGuilds(), @@ -2504,9 +2503,6 @@ void Being::setSprite(const unsigned int slot, if (slot >= CAST_U32(mSlots.size())) mSlots.resize(slot + 1, BeingSlot()); - if (slot >= CAST_U32(mSpriteColors.size())) - mSpriteColors.resize(slot + 1, ""); - // disabled for now, because it may broke replace/reorder sprites logic // if (slot && mSlots[slot].spriteId == id) // return; @@ -2584,7 +2580,7 @@ void Being::setSprite(const unsigned int slot, } mSlots[slot].spriteId = id; - mSpriteColors[slot] = color; + mSlots[slot].color = color; mSlots[slot].colorId = colorId; mSlots[slot].cardsId = CardsList(cards); recalcSpritesOrder(); @@ -2614,9 +2610,6 @@ void Being::setTempSprite(const unsigned int slot, if (slot >= CAST_U32(mSlots.size())) mSlots.resize(slot + 1, BeingSlot()); - if (slot >= CAST_U32(mSpriteColors.size())) - mSpriteColors.resize(slot + 1, ""); - // id = 0 means unequip if (id == 0) { @@ -2679,7 +2672,7 @@ void Being::setSpriteID(const unsigned int slot, { setSprite(slot, id, - mSpriteColors[slot], + mSlots[slot].color, ItemColor_one, mSlots[slot].cardsId); } @@ -2725,16 +2718,14 @@ void Being::dumpSprites() const restrict2 { std::vector::const_iterator it1 = mSlots.begin(); const std::vector::const_iterator it1_end = mSlots.end(); - StringVectCIter it2 = mSpriteColors.begin(); - const StringVectCIter it2_end = mSpriteColors.end(); logger->log("sprites"); - for (; it1 != it1_end && it2 != it2_end; - ++ it1, ++ it2) + for (; it1 != it1_end; + ++ it1) { logger->log("%d,%s,%d", (*it1).spriteId, - (*it2).c_str(), + (*it1).color.c_str(), toInt((*it1).colorId, int)); } } @@ -2904,7 +2895,7 @@ void Being::setGender(const GenderT gender) restrict2 { setSprite(i, mSlots[i].spriteId, - mSpriteColors[i], + mSlots[i].color, ItemColor_one, mSlots[i].cardsId); } @@ -3477,7 +3468,7 @@ void Being::recalcSpritesOrder() restrict2 { setTempSprite(remSprite, repIt->second, - mSpriteColors[remSprite], + mSlots[remSprite].color, mSlots[remSprite].cardsId); } else @@ -3508,7 +3499,7 @@ void Being::recalcSpritesOrder() restrict2 { setTempSprite(slot2, repIt->second, - mSpriteColors[slot2], + mSlots[slot2].color, mSlots[slot2].cardsId); } else @@ -3662,7 +3653,7 @@ void Being::recalcSpritesOrder() restrict2 updatedSprite[slot] = true; setTempSprite(slot, id, - mSpriteColors[slot], + mSlots[slot].color, mSlots[slot].cardsId); } } @@ -3677,7 +3668,7 @@ void Being::recalcSpritesOrder() restrict2 { setTempSprite(static_cast(slot), id, - mSpriteColors[slot], + mSlots[slot].color, mSlots[slot].cardsId); } } diff --git a/src/being/being.h b/src/being/being.h index 0574a3158..ad77c4672 100644 --- a/src/being/being.h +++ b/src/being/being.h @@ -1095,7 +1095,6 @@ class Being notfinal : public ActorSprite, typedef std::map SpriteParticleInfo; typedef SpriteParticleInfo::iterator SpriteParticleInfoIter; - StringVect mSpriteColors; std::vector mSlots; SpriteParticleInfo mSpriteParticles; diff --git a/src/resources/beingslot.h b/src/resources/beingslot.h index c889b6045..1d4ef4d55 100644 --- a/src/resources/beingslot.h +++ b/src/resources/beingslot.h @@ -25,6 +25,8 @@ #include "resources/item/cardslist.h" +#include + #include "localconsts.h" struct BeingSlot final @@ -32,13 +34,15 @@ struct BeingSlot final BeingSlot() : spriteId(0), cardsId(zeroCards), - colorId(ItemColor_one) + colorId(ItemColor_one), + color() { } int spriteId; CardsList cardsId; ItemColor colorId; + std::string color; }; #endif // RESOURCES_BEINGSLOT_H -- cgit v1.2.3-70-g09d2