diff options
author | Andrei Karas <akaras@inbox.ru> | 2017-07-31 21:37:07 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2017-07-31 21:37:07 +0300 |
commit | a1a404408a790623f518bcb2966b472622f39116 (patch) | |
tree | 03edd8016f4efe6d46082fcbe0936f5abd659056 | |
parent | 6a64f7e58501280751d6cbe4f3a474cdb1a93f46 (diff) | |
download | mv-a1a404408a790623f518bcb2966b472622f39116.tar.gz mv-a1a404408a790623f518bcb2966b472622f39116.tar.bz2 mv-a1a404408a790623f518bcb2966b472622f39116.tar.xz mv-a1a404408a790623f518bcb2966b472622f39116.zip |
Precalculate badges position on each change time.
-rw-r--r-- | src/being/being.cpp | 107 | ||||
-rw-r--r-- | src/being/being.h | 4 |
2 files changed, 68 insertions, 43 deletions
diff --git a/src/being/being.cpp b/src/being/being.cpp index bf1b2db59..36badf728 100644 --- a/src/being/being.cpp +++ b/src/being/being.cpp @@ -257,6 +257,8 @@ Being::Being(const BeingId id, mAreaSize(11), mCastEndTime(0), mLanguageId(-1), + mBadgesX(0), + mBadgesY(0), mCreatorId(BeingId_zero), mTeamId(0U), mLook(0U), @@ -2258,74 +2260,84 @@ void Being::updateBotDirection(const int dstX, } } -void Being::drawEmotion(Graphics *restrict const graphics, - const int offsetX, - const int offsetY) const restrict2 +void Being::updateBadgesPosition() { - if (mErased) - return; - - const int px = mPixelX - offsetX - mapTileSize / 2; - const int py = mPixelY - offsetY - mapTileSize * 2 - mapTileSize; - if (mAnimationEffect != nullptr) - mAnimationEffect->draw(graphics, px, py); + const int px = mPixelX - mapTileSize / 2; + const int py = mPixelY - mapTileSize * 2 - mapTileSize; if (mShowBadges != BadgeDrawType::Hide && mBadgesCount != 0u) { - int x; - int y; if (mDispName != nullptr && gui != nullptr) { if (mShowBadges == BadgeDrawType::Right) { const Font *restrict const font = gui->getFont(); - x = mDispName->getX() - offsetX + mDispName->getWidth(); - y = mDispName->getY() - offsetY - font->getHeight(); + mBadgesX = mDispName->getX() + mDispName->getWidth(); + mBadgesY = mDispName->getY() - font->getHeight(); } else if (mShowBadges == BadgeDrawType::Bottom) { - x = px + 8 - mBadgesCount * 8; + mBadgesX = px + 8 - mBadgesCount * 8; if (mVisibleNamePos == VisibleNamePos::Buttom) { - y = mDispName->getY() - offsetY; + mBadgesY = mDispName->getY(); } else { - y = py + settings.playerNameOffset + 16; + mBadgesY = py + settings.playerNameOffset + 16; } } else { - x = px + 8 - mBadgesCount * 8; + mBadgesX = px + 8 - mBadgesCount * 8; if (mVisibleNamePos == VisibleNamePos::Top) - y = py - mDispName->getHeight(); + mBadgesY = py - mDispName->getHeight(); else - y = py; + mBadgesY = py; } } else { if (mShowBadges == BadgeDrawType::Right) { - x = px + settings.playerBadgeAtRightOffset; - y = py; + mBadgesX = px + settings.playerBadgeAtRightOffset; + mBadgesY = py; } else if (mShowBadges == BadgeDrawType::Bottom) { - x = px + 8 - mBadgesCount * 8; + mBadgesX = px + 8 - mBadgesCount * 8; const int height = settings.playerNameOffset; if (mVisibleNamePos == VisibleNamePos::Buttom) - y = py + height; + mBadgesY = py + height; else - y = py + height + 16; + mBadgesY = py + height + 16; } else { - x = px + 8 - mBadgesCount * 8; - y = py; + mBadgesX = px + 8 - mBadgesCount * 8; + mBadgesY = py; } } + } +} + +void Being::drawEmotion(Graphics *restrict const graphics, + const int offsetX, + const int offsetY) const restrict2 +{ + if (mErased) + return; + + const int px = mPixelX - offsetX - mapTileSize / 2; + const int py = mPixelY - offsetY - mapTileSize * 2 - mapTileSize; + if (mAnimationEffect != nullptr) + mAnimationEffect->draw(graphics, px, py); + if (mShowBadges != BadgeDrawType::Hide && + mBadgesCount != 0u) + { + int x = mBadgesX - offsetX; + const int y = mBadgesY - offsetY; for_each_badges() { const AnimatedSprite *restrict const sprite = mBadges[f]; @@ -2438,30 +2450,33 @@ int Being::getOffset() const restrict2 void Being::updateCoords() restrict2 { - if (mDispName == nullptr) - return; - - int offsetX = mPixelX; - int offsetY = mPixelY; - if (mInfo != nullptr) - { - offsetX += mInfo->getNameOffsetX(); - offsetY += mInfo->getNameOffsetY(); - } - // Monster names show above the sprite instead of below it - if (mType == ActorType::Monster || - mVisibleNamePos == VisibleNamePos::Top) + if (mDispName != nullptr) { - offsetY += - settings.playerNameOffset - mDispName->getHeight(); + int offsetX = mPixelX; + int offsetY = mPixelY; + if (mInfo != nullptr) + { + offsetX += mInfo->getNameOffsetX(); + offsetY += mInfo->getNameOffsetY(); + } + // Monster names show above the sprite instead of below it + if (mType == ActorType::Monster || + mVisibleNamePos == VisibleNamePos::Top) + { + offsetY += - settings.playerNameOffset - mDispName->getHeight(); + } + mDispName->adviseXY(offsetX, offsetY, mMoveNames); } - - mDispName->adviseXY(offsetX, offsetY, mMoveNames); + updateBadgesPosition(); } void Being::optionChanged(const std::string &restrict value) restrict2 { if (mType == ActorType::Player && value == "visiblenames") + { setShowName(config.getIntValue("visiblenames") == VisibleName::Show); + updateBadgesPosition(); + } } void Being::flashName(const int time) restrict2 @@ -3562,6 +3577,7 @@ void Being::showGmBadge(const bool show) restrict2 } } updateBadgesCount(); + updateBadgesPosition(); } void Being::setGM(const bool gm) restrict2 @@ -5079,6 +5095,7 @@ void Being::showTeamBadge(const bool show) restrict2 mBadges[BadgeIndex::Team] = AnimatedSprite::load(name); } updateBadgesCount(); + updateBadgesPosition(); } void Being::showBadges(const bool show) restrict2 @@ -5108,6 +5125,7 @@ void Being::showPartyBadge(const bool show) restrict2 } } updateBadgesCount(); + updateBadgesPosition(); } @@ -5135,6 +5153,7 @@ void Being::showShopBadge(const bool show) restrict2 } } updateBadgesCount(); + updateBadgesPosition(); } void Being::showInactiveBadge(const bool show) restrict2 @@ -5152,6 +5171,7 @@ void Being::showInactiveBadge(const bool show) restrict2 } } updateBadgesCount(); + updateBadgesPosition(); } void Being::showAwayBadge(const bool show) restrict2 @@ -5169,6 +5189,7 @@ void Being::showAwayBadge(const bool show) restrict2 } } updateBadgesCount(); + updateBadgesPosition(); } void Being::updateBadgesCount() restrict2 diff --git a/src/being/being.h b/src/being/being.h index 0f652139d..cd5b0efff 100644 --- a/src/being/being.h +++ b/src/being/being.h @@ -1222,6 +1222,8 @@ class Being notfinal : public ActorSprite, void postInit(const BeingTypeId subType, Map *const map); + void updateBadgesPosition(); + /** * Calculates the offset in the given directions. * If walking in direction 'neg' the value is negated. @@ -1349,6 +1351,8 @@ class Being notfinal : public ActorSprite, int mAreaSize; int mCastEndTime; int mLanguageId; + int mBadgesX; + int mBadgesY; BeingId mCreatorId; uint16_t mTeamId; uint16_t mLook; |