diff --git a/trunk/dist/game/data/scripts.cfg b/trunk/dist/game/data/scripts.cfg
index 1c0402c855..a556d2f648 100644
--- a/trunk/dist/game/data/scripts.cfg
+++ b/trunk/dist/game/data/scripts.cfg
@@ -223,9 +223,11 @@ custom/events/TvT/TvTManager/TvTManager.java
custom/events/Wedding/Wedding.java
# Vehicles
+vehicles/BoatGiranTalking.java
vehicles/BoatInnadrilTour.java
vehicles/BoatGludinRune.java
vehicles/BoatRunePrimeval.java
+vehicles/BoatTalkingGludin.java
# Conquerable Clan Halls
conquerablehalls/flagwar/BanditStronghold/BanditStronghold.java
diff --git a/trunk/dist/game/data/scripts/vehicles/BoatGiranTalking.java b/trunk/dist/game/data/scripts/vehicles/BoatGiranTalking.java
new file mode 100644
index 0000000000..0223e784a2
--- /dev/null
+++ b/trunk/dist/game/data/scripts/vehicles/BoatGiranTalking.java
@@ -0,0 +1,292 @@
+/*
+ * 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 vehicles;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.l2jserver.Config;
+import com.l2jserver.gameserver.ThreadPoolManager;
+import com.l2jserver.gameserver.enums.ChatType;
+import com.l2jserver.gameserver.instancemanager.BoatManager;
+import com.l2jserver.gameserver.model.VehiclePathPoint;
+import com.l2jserver.gameserver.model.actor.instance.L2BoatInstance;
+import com.l2jserver.gameserver.network.SystemMessageId;
+import com.l2jserver.gameserver.network.serverpackets.CreatureSay;
+import com.l2jserver.gameserver.network.serverpackets.PlaySound;
+
+/**
+ * @author DS
+ */
+public class BoatGiranTalking implements Runnable
+{
+ private static final Logger _log = Logger.getLogger(BoatGiranTalking.class.getName());
+
+ // Time: 868s
+ private static final VehiclePathPoint[] GIRAN_TO_TALKING =
+ {
+ new VehiclePathPoint(51914, 189023, -3610, 150, 800),
+ new VehiclePathPoint(60567, 189789, -3610, 150, 800),
+ new VehiclePathPoint(63732, 197457, -3610, 200, 800),
+ new VehiclePathPoint(63732, 219946, -3610, 250, 800),
+ new VehiclePathPoint(62008, 222240, -3610, 250, 1200),
+ new VehiclePathPoint(56115, 226791, -3610, 250, 1200),
+ new VehiclePathPoint(40384, 226432, -3610, 300, 800),
+ new VehiclePathPoint(37760, 226432, -3610, 300, 800),
+ new VehiclePathPoint(27153, 226791, -3610, 300, 800),
+ new VehiclePathPoint(12672, 227535, -3610, 300, 800),
+ new VehiclePathPoint(-1808, 228280, -3610, 300, 800),
+ new VehiclePathPoint(-22165, 230542, -3610, 300, 800),
+ new VehiclePathPoint(-42523, 235205, -3610, 300, 800),
+ new VehiclePathPoint(-68451, 259560, -3610, 250, 800),
+ new VehiclePathPoint(-70848, 261696, -3610, 200, 800),
+ new VehiclePathPoint(-83344, 261610, -3610, 200, 800),
+ new VehiclePathPoint(-88344, 261660, -3610, 180, 800),
+ new VehiclePathPoint(-92344, 261660, -3610, 180, 800),
+ new VehiclePathPoint(-94242, 261659, -3610, 150, 800)
+ };
+
+ private static final VehiclePathPoint[] TALKING_DOCK =
+ {
+ new VehiclePathPoint(-96622, 261660, -3610, 150, 800)
+ };
+
+ // Time: 1398s
+ private static final VehiclePathPoint[] TALKING_TO_GIRAN =
+ {
+ new VehiclePathPoint(-113925, 261660, -3610, 150, 800),
+ new VehiclePathPoint(-126107, 249116, -3610, 180, 800),
+ new VehiclePathPoint(-126107, 234499, -3610, 180, 800),
+ new VehiclePathPoint(-126107, 219882, -3610, 180, 800),
+ new VehiclePathPoint(-109414, 204914, -3610, 180, 800),
+ new VehiclePathPoint(-92807, 204914, -3610, 180, 800),
+ new VehiclePathPoint(-80425, 216450, -3610, 250, 800),
+ new VehiclePathPoint(-68043, 227987, -3610, 250, 800),
+ new VehiclePathPoint(-63744, 231168, -3610, 250, 800),
+ new VehiclePathPoint(-60844, 231369, -3610, 250, 1800),
+ new VehiclePathPoint(-44915, 231369, -3610, 200, 800),
+ new VehiclePathPoint(-28986, 231369, -3610, 200, 800),
+ new VehiclePathPoint(8233, 207624, -3610, 200, 800),
+ new VehiclePathPoint(21470, 201503, -3610, 180, 800),
+ new VehiclePathPoint(40058, 195383, -3610, 180, 800),
+ new VehiclePathPoint(43022, 193793, -3610, 150, 800),
+ new VehiclePathPoint(45986, 192203, -3610, 150, 800),
+ new VehiclePathPoint(48950, 190613, -3610, 150, 800)
+ };
+
+ private static final VehiclePathPoint GIRAN_DOCK = TALKING_TO_GIRAN[TALKING_TO_GIRAN.length - 1];
+
+ private final L2BoatInstance _boat;
+ private int _cycle = 0;
+ private int _shoutCount = 0;
+
+ private final CreatureSay ARRIVED_AT_GIRAN;
+ private final CreatureSay ARRIVED_AT_GIRAN_2;
+ private final CreatureSay LEAVE_GIRAN5;
+ private final CreatureSay LEAVE_GIRAN1;
+ private final CreatureSay LEAVE_GIRAN0;
+ private final CreatureSay LEAVING_GIRAN;
+ private final CreatureSay ARRIVED_AT_TALKING;
+ private final CreatureSay ARRIVED_AT_TALKING_2;
+ private final CreatureSay LEAVE_TALKING5;
+ private final CreatureSay LEAVE_TALKING1;
+ private final CreatureSay LEAVE_TALKING0;
+ private final CreatureSay LEAVING_TALKING;
+ private final CreatureSay BUSY_TALKING;
+
+ private final CreatureSay ARRIVAL_TALKING15;
+ private final CreatureSay ARRIVAL_TALKING10;
+ private final CreatureSay ARRIVAL_TALKING5;
+ private final CreatureSay ARRIVAL_TALKING1;
+ private final CreatureSay ARRIVAL_GIRAN20;
+ private final CreatureSay ARRIVAL_GIRAN15;
+ private final CreatureSay ARRIVAL_GIRAN10;
+ private final CreatureSay ARRIVAL_GIRAN5;
+ private final CreatureSay ARRIVAL_GIRAN1;
+
+ private final PlaySound GIRAN_SOUND;
+ private final PlaySound TALKING_SOUND;
+
+ public BoatGiranTalking(L2BoatInstance boat)
+ {
+ _boat = boat;
+
+ ARRIVED_AT_GIRAN = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_HAS_ARRIVED_AT_GIRAN_HARBOR);
+ ARRIVED_AT_GIRAN_2 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_AFTER_ANCHORING_FOR_TEN_MINUTES);
+ LEAVE_GIRAN5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_IN_FIVE_MINUTES);
+ LEAVE_GIRAN1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_IN_ONE_MINUTE);
+ LEAVE_GIRAN0 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_BE_LEAVING_SOON_FOR_TALKING_ISLAND_HARBOR);
+ LEAVING_GIRAN = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_IS_LEAVING_FOR_TALKING_ISLAND_HARBOR);
+ ARRIVED_AT_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_HAS_ARRIVED_AT_TALKING_ISLAND_HARBOR);
+ ARRIVED_AT_TALKING_2 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GIRAN_HARBOR_AFTER_ANCHORING_FOR_TEN_MINUTES);
+ LEAVE_TALKING5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GIRAN_HARBOR_IN_FIVE_MINUTES);
+ LEAVE_TALKING1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GIRAN_HARBOR_IN_ONE_MINUTE);
+ LEAVE_TALKING0 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_BE_LEAVING_SOON_FOR_GIRAN_HARBOR);
+ LEAVING_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_IS_LEAVING_FOR_GIRAN_HARBOR);
+ BUSY_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_TO_GIRAN_HARBOR_HAS_BEEN_DELAYED);
+
+ ARRIVAL_TALKING15 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_15_MINUTES);
+ ARRIVAL_TALKING10 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_10_MINUTES);
+ ARRIVAL_TALKING5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_5_MINUTES);
+ ARRIVAL_TALKING1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_1_MINUTE);
+ ARRIVAL_GIRAN20 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GIRAN_HARBOR_IN_APPROXIMATELY_20_MINUTES);
+ ARRIVAL_GIRAN15 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GIRAN_HARBOR_IN_APPROXIMATELY_15_MINUTES);
+ ARRIVAL_GIRAN10 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GIRAN_HARBOR_IN_APPROXIMATELY_10_MINUTES);
+ ARRIVAL_GIRAN5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GIRAN_HARBOR_IN_APPROXIMATELY_5_MINUTES);
+ ARRIVAL_GIRAN1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GIRAN_HARBOR_IN_APPROXIMATELY_1_MINUTE);
+
+ GIRAN_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), GIRAN_DOCK.getX(), GIRAN_DOCK.getY(), GIRAN_DOCK.getZ());
+ TALKING_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), TALKING_DOCK[0].getX(), TALKING_DOCK[0].getY(), TALKING_DOCK[0].getZ());
+ }
+
+ @Override
+ public void run()
+ {
+ try
+ {
+ switch (_cycle)
+ {
+ case 0:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], LEAVE_GIRAN5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 1:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], LEAVE_GIRAN1);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 40000);
+ break;
+ case 2:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], LEAVE_GIRAN0);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 20000);
+ break;
+ case 3:
+ BoatManager.getInstance().broadcastPackets(GIRAN_DOCK, TALKING_DOCK[0], LEAVING_GIRAN, ARRIVAL_TALKING15);
+ _boat.broadcastPacket(GIRAN_SOUND);
+ _boat.payForRide(3946, 1, 46763, 187041, -3451);
+ _boat.executePath(GIRAN_TO_TALKING);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 250000);
+ break;
+ case 4:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, ARRIVAL_TALKING10);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 5:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, ARRIVAL_TALKING5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 6:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, ARRIVAL_TALKING1);
+ break;
+ case 7:
+ if (BoatManager.getInstance().dockBusy(BoatManager.TALKING_ISLAND))
+ {
+ if (_shoutCount == 0)
+ {
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, BUSY_TALKING);
+ }
+
+ _shoutCount++;
+ if (_shoutCount > 35)
+ {
+ _shoutCount = 0;
+ }
+
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 5000);
+ return;
+ }
+ _boat.executePath(TALKING_DOCK);
+ break;
+ case 8:
+ BoatManager.getInstance().dockShip(BoatManager.TALKING_ISLAND, true);
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GIRAN_DOCK, ARRIVED_AT_TALKING, ARRIVED_AT_TALKING_2);
+ _boat.broadcastPacket(TALKING_SOUND);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 9:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, LEAVE_TALKING5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 10:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, LEAVE_TALKING1);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 40000);
+ break;
+ case 11:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GIRAN_DOCK, LEAVE_TALKING0);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 20000);
+ break;
+ case 12:
+ BoatManager.getInstance().dockShip(BoatManager.TALKING_ISLAND, false);
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GIRAN_DOCK, LEAVING_TALKING);
+ _boat.broadcastPacket(TALKING_SOUND);
+ _boat.payForRide(3945, 1, -96777, 258970, -3623);
+ _boat.executePath(TALKING_TO_GIRAN);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 200000);
+ break;
+ case 13:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], ARRIVAL_GIRAN20);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 14:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], ARRIVAL_GIRAN15);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 15:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], ARRIVAL_GIRAN10);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 16:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], ARRIVAL_GIRAN5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 17:
+ BoatManager.getInstance().broadcastPacket(GIRAN_DOCK, TALKING_DOCK[0], ARRIVAL_GIRAN1);
+ break;
+ case 18:
+ BoatManager.getInstance().broadcastPackets(GIRAN_DOCK, TALKING_DOCK[0], ARRIVED_AT_GIRAN, ARRIVED_AT_GIRAN_2);
+ _boat.broadcastPacket(GIRAN_SOUND);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ }
+ _shoutCount = 0;
+ _cycle++;
+ if (_cycle > 18)
+ {
+ _cycle = 0;
+ }
+ }
+ catch (Exception e)
+ {
+ _log.log(Level.WARNING, e.getMessage());
+ }
+ }
+
+ public static void main(String[] args)
+ {
+ if (!Config.SERVER_CLASSIC_SUPPORT)
+ {
+ return;
+ }
+
+ final L2BoatInstance boat = BoatManager.getInstance().getNewBoat(2, 48950, 190613, -3610, 60800);
+ if (boat != null)
+ {
+ boat.registerEngine(new BoatGiranTalking(boat));
+ boat.runEngine(180000);
+ }
+ }
+}
diff --git a/trunk/dist/game/data/scripts/vehicles/BoatRunePrimeval.java b/trunk/dist/game/data/scripts/vehicles/BoatRunePrimeval.java
index 3e11cfd8b9..2556f087af 100644
--- a/trunk/dist/game/data/scripts/vehicles/BoatRunePrimeval.java
+++ b/trunk/dist/game/data/scripts/vehicles/BoatRunePrimeval.java
@@ -21,6 +21,7 @@ package vehicles;
import java.util.logging.Level;
import java.util.logging.Logger;
+import com.l2jserver.Config;
import com.l2jserver.gameserver.ThreadPoolManager;
import com.l2jserver.gameserver.enums.ChatType;
import com.l2jserver.gameserver.instancemanager.BoatManager;
@@ -167,6 +168,11 @@ public class BoatRunePrimeval implements Runnable
public static void main(String[] args)
{
+ if (Config.SERVER_CLASSIC_SUPPORT)
+ {
+ return;
+ }
+
final L2BoatInstance boat = BoatManager.getInstance().getNewBoat(5, 34381, -37680, -3610, 40785);
if (boat != null)
{
diff --git a/trunk/dist/game/data/scripts/vehicles/BoatTalkingGludin.java b/trunk/dist/game/data/scripts/vehicles/BoatTalkingGludin.java
new file mode 100644
index 0000000000..7601bf12a0
--- /dev/null
+++ b/trunk/dist/game/data/scripts/vehicles/BoatTalkingGludin.java
@@ -0,0 +1,290 @@
+/*
+ * 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 vehicles;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+import com.l2jserver.Config;
+import com.l2jserver.gameserver.ThreadPoolManager;
+import com.l2jserver.gameserver.enums.ChatType;
+import com.l2jserver.gameserver.instancemanager.BoatManager;
+import com.l2jserver.gameserver.model.VehiclePathPoint;
+import com.l2jserver.gameserver.model.actor.instance.L2BoatInstance;
+import com.l2jserver.gameserver.network.SystemMessageId;
+import com.l2jserver.gameserver.network.serverpackets.CreatureSay;
+import com.l2jserver.gameserver.network.serverpackets.PlaySound;
+
+/**
+ * @author DS
+ */
+public class BoatTalkingGludin implements Runnable
+{
+ private static final Logger _log = Logger.getLogger(BoatTalkingGludin.class.getName());
+
+ // Time: 919s
+ private static final VehiclePathPoint[] TALKING_TO_GLUDIN =
+ {
+ new VehiclePathPoint(-121385, 261660, -3610, 180, 800),
+ new VehiclePathPoint(-127694, 253312, -3610, 200, 800),
+ new VehiclePathPoint(-129274, 237060, -3610, 250, 800),
+ new VehiclePathPoint(-114688, 139040, -3610, 200, 800),
+ new VehiclePathPoint(-109663, 135704, -3610, 180, 800),
+ new VehiclePathPoint(-102151, 135704, -3610, 180, 800),
+ new VehiclePathPoint(-96686, 140595, -3610, 180, 800),
+ new VehiclePathPoint(-95686, 147718, -3610, 180, 800),
+ new VehiclePathPoint(-95686, 148718, -3610, 180, 800),
+ new VehiclePathPoint(-95686, 149718, -3610, 150, 800)
+ };
+
+ private static final VehiclePathPoint[] GLUDIN_DOCK =
+ {
+ new VehiclePathPoint(-95686, 150514, -3610, 150, 800)
+ };
+
+ // Time: 780s
+ private static final VehiclePathPoint[] GLUDIN_TO_TALKING =
+ {
+ new VehiclePathPoint(-95686, 155514, -3610, 180, 800),
+ new VehiclePathPoint(-95686, 185514, -3610, 250, 800),
+ new VehiclePathPoint(-60136, 238816, -3610, 200, 800),
+ new VehiclePathPoint(-60520, 259609, -3610, 180, 1800),
+ new VehiclePathPoint(-65344, 261460, -3610, 180, 1800),
+ new VehiclePathPoint(-83344, 261560, -3610, 180, 1800),
+ new VehiclePathPoint(-88344, 261660, -3610, 180, 1800),
+ new VehiclePathPoint(-92344, 261660, -3610, 150, 1800),
+ new VehiclePathPoint(-94242, 261659, -3610, 150, 1800)
+ };
+
+ private static final VehiclePathPoint[] TALKING_DOCK =
+ {
+ new VehiclePathPoint(-96622, 261660, -3610, 150, 1800)
+ };
+
+ private final L2BoatInstance _boat;
+ private int _cycle = 0;
+ private int _shoutCount = 0;
+
+ private final CreatureSay ARRIVED_AT_TALKING;
+ private final CreatureSay ARRIVED_AT_TALKING_2;
+ private final CreatureSay LEAVE_TALKING5;
+ private final CreatureSay LEAVE_TALKING1;
+ private final CreatureSay LEAVE_TALKING1_2;
+ private final CreatureSay LEAVE_TALKING0;
+ private final CreatureSay LEAVING_TALKING;
+ private final CreatureSay ARRIVED_AT_GLUDIN;
+ private final CreatureSay ARRIVED_AT_GLUDIN_2;
+ private final CreatureSay LEAVE_GLUDIN5;
+ private final CreatureSay LEAVE_GLUDIN1;
+ private final CreatureSay LEAVE_GLUDIN0;
+ private final CreatureSay LEAVING_GLUDIN;
+ private final CreatureSay BUSY_TALKING;
+ private final CreatureSay BUSY_GLUDIN;
+
+ private final CreatureSay ARRIVAL_GLUDIN10;
+ private final CreatureSay ARRIVAL_GLUDIN5;
+ private final CreatureSay ARRIVAL_GLUDIN1;
+ private final CreatureSay ARRIVAL_TALKING10;
+ private final CreatureSay ARRIVAL_TALKING5;
+ private final CreatureSay ARRIVAL_TALKING1;
+
+ private final PlaySound TALKING_SOUND;
+ private final PlaySound GLUDIN_SOUND;
+
+ public BoatTalkingGludin(L2BoatInstance boat)
+ {
+ _boat = boat;
+ _cycle = 0;
+
+ ARRIVED_AT_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_HAS_ARRIVED_AT_TALKING_ISLAND_HARBOR);
+ ARRIVED_AT_TALKING_2 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GLUDIN_HARBOR_AFTER_ANCHORING_FOR_TEN_MINUTES);
+ LEAVE_TALKING5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GLUDIN_HARBOR_IN_FIVE_MINUTES);
+ LEAVE_TALKING1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_GLUDIN_HARBOR_IN_ONE_MINUTE);
+ LEAVE_TALKING1_2 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THOSE_WISHING_TO_RIDE_THE_FERRY_SHOULD_MAKE_HASTE_TO_GET_ON);
+ LEAVE_TALKING0 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_BE_LEAVING_SOON_FOR_GLUDIN_HARBOR);
+ LEAVING_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_IS_LEAVING_FOR_GLUDIN_HARBOR);
+ ARRIVED_AT_GLUDIN = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_HAS_ARRIVED_AT_GLUDIN_HARBOR);
+ ARRIVED_AT_GLUDIN_2 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_AFTER_ANCHORING_FOR_TEN_MINUTES);
+ LEAVE_GLUDIN5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_IN_FIVE_MINUTES);
+ LEAVE_GLUDIN1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_LEAVE_FOR_TALKING_ISLAND_HARBOR_IN_ONE_MINUTE);
+ LEAVE_GLUDIN0 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_WILL_BE_LEAVING_SOON_FOR_TALKING_ISLAND_HARBOR);
+ LEAVING_GLUDIN = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_IS_LEAVING_FOR_TALKING_ISLAND_HARBOR);
+ BUSY_TALKING = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GLUDIN_HARBOR_TO_TALKING_ISLAND_HAS_BEEN_DELAYED);
+ BUSY_GLUDIN = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_TO_GLUDIN_HARBOR_HAS_BEEN_DELAYED);
+
+ ARRIVAL_GLUDIN10 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_ARRIVE_AT_GLUDIN_HARBOR_IN_APPROXIMATELY_10_MINUTES);
+ ARRIVAL_GLUDIN5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GLUDIN_HARBOR_IN_APPROXIMATELY_5_MINUTES);
+ ARRIVAL_GLUDIN1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_TALKING_ISLAND_WILL_BE_ARRIVING_AT_GLUDIN_HARBOR_IN_APPROXIMATELY_1_MINUTE);
+ ARRIVAL_TALKING10 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_10_MINUTES);
+ ARRIVAL_TALKING5 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_5_MINUTES);
+ ARRIVAL_TALKING1 = new CreatureSay(0, ChatType.BOAT, 801, SystemMessageId.THE_FERRY_FROM_GIRAN_HARBOR_WILL_BE_ARRIVING_AT_TALKING_ISLAND_IN_APPROXIMATELY_1_MINUTE);
+
+ TALKING_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), TALKING_DOCK[0].getX(), TALKING_DOCK[0].getY(), TALKING_DOCK[0].getZ());
+ GLUDIN_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), GLUDIN_DOCK[0].getX(), GLUDIN_DOCK[0].getY(), GLUDIN_DOCK[0].getZ());
+ }
+
+ @Override
+ public void run()
+ {
+ try
+ {
+ switch (_cycle)
+ {
+ case 0:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_TALKING5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 1:
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_TALKING1, LEAVE_TALKING1_2);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 40000);
+ break;
+ case 2:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_TALKING0);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 20000);
+ break;
+ case 3:
+ BoatManager.getInstance().dockShip(BoatManager.TALKING_ISLAND, false);
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVING_TALKING);
+ _boat.broadcastPacket(TALKING_SOUND);
+ _boat.payForRide(1074, 1, -96777, 258970, -3623);
+ _boat.executePath(TALKING_TO_GLUDIN);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 4:
+ BoatManager.getInstance().broadcastPacket(GLUDIN_DOCK[0], TALKING_DOCK[0], ARRIVAL_GLUDIN10);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 5:
+ BoatManager.getInstance().broadcastPacket(GLUDIN_DOCK[0], TALKING_DOCK[0], ARRIVAL_GLUDIN5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 6:
+ BoatManager.getInstance().broadcastPacket(GLUDIN_DOCK[0], TALKING_DOCK[0], ARRIVAL_GLUDIN1);
+ break;
+ case 7:
+ if (BoatManager.getInstance().dockBusy(BoatManager.GLUDIN_HARBOR))
+ {
+ if (_shoutCount == 0)
+ {
+ BoatManager.getInstance().broadcastPacket(GLUDIN_DOCK[0], TALKING_DOCK[0], BUSY_GLUDIN);
+ }
+
+ _shoutCount++;
+ if (_shoutCount > 35)
+ {
+ _shoutCount = 0;
+ }
+
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 5000);
+ return;
+ }
+ _boat.executePath(GLUDIN_DOCK);
+ break;
+ case 8:
+ BoatManager.getInstance().dockShip(BoatManager.GLUDIN_HARBOR, true);
+ BoatManager.getInstance().broadcastPackets(GLUDIN_DOCK[0], TALKING_DOCK[0], ARRIVED_AT_GLUDIN, ARRIVED_AT_GLUDIN_2);
+ _boat.broadcastPacket(GLUDIN_SOUND);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 9:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_GLUDIN5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 10:
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_GLUDIN1, LEAVE_TALKING1_2);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 40000);
+ break;
+ case 11:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVE_GLUDIN0);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 20000);
+ break;
+ case 12:
+ BoatManager.getInstance().dockShip(BoatManager.GLUDIN_HARBOR, false);
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GLUDIN_DOCK[0], LEAVING_GLUDIN);
+ _boat.broadcastPacket(GLUDIN_SOUND);
+ _boat.payForRide(1075, 1, -90015, 150422, -3610);
+ _boat.executePath(GLUDIN_TO_TALKING);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 150000);
+ break;
+ case 13:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], ARRIVAL_TALKING10);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ case 14:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], ARRIVAL_TALKING5);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 240000);
+ break;
+ case 15:
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], ARRIVAL_TALKING1);
+ break;
+ case 16:
+ if (BoatManager.getInstance().dockBusy(BoatManager.TALKING_ISLAND))
+ {
+ if (_shoutCount == 0)
+ {
+ BoatManager.getInstance().broadcastPacket(TALKING_DOCK[0], GLUDIN_DOCK[0], BUSY_TALKING);
+ }
+
+ _shoutCount++;
+ if (_shoutCount > 35)
+ {
+ _shoutCount = 0;
+ }
+
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 5000);
+ return;
+ }
+ _boat.executePath(TALKING_DOCK);
+ break;
+ case 17:
+ BoatManager.getInstance().dockShip(BoatManager.TALKING_ISLAND, true);
+ BoatManager.getInstance().broadcastPackets(TALKING_DOCK[0], GLUDIN_DOCK[0], ARRIVED_AT_TALKING, ARRIVED_AT_TALKING_2);
+ _boat.broadcastPacket(TALKING_SOUND);
+ ThreadPoolManager.getInstance().scheduleGeneral(this, 300000);
+ break;
+ }
+ _shoutCount = 0;
+ _cycle++;
+ if (_cycle > 17)
+ {
+ _cycle = 0;
+ }
+ }
+ catch (Exception e)
+ {
+ _log.log(Level.WARNING, e.getMessage());
+ }
+ }
+
+ public static void main(String[] args)
+ {
+ if (!Config.SERVER_CLASSIC_SUPPORT)
+ {
+ return;
+ }
+
+ final L2BoatInstance boat = BoatManager.getInstance().getNewBoat(1, -96622, 261660, -3610, 32768);
+ if (boat != null)
+ {
+ boat.registerEngine(new BoatTalkingGludin(boat));
+ boat.runEngine(180000);
+ BoatManager.getInstance().dockShip(BoatManager.TALKING_ISLAND, true);
+ }
+ }
+}