New Fishing changes.
This commit is contained in:
@@ -131,7 +131,7 @@ public final class L2FishermanInstance extends L2MerchantInstance
|
||||
private static void sendHtml(L2PcInstance player, L2Npc npc, String htmlName)
|
||||
{
|
||||
final NpcHtmlMessage html = new NpcHtmlMessage(npc.getObjectId());
|
||||
html.setFile(player.getHtmlPrefix(), "data/html/fisherman/championship/" + htmlName);
|
||||
html.setFile(player.getHtmlPrefix(), "html/fisherman/championship/" + htmlName);
|
||||
player.sendPacket(html);
|
||||
}
|
||||
}
|
||||
|
@@ -20,7 +20,6 @@ package com.l2jserver.gameserver.model.fishing;
|
||||
|
||||
import java.util.concurrent.Future;
|
||||
|
||||
import com.l2jserver.gameserver.ThreadPoolManager;
|
||||
import com.l2jserver.gameserver.data.xml.impl.FishingMonstersData;
|
||||
import com.l2jserver.gameserver.instancemanager.FishingChampionshipManager;
|
||||
import com.l2jserver.gameserver.model.actor.L2Npc;
|
||||
@@ -104,12 +103,15 @@ public class L2Fishing implements Runnable
|
||||
_fisher.broadcastPacket(new ExFishingStartCombat(_fisher, _time, _fishMaxHp, _mode, lureType, _deceptiveMode));
|
||||
_fisher.sendPacket(new PlaySound(1, "SF_S_01", 0, 0, 0, 0, 0));
|
||||
// Succeeded in getting a bite
|
||||
_fisher.sendPacket(SystemMessageId.YOU_VE_GOT_A_BITE);
|
||||
// _fisher.sendPacket(SystemMessageId.YOU_VE_GOT_A_BITE);
|
||||
|
||||
if (_fishAiTask == null)
|
||||
{
|
||||
_fishAiTask = ThreadPoolManager.getInstance().scheduleEffectAtFixedRate(this, 1000, 1000);
|
||||
}
|
||||
// if (_fishAiTask == null)
|
||||
// {
|
||||
// _fishAiTask = ThreadPoolManager.getInstance().scheduleEffectAtFixedRate(this, 1000, 1000);
|
||||
// }
|
||||
|
||||
// TODO: New fishing system?
|
||||
doDie(true);
|
||||
}
|
||||
|
||||
public void changeHp(int hp, int pen)
|
||||
|
@@ -32,6 +32,7 @@ public enum ZoneId
|
||||
LANDING,
|
||||
NO_LANDING,
|
||||
WATER,
|
||||
FISHING,
|
||||
JAIL,
|
||||
MONSTER_TRACK,
|
||||
CASTLE,
|
||||
|
@@ -18,15 +18,29 @@
|
||||
*/
|
||||
package com.l2jserver.gameserver.model.zone.type;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.concurrent.Future;
|
||||
|
||||
import com.l2jserver.Config;
|
||||
import com.l2jserver.gameserver.ThreadPoolManager;
|
||||
import com.l2jserver.gameserver.model.actor.L2Character;
|
||||
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
|
||||
import com.l2jserver.gameserver.model.zone.L2ZoneType;
|
||||
import com.l2jserver.gameserver.model.zone.ZoneId;
|
||||
import com.l2jserver.gameserver.network.serverpackets.ExAutoFishAvailable;
|
||||
|
||||
/**
|
||||
* A fishing zone
|
||||
* @author durgus
|
||||
* @author durgus, Darky999
|
||||
*/
|
||||
public class L2FishingZone extends L2ZoneType
|
||||
{
|
||||
private final Map<Integer, Future<?>> _task = new HashMap<>();
|
||||
int _fishx = 0;
|
||||
int _fishy = 0;
|
||||
int _fishz = 0;
|
||||
|
||||
public L2FishingZone(int id)
|
||||
{
|
||||
super(id);
|
||||
@@ -35,11 +49,50 @@ public class L2FishingZone extends L2ZoneType
|
||||
@Override
|
||||
protected void onEnter(L2Character character)
|
||||
{
|
||||
if (character.isPlayer())
|
||||
{
|
||||
character.setInsideZone(ZoneId.FISHING, true);
|
||||
}
|
||||
|
||||
if (character.isPlayer() && !Config.SERVER_CLASSIC_SUPPORT)
|
||||
{
|
||||
final L2PcInstance plr = (L2PcInstance) character;
|
||||
stopTask(plr);
|
||||
_task.put(plr.getObjectId(), ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new FishReq(plr), 100, 7000));
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onExit(L2Character character)
|
||||
{
|
||||
if (character.isPlayer())
|
||||
{
|
||||
character.setInsideZone(ZoneId.FISHING, false);
|
||||
}
|
||||
stopTask(character);
|
||||
_task.remove(character.getObjectId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDieInside(L2Character character)
|
||||
{
|
||||
onExit(character);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onReviveInside(L2Character character)
|
||||
{
|
||||
onEnter(character);
|
||||
}
|
||||
|
||||
protected void stopTask(L2Character character)
|
||||
{
|
||||
_task.remove(character.getObjectId());
|
||||
Future<?> t = _task.get(character.getObjectId());
|
||||
if (t != null)
|
||||
{
|
||||
t.cancel(false);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -49,4 +102,23 @@ public class L2FishingZone extends L2ZoneType
|
||||
{
|
||||
return getZone().getHighZ();
|
||||
}
|
||||
}
|
||||
|
||||
class FishReq implements Runnable
|
||||
{
|
||||
private final L2PcInstance player;
|
||||
|
||||
FishReq(L2PcInstance pl)
|
||||
{
|
||||
player = pl;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run()
|
||||
{
|
||||
if (!player.isFishing())
|
||||
{
|
||||
player.sendPacket(new ExAutoFishAvailable(player));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user