Queen Ant kite protection.
This commit is contained in:
parent
28ffb4a437
commit
26a4c1480c
@ -19,11 +19,13 @@
|
|||||||
package ai.individual;
|
package ai.individual;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.ScheduledFuture;
|
||||||
|
|
||||||
import javolution.util.FastList;
|
import javolution.util.FastList;
|
||||||
import ai.npc.AbstractNpcAI;
|
import ai.npc.AbstractNpcAI;
|
||||||
|
|
||||||
import com.l2jserver.Config;
|
import com.l2jserver.Config;
|
||||||
|
import com.l2jserver.gameserver.ThreadPoolManager;
|
||||||
import com.l2jserver.gameserver.ai.CtrlIntention;
|
import com.l2jserver.gameserver.ai.CtrlIntention;
|
||||||
import com.l2jserver.gameserver.instancemanager.GrandBossManager;
|
import com.l2jserver.gameserver.instancemanager.GrandBossManager;
|
||||||
import com.l2jserver.gameserver.model.Location;
|
import com.l2jserver.gameserver.model.Location;
|
||||||
@ -79,9 +81,10 @@ public final class QueenAnt extends AbstractNpcAI
|
|||||||
private static SkillHolder HEAL1 = new SkillHolder(4020, 1);
|
private static SkillHolder HEAL1 = new SkillHolder(4020, 1);
|
||||||
private static SkillHolder HEAL2 = new SkillHolder(4024, 1);
|
private static SkillHolder HEAL2 = new SkillHolder(4024, 1);
|
||||||
|
|
||||||
private L2MonsterInstance _queen = null;
|
L2MonsterInstance _queen = null;
|
||||||
private L2MonsterInstance _larva = null;
|
private L2MonsterInstance _larva = null;
|
||||||
private final List<L2MonsterInstance> _nurses = new FastList<>(5);
|
private final List<L2MonsterInstance> _nurses = new FastList<>(5);
|
||||||
|
ScheduledFuture<?> _task = null;
|
||||||
|
|
||||||
private QueenAnt()
|
private QueenAnt()
|
||||||
{
|
{
|
||||||
@ -114,18 +117,13 @@ public final class QueenAnt extends AbstractNpcAI
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int loc_x = info.getInt("loc_x");
|
int loc_x = QUEEN_X;
|
||||||
int loc_y = info.getInt("loc_y");
|
int loc_y = QUEEN_Y;
|
||||||
int loc_z = info.getInt("loc_z");
|
int loc_z = QUEEN_Z;
|
||||||
int heading = info.getInt("heading");
|
int heading = info.getInt("heading");
|
||||||
int hp = info.getInt("currentHP");
|
int hp = info.getInt("currentHP");
|
||||||
int mp = info.getInt("currentMP");
|
int mp = info.getInt("currentMP");
|
||||||
if (!_zone.isInsideZone(loc_x, loc_y, loc_z))
|
|
||||||
{
|
|
||||||
loc_x = QUEEN_X;
|
|
||||||
loc_y = QUEEN_Y;
|
|
||||||
loc_z = QUEEN_Z;
|
|
||||||
}
|
|
||||||
L2GrandBossInstance queen = (L2GrandBossInstance) addSpawn(QUEEN, loc_x, loc_y, loc_z, heading, false, 0);
|
L2GrandBossInstance queen = (L2GrandBossInstance) addSpawn(QUEEN, loc_x, loc_y, loc_z, heading, false, 0);
|
||||||
queen.setCurrentHpMp(hp, mp);
|
queen.setCurrentHpMp(hp, mp);
|
||||||
spawnBoss(queen);
|
spawnBoss(queen);
|
||||||
@ -244,6 +242,9 @@ public final class QueenAnt extends AbstractNpcAI
|
|||||||
case GUARD:
|
case GUARD:
|
||||||
mob.setIsRaidMinion(true);
|
mob.setIsRaidMinion(true);
|
||||||
break;
|
break;
|
||||||
|
case QUEEN:
|
||||||
|
_task = ThreadPoolManager.getInstance().scheduleAiAtFixedRate(new QueenAntTask(), 5 * 1000, 5 * 1000);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.onSpawn(npc);
|
return super.onSpawn(npc);
|
||||||
@ -347,6 +348,11 @@ public final class QueenAnt extends AbstractNpcAI
|
|||||||
_larva.deleteMe();
|
_larva.deleteMe();
|
||||||
_larva = null;
|
_larva = null;
|
||||||
_queen = null;
|
_queen = null;
|
||||||
|
if (_task != null)
|
||||||
|
{
|
||||||
|
_task.cancel(false);
|
||||||
|
_task = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if ((_queen != null) && !_queen.isAlikeDead())
|
else if ((_queen != null) && !_queen.isAlikeDead())
|
||||||
{
|
{
|
||||||
@ -371,6 +377,32 @@ public final class QueenAnt extends AbstractNpcAI
|
|||||||
return super.onKill(npc, killer, isSummon);
|
return super.onKill(npc, killer, isSummon);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class QueenAntTask implements Runnable
|
||||||
|
{
|
||||||
|
public QueenAntTask()
|
||||||
|
{
|
||||||
|
// Constructor stub
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
if ((_queen == null) || _queen.isDead())
|
||||||
|
{
|
||||||
|
_task.cancel(false);
|
||||||
|
_task = null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (_queen.calculateDistance(QUEEN_X, QUEEN_Y, QUEEN_Z, false, false) > 2000.)
|
||||||
|
{
|
||||||
|
_queen.clearAggroList();
|
||||||
|
_queen.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new Location(QUEEN_X, QUEEN_Y, QUEEN_Z, 0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args)
|
||||||
{
|
{
|
||||||
new QueenAnt();
|
new QueenAnt();
|
||||||
|
Loading…
Reference in New Issue
Block a user