/*
* Copyright (C) 2004-2015 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 .
*/
package hellbound.AI;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;
import ai.npc.AbstractNpcAI;
import com.l2jserver.gameserver.model.actor.L2Npc;
import com.l2jserver.gameserver.model.actor.instance.L2MonsterInstance;
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
import com.l2jserver.gameserver.model.skills.Skill;
import com.l2jserver.gameserver.network.NpcStringId;
import com.l2jserver.gameserver.network.clientpackets.Say2;
import com.l2jserver.gameserver.util.MinionList;
/**
* Ranku's AI.
* @author GKR
*/
public final class Ranku extends AbstractNpcAI
{
// NPCs
private static final int RANKU = 25542;
private static final int MINION = 32305;
private static final int MINION_2 = 25543;
// Misc
private static final Set MY_TRACKING_SET = ConcurrentHashMap.newKeySet();
public Ranku()
{
super(Ranku.class.getSimpleName(), "hellbound/AI");
addAttackId(RANKU);
addKillId(RANKU, MINION);
}
@Override
public final String onAdvEvent(String event, L2Npc npc, L2PcInstance player)
{
if (event.equalsIgnoreCase("checkup") && (npc.getId() == RANKU) && !npc.isDead())
{
for (L2MonsterInstance minion : ((L2MonsterInstance) npc).getMinionList().getSpawnedMinions())
{
if ((minion != null) && !minion.isDead() && MY_TRACKING_SET.contains(minion.getObjectId()))
{
final L2PcInstance[] players = minion.getKnownList().getKnownPlayers().values().toArray(new L2PcInstance[minion.getKnownList().getKnownPlayers().size()]);
final L2PcInstance killer = players[getRandom(players.length)];
minion.reduceCurrentHp(minion.getMaxHp() / 100, killer, null);
}
}
startQuestTimer("checkup", 1000, npc, null);
}
return super.onAdvEvent(event, npc, player);
}
@Override
public String onAttack(L2Npc npc, L2PcInstance attacker, int damage, boolean isSummon, Skill skill)
{
if (npc.getId() == RANKU)
{
for (L2MonsterInstance minion : ((L2MonsterInstance) npc).getMinionList().getSpawnedMinions())
{
if ((minion != null) && !minion.isDead() && !MY_TRACKING_SET.contains(minion.getObjectId()))
{
broadcastNpcSay(minion, Say2.NPC_ALL, NpcStringId.DONT_KILL_ME_PLEASE_SOMETHINGS_STRANGLING_ME);
startQuestTimer("checkup", 1000, npc, null);
MY_TRACKING_SET.add(minion.getObjectId());
}
}
}
return super.onAttack(npc, attacker, damage, isSummon, skill);
}
@Override
public String onKill(L2Npc npc, L2PcInstance killer, boolean isSummon)
{
if (npc.getId() == MINION)
{
if (MY_TRACKING_SET.contains(npc.getObjectId()))
{
MY_TRACKING_SET.remove(npc.getObjectId());
}
final L2MonsterInstance master = ((L2MonsterInstance) npc).getLeader();
if ((master != null) && !master.isDead())
{
L2MonsterInstance minion2 = MinionList.spawnMinion(master, MINION_2);
minion2.teleToLocation(npc.getLocation());
}
}
else if (npc.getId() == RANKU)
{
for (L2MonsterInstance minion : ((L2MonsterInstance) npc).getMinionList().getSpawnedMinions())
{
if (MY_TRACKING_SET.contains(minion.getObjectId()))
{
MY_TRACKING_SET.remove(minion.getObjectId());
}
}
}
return super.onKill(npc, killer, isSummon);
}
}