/* * This program 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. * * This program 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.gameserver.ThreadPoolManager; 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.clientpackets.Say2; 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, Say2.BOAT, 801, SystemMessageId.FERRY_ARRIVED_AT_GIRAN ); ARRIVED_AT_GIRAN_2 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_TALKING_AFTER_10_MINUTES); LEAVE_GIRAN5 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_TALKING_IN_5_MINUTES); LEAVE_GIRAN1 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_TALKING_IN_1_MINUTE); LEAVE_GIRAN0 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_SOON_FOR_TALKING); LEAVING_GIRAN = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVING_FOR_TALKING); ARRIVED_AT_TALKING = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_ARRIVED_AT_TALKING); ARRIVED_AT_TALKING_2 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_GIRAN_AFTER_10_MINUTES); LEAVE_TALKING5 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_GIRAN_IN_5_MINUTES); LEAVE_TALKING1 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_FOR_GIRAN_IN_1_MINUTE); LEAVE_TALKING0 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVE_SOON_FOR_GIRAN); LEAVING_TALKING = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_LEAVING_FOR_GIRAN); BUSY_TALKING = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_GIRAN_TALKING_DELAYED); ARRIVAL_TALKING15 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_GIRAN_ARRIVE_AT_TALKING_15_MINUTES); ARRIVAL_TALKING10 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_GIRAN_ARRIVE_AT_TALKING_10_MINUTES); ARRIVAL_TALKING5 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_GIRAN_ARRIVE_AT_TALKING_5_MINUTES); ARRIVAL_TALKING1 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_GIRAN_ARRIVE_AT_TALKING_1_MINUTE); ARRIVAL_GIRAN20 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_TALKING_ARRIVE_AT_GIRAN_20_MINUTES); ARRIVAL_GIRAN15 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_TALKING_ARRIVE_AT_GIRAN_15_MINUTES); ARRIVAL_GIRAN10 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_TALKING_ARRIVE_AT_GIRAN_10_MINUTES); ARRIVAL_GIRAN5 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_TALKING_ARRIVE_AT_GIRAN_5_MINUTES); ARRIVAL_GIRAN1 = new CreatureSay(0, Say2.BOAT, 801, SystemMessageId.FERRY_FROM_TALKING_ARRIVE_AT_GIRAN_1_MINUTE); GIRAN_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), GIRAN_DOCK.x, GIRAN_DOCK.y, GIRAN_DOCK.z); TALKING_SOUND = new PlaySound(0, "itemsound.ship_arrival_departure", 1, _boat.getObjectId(), TALKING_DOCK[0].x, TALKING_DOCK[0].y, TALKING_DOCK[0].z); } 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) { final L2BoatInstance boat = BoatManager.getInstance().getNewBoat(2, 48950, 190613, -3610, 60800); if (boat != null) { boat.registerEngine(new BoatGiranTalking(boat)); boat.runEngine(180000); } } }