RandomizeHate.java 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * Copyright (C) 2004-2013 L2J DataPack
  3. *
  4. * This file is part of L2J DataPack.
  5. *
  6. * L2J DataPack is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * L2J DataPack is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. package handlers.effecthandlers;
  20. import java.util.ArrayList;
  21. import java.util.List;
  22. import com.l2jserver.gameserver.model.actor.L2Attackable;
  23. import com.l2jserver.gameserver.model.actor.L2Character;
  24. import com.l2jserver.gameserver.model.effects.EffectTemplate;
  25. import com.l2jserver.gameserver.model.effects.L2Effect;
  26. import com.l2jserver.gameserver.model.effects.L2EffectType;
  27. import com.l2jserver.gameserver.model.stats.Env;
  28. import com.l2jserver.gameserver.model.stats.Formulas;
  29. import com.l2jserver.util.Rnd;
  30. /**
  31. * Randomize Hate effect implementation.
  32. */
  33. public class RandomizeHate extends L2Effect
  34. {
  35. private final int _chance;
  36. public RandomizeHate(Env env, EffectTemplate template)
  37. {
  38. super(env, template);
  39. _chance = template.hasParameters() ? template.getParameters().getInteger("chance", 100) : 100;
  40. }
  41. @Override
  42. public boolean calcSuccess()
  43. {
  44. return Formulas.calcProbability(_chance, getEffector(), getEffected(), getSkill());
  45. }
  46. @Override
  47. public L2EffectType getEffectType()
  48. {
  49. return L2EffectType.NONE;
  50. }
  51. @Override
  52. public boolean isInstant()
  53. {
  54. return true;
  55. }
  56. @Override
  57. public boolean onStart()
  58. {
  59. if ((getEffected() == null) || (getEffected() == getEffector()) || !getEffected().isL2Attackable())
  60. {
  61. return false;
  62. }
  63. L2Attackable effectedMob = (L2Attackable) getEffected();
  64. final List<L2Character> targetList = new ArrayList<>();
  65. for (L2Character cha : getEffected().getKnownList().getKnownCharacters())
  66. {
  67. if ((cha != null) && (cha != effectedMob) && (cha != getEffector()))
  68. {
  69. // Aggro cannot be transfered to a mob of the same faction.
  70. if (cha.isL2Attackable() && (((L2Attackable) cha).getFactionId() != null) && ((L2Attackable) cha).getFactionId().equals(effectedMob.getFactionId()))
  71. {
  72. continue;
  73. }
  74. targetList.add(cha);
  75. }
  76. }
  77. // if there is no target, exit function
  78. if (targetList.isEmpty())
  79. {
  80. return true;
  81. }
  82. // Choosing randomly a new target
  83. final L2Character target = targetList.get(Rnd.get(targetList.size()));
  84. final int hate = effectedMob.getHating(getEffector());
  85. effectedMob.stopHating(getEffector());
  86. effectedMob.addDamageHate(target, 0, hate);
  87. return true;
  88. }
  89. }