From 03f5a7fbbb076dc98fdcdeba1fe2a2888aaf32f4 Mon Sep 17 00:00:00 2001 From: Arkadiusz Lach Date: Mon, 16 Dec 2024 19:09:58 +0100 Subject: [PATCH] Item animator for Enhanced Animations only --- src/client/item.cpp | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/src/client/item.cpp b/src/client/item.cpp index 89f0dd0d..1e90dcf6 100644 --- a/src/client/item.cpp +++ b/src/client/item.cpp @@ -52,8 +52,10 @@ Item::Item() : m_durationTimePaused(0), m_durationIsPaused(false) { - m_animator = std::make_shared(); - m_idleAnimator = std::make_shared(); + if (g_game.getFeature(Otc::GameEnhancedAnimations)) { + m_animator = std::make_shared(); + m_idleAnimator = std::make_shared(); + } } ItemPtr Item::create(int id, int countOrSubtype) @@ -134,13 +136,15 @@ void Item::setId(uint32 id) m_serverId = g_things.findItemTypeByClientId(id)->getServerId(); m_clientId = id; - if (auto thingType = rawGetThingType()) { - if (auto animator = thingType->getAnimator()) { - m_animator->copy(animator); - } + if (g_game.getFeature(Otc::GameEnhancedAnimations)) { + if (auto thingType = rawGetThingType()) { + if (auto animator = thingType->getAnimator()) { + m_animator->copy(animator); + } - if (auto animator = thingType->getIdleAnimator()) - m_idleAnimator->copy(animator); + if (auto animator = thingType->getIdleAnimator()) + m_idleAnimator->copy(animator); + } } } @@ -156,13 +160,15 @@ void Item::setOtbId(uint16 id) id = 0; m_clientId = id; - if (auto thingType = rawGetThingType()) { - if (auto animator = thingType->getAnimator()) { - m_animator->copy(animator); - } + if (g_game.getFeature(Otc::GameEnhancedAnimations)) { + if (auto thingType = rawGetThingType()) { + if (auto animator = thingType->getAnimator()) { + m_animator->copy(animator); + } - if (auto animator = thingType->getIdleAnimator()) - m_idleAnimator->copy(animator); + if (auto animator = thingType->getIdleAnimator()) + m_idleAnimator->copy(animator); + } } }