/*
* 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 <http://www.gnu.org/licenses/>.
*/
package silentium.scripts.vehicle;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import silentium.gameserver.ThreadPoolManager;
import silentium.gameserver.instancemanager.BoatManager;
import silentium.gameserver.model.VehiclePathPoint;
import silentium.gameserver.model.actor.instance.L2BoatInstance;
import silentium.gameserver.network.SystemMessageId;
import silentium.gameserver.network.clientpackets.Say2;
import silentium.gameserver.network.serverpackets.CreatureSay;
import silentium.gameserver.network.serverpackets.PlaySound;
import silentium.gameserver.scripting.ScriptFile;
/**
* @author DS
*/
public class BoatGiranTalking implements Runnable, ScriptFile {
private static final Logger _log = LoggerFactory.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(final 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);
}
@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.warn(e.getLocalizedMessage(), e);
}
}
public static void onLoad() {
final L2BoatInstance boat = BoatManager.getInstance().getNewBoat(2, 48950, 190613, -3610, 60800);
if (boat != null) {
boat.registerEngine(new BoatGiranTalking(boat));
boat.runEngine(180000);
}
}
}