diff --git a/server/gameserver/metamgr.cc b/server/gameserver/metamgr.cc index 6f08a0f..fed7afa 100755 --- a/server/gameserver/metamgr.cc +++ b/server/gameserver/metamgr.cc @@ -132,6 +132,7 @@ public: MetaMgr::Instance()->tank_damage_interval = MetaMgr::Instance()->GetSysParamAsFloat("tank_damage_interval", 1); MetaMgr::Instance()->average_oil = MetaMgr::Instance()->GetSysParamAsInt("average_oil"); MetaMgr::Instance()->max_oil = MetaMgr::Instance()->GetSysParamAsInt("max_oil"); + MetaMgr::Instance()->max_energy_shield = MetaMgr::Instance()->GetSysParamAsInt("max_energy_shield"); if (MetaMgr::Instance()->K < 0.01f) { abort(); } diff --git a/server/gameserver/metamgr.h b/server/gameserver/metamgr.h index 20a6057..75ec555 100755 --- a/server/gameserver/metamgr.h +++ b/server/gameserver/metamgr.h @@ -55,6 +55,7 @@ class MetaMgr : public a8::Singleton float tank_damage_interval = 0.0f; float average_oil = 0.0f; float max_oil = 0.0f; + int max_energy_shield = 100; private: MetaDataLoader* loader_ = nullptr; diff --git a/server/gameserver/player.cc b/server/gameserver/player.cc index 7b408df..b5a4812 100644 --- a/server/gameserver/player.cc +++ b/server/gameserver/player.cc @@ -31,7 +31,12 @@ void Player::Initialize() { Human::Initialize(); health = meta->i->health(); - max_energy_shield = energy_shield; + if (energy_shield) { + energy_shield = MetaMgr::Instance()->max_energy_shield; + max_energy_shield = energy_shield; + } else { + max_energy_shield = 0; + } skin_meta = MetaMgr::Instance()->GetDress(SkinId()); if (skin_meta) { skill_meta = MetaMgr::Instance()->GetSkill(skin_meta->i->skill_id()); @@ -1123,6 +1128,8 @@ void Player::_CMRevive(f8::MsgHdr& hdr, const cs::CMRevive& msg) dead = false; real_dead = false; downed = false; + energy_shield = MetaMgr::Instance()->max_energy_shield; + max_energy_shield = energy_shield; FreeDownedTimer(); health = GetMaxHP(); ResetTankSkin();