123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- /*
- * Copyright (C) 2004-2013 L2J DataPack
- *
- * This file is part of L2J DataPack.
- *
- * L2J DataPack 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 3 of the License, or
- * (at your option) any later version.
- *
- * L2J DataPack 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 <http://www.gnu.org/licenses/>.
- */
- package handlers.effecthandlers;
- import com.l2jserver.gameserver.model.effects.EffectTemplate;
- import com.l2jserver.gameserver.model.effects.L2Effect;
- import com.l2jserver.gameserver.model.effects.L2EffectType;
- import com.l2jserver.gameserver.model.stats.Env;
- import com.l2jserver.gameserver.network.SystemMessageId;
- import com.l2jserver.gameserver.network.serverpackets.ChangeWaitType;
- import com.l2jserver.gameserver.network.serverpackets.Revive;
- /**
- * Fake Death effect implementation.
- * @author mkizub
- */
- public class FakeDeath extends L2Effect
- {
- public FakeDeath(Env env, EffectTemplate template)
- {
- super(env, template);
- }
-
- @Override
- public L2EffectType getEffectType()
- {
- return L2EffectType.FAKE_DEATH;
- }
-
- @Override
- public boolean onActionTime()
- {
- if (getEffected().isDead())
- {
- return false;
- }
-
- final double manaDam = calc() * getEffectTemplate().getTotalTickCount();
- if (manaDam > getEffected().getCurrentMp())
- {
- if (getSkill().isToggle())
- {
- getEffected().sendPacket(SystemMessageId.SKILL_REMOVED_DUE_LACK_MP);
- return false;
- }
- }
-
- getEffected().reduceCurrentMp(manaDam);
- return true;
- }
-
- @Override
- public void onExit()
- {
- if (getEffected().isPlayer())
- {
- getEffected().getActingPlayer().setIsFakeDeath(false);
- getEffected().getActingPlayer().setRecentFakeDeath(true);
- }
-
- getEffected().broadcastPacket(new ChangeWaitType(getEffected(), ChangeWaitType.WT_STOP_FAKEDEATH));
- getEffected().broadcastPacket(new Revive(getEffected()));
- }
-
- @Override
- public boolean onStart()
- {
- getEffected().startFakeDeath();
- return true;
- }
- }
|