Servitor improvements.
This commit is contained in:
parent
eb4f43f5c2
commit
9baee86367
@ -62,7 +62,7 @@ public enum NpcInfoType implements IUpdateTypeComponent
|
||||
// 4
|
||||
TITLE_NPCSTRINGID(0x20, 4),
|
||||
PVP_FLAG(0x21, 1),
|
||||
NAME_COLOR(0x22, 4),
|
||||
REPUTATION(0x22, 4),
|
||||
CLAN(0x23, (5 * 4)),
|
||||
ABNORMALS(0x24, 0),
|
||||
VISUAL_STATE(0x25, 1);
|
||||
|
@ -191,20 +191,19 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
L2World.getInstance().forEachVisibleObject(this, L2PcInstance.class, player ->
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
return;
|
||||
}
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
player.sendPacket(new ExPetInfo(this, player, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -364,6 +363,8 @@ public abstract class L2Summon extends L2Playable
|
||||
|
||||
public void deleteMe(L2PcInstance owner)
|
||||
{
|
||||
super.deleteMe();
|
||||
|
||||
if (owner != null)
|
||||
{
|
||||
owner.sendPacket(new PetDelete(getSummonType(), getObjectId()));
|
||||
@ -372,16 +373,7 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
party.broadcastToPartyMembers(owner, new ExPartyPetWindowDelete(this));
|
||||
}
|
||||
}
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
if (owner != null)
|
||||
{
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
owner.setPet(null);
|
||||
@ -391,7 +383,13 @@ public abstract class L2Summon extends L2Playable
|
||||
owner.removeServitor(getObjectId());
|
||||
}
|
||||
}
|
||||
super.deleteMe();
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
}
|
||||
|
||||
public void unSummon(L2PcInstance owner)
|
||||
@ -842,7 +840,7 @@ public abstract class L2Summon extends L2Playable
|
||||
// Check if the L2PcInstance is the owner of the Pet
|
||||
if (activeChar == getOwner())
|
||||
{
|
||||
activeChar.sendPacket(new PetInfo(this, 1));
|
||||
activeChar.sendPacket(new PetInfo(this, isDead() ? 0 : 1));
|
||||
// The PetInfo packet wipes the PartySpelled (list of active spells' icons). Re-add them
|
||||
updateEffectIcons(true);
|
||||
if (isPet())
|
||||
|
@ -147,6 +147,11 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -400,7 +400,7 @@ public class NpcInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_npc.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
}
|
||||
|
@ -65,8 +65,11 @@ public class PetInfo implements IClientOutgoingPacket
|
||||
_maxFed = sum.getLifeTime();
|
||||
}
|
||||
|
||||
// _statusMask |= 0x01; // Auto attackable status
|
||||
// _statusMask |= 0x02; // can be chatted with
|
||||
if (summon.isBetrayed())
|
||||
{
|
||||
_statusMask |= 0x01; // Auto attackable status
|
||||
}
|
||||
_statusMask |= 0x02; // can be chatted with
|
||||
|
||||
if (summon.isRunning())
|
||||
{
|
||||
|
@ -147,6 +147,11 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -62,7 +62,7 @@ public enum NpcInfoType implements IUpdateTypeComponent
|
||||
// 4
|
||||
TITLE_NPCSTRINGID(0x20, 4),
|
||||
PVP_FLAG(0x21, 1),
|
||||
NAME_COLOR(0x22, 4),
|
||||
REPUTATION(0x22, 4),
|
||||
CLAN(0x23, (5 * 4)),
|
||||
ABNORMALS(0x24, 0),
|
||||
VISUAL_STATE(0x25, 1);
|
||||
|
@ -191,20 +191,19 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
L2World.getInstance().forEachVisibleObject(this, L2PcInstance.class, player ->
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
return;
|
||||
}
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
player.sendPacket(new ExPetInfo(this, player, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -364,6 +363,8 @@ public abstract class L2Summon extends L2Playable
|
||||
|
||||
public void deleteMe(L2PcInstance owner)
|
||||
{
|
||||
super.deleteMe();
|
||||
|
||||
if (owner != null)
|
||||
{
|
||||
owner.sendPacket(new PetDelete(getSummonType(), getObjectId()));
|
||||
@ -372,16 +373,7 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
party.broadcastToPartyMembers(owner, new ExPartyPetWindowDelete(this));
|
||||
}
|
||||
}
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
if (owner != null)
|
||||
{
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
owner.setPet(null);
|
||||
@ -391,7 +383,13 @@ public abstract class L2Summon extends L2Playable
|
||||
owner.removeServitor(getObjectId());
|
||||
}
|
||||
}
|
||||
super.deleteMe();
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
}
|
||||
|
||||
public void unSummon(L2PcInstance owner)
|
||||
@ -842,7 +840,7 @@ public abstract class L2Summon extends L2Playable
|
||||
// Check if the L2PcInstance is the owner of the Pet
|
||||
if (activeChar == getOwner())
|
||||
{
|
||||
activeChar.sendPacket(new PetInfo(this, 1));
|
||||
activeChar.sendPacket(new PetInfo(this, isDead() ? 0 : 1));
|
||||
// The PetInfo packet wipes the PartySpelled (list of active spells' icons). Re-add them
|
||||
updateEffectIcons(true);
|
||||
if (isPet())
|
||||
|
@ -147,6 +147,11 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -400,7 +400,7 @@ public class NpcInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_npc.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
}
|
||||
|
@ -65,8 +65,11 @@ public class PetInfo implements IClientOutgoingPacket
|
||||
_maxFed = sum.getLifeTime();
|
||||
}
|
||||
|
||||
// _statusMask |= 0x01; // Auto attackable status
|
||||
// _statusMask |= 0x02; // can be chatted with
|
||||
if (summon.isBetrayed())
|
||||
{
|
||||
_statusMask |= 0x01; // Auto attackable status
|
||||
}
|
||||
_statusMask |= 0x02; // can be chatted with
|
||||
|
||||
if (summon.isRunning())
|
||||
{
|
||||
|
@ -147,6 +147,11 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -62,7 +62,7 @@ public enum NpcInfoType implements IUpdateTypeComponent
|
||||
// 4
|
||||
TITLE_NPCSTRINGID(0x20, 4),
|
||||
PVP_FLAG(0x21, 1),
|
||||
NAME_COLOR(0x22, 4),
|
||||
REPUTATION(0x22, 4),
|
||||
CLAN(0x23, (5 * 4)),
|
||||
ABNORMALS(0x24, 0),
|
||||
VISUAL_STATE(0x25, 1);
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -147,6 +147,11 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -400,7 +400,7 @@ public class NpcInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_npc.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
}
|
||||
|
@ -65,8 +65,11 @@ public class PetInfo implements IClientOutgoingPacket
|
||||
_maxFed = sum.getLifeTime();
|
||||
}
|
||||
|
||||
// _statusMask |= 0x01; // Auto attackable status
|
||||
// _statusMask |= 0x02; // can be chatted with
|
||||
if (summon.isBetrayed())
|
||||
{
|
||||
_statusMask |= 0x01; // Auto attackable status
|
||||
}
|
||||
_statusMask |= 0x02; // can be chatted with
|
||||
|
||||
if (summon.isRunning())
|
||||
{
|
||||
|
@ -1,397 +1,402 @@
|
||||
/*
|
||||
* This file is part of the L2J Mobius project.
|
||||
*
|
||||
* 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 com.l2jmobius.gameserver.network.serverpackets;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
import com.l2jmobius.commons.network.PacketWriter;
|
||||
import com.l2jmobius.gameserver.enums.NpcInfoType;
|
||||
import com.l2jmobius.gameserver.enums.Team;
|
||||
import com.l2jmobius.gameserver.model.actor.L2Summon;
|
||||
import com.l2jmobius.gameserver.model.actor.instance.L2PcInstance;
|
||||
import com.l2jmobius.gameserver.model.skills.AbnormalVisualEffect;
|
||||
import com.l2jmobius.gameserver.model.zone.ZoneId;
|
||||
import com.l2jmobius.gameserver.network.OutgoingPackets;
|
||||
|
||||
/**
|
||||
* @author Sdw
|
||||
*/
|
||||
public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
private final L2Summon _summon;
|
||||
private final L2PcInstance _attacker;
|
||||
private final int _val;
|
||||
private final byte[] _masks = new byte[]
|
||||
{
|
||||
(byte) 0x00,
|
||||
(byte) 0x0C,
|
||||
(byte) 0x0C,
|
||||
(byte) 0x00,
|
||||
(byte) 0x00
|
||||
};
|
||||
|
||||
private int _initSize = 0;
|
||||
private int _blockSize = 0;
|
||||
|
||||
private int _clanCrest = 0;
|
||||
private int _clanLargeCrest = 0;
|
||||
private int _allyCrest = 0;
|
||||
private int _allyId = 0;
|
||||
private int _clanId = 0;
|
||||
private int _statusMask = 0;
|
||||
private final String _title;
|
||||
private final Set<AbnormalVisualEffect> _abnormalVisualEffects;
|
||||
|
||||
public SummonInfo(L2Summon summon, L2PcInstance attacker, int val)
|
||||
{
|
||||
_summon = summon;
|
||||
_attacker = attacker;
|
||||
_title = (summon.getOwner() != null) && summon.getOwner().isOnline() ? summon.getOwner().getName() : "";
|
||||
_val = val;
|
||||
_abnormalVisualEffects = summon.getCurrentAbnormalVisualEffects();
|
||||
|
||||
if (summon.getTemplate().getDisplayId() != summon.getTemplate().getId())
|
||||
{
|
||||
_masks[2] |= 0x10;
|
||||
addComponentType(NpcInfoType.NAME);
|
||||
}
|
||||
|
||||
addComponentType(NpcInfoType.ATTACKABLE, NpcInfoType.UNKNOWN1, NpcInfoType.TITLE, NpcInfoType.ID, NpcInfoType.POSITION, NpcInfoType.ALIVE, NpcInfoType.RUNNING);
|
||||
|
||||
if (summon.getHeading() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.HEADING);
|
||||
}
|
||||
|
||||
if ((summon.getStat().getPAtkSpd() > 0) || (summon.getStat().getMAtkSpd() > 0))
|
||||
{
|
||||
addComponentType(NpcInfoType.ATK_CAST_SPEED);
|
||||
}
|
||||
|
||||
if (summon.getRunSpeed() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.SPEED_MULTIPLIER);
|
||||
}
|
||||
|
||||
if ((summon.getWeapon() > 0) || (summon.getArmor() > 0))
|
||||
{
|
||||
addComponentType(NpcInfoType.EQUIPPED);
|
||||
}
|
||||
|
||||
if (summon.getTeam() != Team.NONE)
|
||||
{
|
||||
addComponentType(NpcInfoType.TEAM);
|
||||
}
|
||||
|
||||
if (summon.isInsideZone(ZoneId.WATER) || summon.isFlying())
|
||||
{
|
||||
addComponentType(NpcInfoType.SWIM_OR_FLY);
|
||||
}
|
||||
|
||||
if (summon.isFlying())
|
||||
{
|
||||
addComponentType(NpcInfoType.FLYING);
|
||||
}
|
||||
|
||||
if (summon.getMaxHp() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.MAX_HP);
|
||||
}
|
||||
|
||||
if (summon.getMaxMp() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.MAX_MP);
|
||||
}
|
||||
|
||||
if (summon.getCurrentHp() <= summon.getMaxHp())
|
||||
{
|
||||
addComponentType(NpcInfoType.CURRENT_HP);
|
||||
}
|
||||
|
||||
if (summon.getCurrentMp() <= summon.getMaxMp())
|
||||
{
|
||||
addComponentType(NpcInfoType.CURRENT_MP);
|
||||
}
|
||||
|
||||
if (!_abnormalVisualEffects.isEmpty())
|
||||
{
|
||||
addComponentType(NpcInfoType.ABNORMALS);
|
||||
}
|
||||
|
||||
if (summon.getTemplate().getWeaponEnchant() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.ENCHANT);
|
||||
}
|
||||
|
||||
if (summon.getTransformationDisplayId() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.TRANSFORMATION);
|
||||
}
|
||||
|
||||
if (summon.isShowSummonAnimation())
|
||||
{
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
_clanCrest = summon.getOwner().getAppearance().getVisibleClanCrestId();
|
||||
_clanLargeCrest = summon.getOwner().getAppearance().getVisibleClanLargeCrestId();
|
||||
_allyCrest = summon.getOwner().getAppearance().getVisibleAllyId();
|
||||
_allyId = summon.getOwner().getAppearance().getVisibleAllyCrestId();
|
||||
|
||||
addComponentType(NpcInfoType.CLAN);
|
||||
}
|
||||
|
||||
addComponentType(NpcInfoType.COLOR_EFFECT);
|
||||
|
||||
// TODO: Confirm me
|
||||
if (summon.isInCombat())
|
||||
{
|
||||
_statusMask |= 0x01;
|
||||
}
|
||||
if (summon.isDead())
|
||||
{
|
||||
_statusMask |= 0x02;
|
||||
}
|
||||
if (summon.isTargetable())
|
||||
{
|
||||
_statusMask |= 0x04;
|
||||
}
|
||||
|
||||
_statusMask |= 0x08;
|
||||
|
||||
if (_statusMask != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.VISUAL_STATE);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected byte[] getMasks()
|
||||
{
|
||||
return _masks;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onNewMaskAdded(NpcInfoType component)
|
||||
{
|
||||
calcBlockSize(_summon, component);
|
||||
}
|
||||
|
||||
private void calcBlockSize(L2Summon summon, NpcInfoType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case ATTACKABLE:
|
||||
case UNKNOWN1:
|
||||
{
|
||||
_initSize += type.getBlockLength();
|
||||
break;
|
||||
}
|
||||
case TITLE:
|
||||
{
|
||||
_initSize += type.getBlockLength() + (_title.length() * 2);
|
||||
break;
|
||||
}
|
||||
case NAME:
|
||||
{
|
||||
_blockSize += type.getBlockLength() + (summon.getName().length() * 2);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
_blockSize += type.getBlockLength();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean write(PacketWriter packet)
|
||||
{
|
||||
OutgoingPackets.SUMMON_INFO.writeId(packet);
|
||||
|
||||
packet.writeD(_summon.getObjectId());
|
||||
packet.writeC(_val); // 0=teleported 1=default 2=summoned
|
||||
packet.writeH(37); // mask_bits_37
|
||||
packet.writeB(_masks);
|
||||
|
||||
// Block 1
|
||||
packet.writeC(_initSize);
|
||||
|
||||
if (containsMask(NpcInfoType.ATTACKABLE))
|
||||
{
|
||||
packet.writeC(_summon.isAutoAttackable(_attacker) ? 0x01 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN1))
|
||||
{
|
||||
packet.writeD(0x00); // unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.TITLE))
|
||||
{
|
||||
packet.writeS(_title);
|
||||
}
|
||||
|
||||
// Block 2
|
||||
packet.writeH(_blockSize);
|
||||
if (containsMask(NpcInfoType.ID))
|
||||
{
|
||||
packet.writeD(_summon.getTemplate().getDisplayId() + 1000000);
|
||||
}
|
||||
if (containsMask(NpcInfoType.POSITION))
|
||||
{
|
||||
packet.writeD(_summon.getX());
|
||||
packet.writeD(_summon.getY());
|
||||
packet.writeD(_summon.getZ());
|
||||
}
|
||||
if (containsMask(NpcInfoType.HEADING))
|
||||
{
|
||||
packet.writeD(_summon.getHeading());
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN2))
|
||||
{
|
||||
packet.writeD(0x00); // Unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.ATK_CAST_SPEED))
|
||||
{
|
||||
packet.writeD(_summon.getPAtkSpd());
|
||||
packet.writeD(_summon.getMAtkSpd());
|
||||
}
|
||||
if (containsMask(NpcInfoType.SPEED_MULTIPLIER))
|
||||
{
|
||||
packet.writeE((float) _summon.getStat().getMovementSpeedMultiplier());
|
||||
packet.writeE(_summon.getStat().getAttackSpeedMultiplier());
|
||||
}
|
||||
if (containsMask(NpcInfoType.EQUIPPED))
|
||||
{
|
||||
packet.writeD(_summon.getWeapon());
|
||||
packet.writeD(_summon.getArmor()); // Armor id?
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.ALIVE))
|
||||
{
|
||||
packet.writeC(_summon.isDead() ? 0x00 : 0x01);
|
||||
}
|
||||
if (containsMask(NpcInfoType.RUNNING))
|
||||
{
|
||||
packet.writeC(_summon.isRunning() ? 0x01 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.SWIM_OR_FLY))
|
||||
{
|
||||
packet.writeC(_summon.isInsideZone(ZoneId.WATER) ? 0x01 : _summon.isFlying() ? 0x02 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.TEAM))
|
||||
{
|
||||
packet.writeC(_summon.getTeam().getId());
|
||||
}
|
||||
if (containsMask(NpcInfoType.ENCHANT))
|
||||
{
|
||||
packet.writeD(_summon.getTemplate().getWeaponEnchant());
|
||||
}
|
||||
if (containsMask(NpcInfoType.FLYING))
|
||||
{
|
||||
packet.writeD(_summon.isFlying() ? 0x01 : 00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLONE))
|
||||
{
|
||||
packet.writeD(0x00); // Player ObjectId with Decoy
|
||||
}
|
||||
if (containsMask(NpcInfoType.COLOR_EFFECT))
|
||||
{
|
||||
// No visual effect
|
||||
packet.writeD(0x00); // Unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.DISPLAY_EFFECT))
|
||||
{
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.TRANSFORMATION))
|
||||
{
|
||||
packet.writeD(_summon.getTransformationDisplayId()); // Transformation ID
|
||||
}
|
||||
if (containsMask(NpcInfoType.CURRENT_HP))
|
||||
{
|
||||
packet.writeD((int) _summon.getCurrentHp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.CURRENT_MP))
|
||||
{
|
||||
packet.writeD((int) _summon.getCurrentMp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.MAX_HP))
|
||||
{
|
||||
packet.writeD(_summon.getMaxHp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.MAX_MP))
|
||||
{
|
||||
packet.writeD(_summon.getMaxMp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.SUMMONED))
|
||||
{
|
||||
packet.writeC(_summon.isShowSummonAnimation() ? 0x02 : 00); // 2 - do some animation on spawn
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN12))
|
||||
{
|
||||
packet.writeD(0x00);
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME))
|
||||
{
|
||||
packet.writeS(_summon.getName());
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_NPCSTRINGID))
|
||||
{
|
||||
packet.writeD(-1); // NPCStringId for name
|
||||
}
|
||||
if (containsMask(NpcInfoType.TITLE_NPCSTRINGID))
|
||||
{
|
||||
packet.writeD(-1); // NPCStringId for title
|
||||
}
|
||||
if (containsMask(NpcInfoType.PVP_FLAG))
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
packet.writeD(_clanId);
|
||||
packet.writeD(_clanCrest);
|
||||
packet.writeD(_clanLargeCrest);
|
||||
packet.writeD(_allyId);
|
||||
packet.writeD(_allyCrest);
|
||||
}
|
||||
|
||||
if (containsMask(NpcInfoType.VISUAL_STATE))
|
||||
{
|
||||
packet.writeC(_statusMask);
|
||||
}
|
||||
|
||||
if (containsMask(NpcInfoType.ABNORMALS))
|
||||
{
|
||||
packet.writeH(_abnormalVisualEffects.size());
|
||||
for (AbnormalVisualEffect abnormalVisualEffect : _abnormalVisualEffects)
|
||||
{
|
||||
packet.writeH(abnormalVisualEffect.getClientId());
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
/*
|
||||
* This file is part of the L2J Mobius project.
|
||||
*
|
||||
* 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 com.l2jmobius.gameserver.network.serverpackets;
|
||||
|
||||
import java.util.Set;
|
||||
|
||||
import com.l2jmobius.commons.network.PacketWriter;
|
||||
import com.l2jmobius.gameserver.enums.NpcInfoType;
|
||||
import com.l2jmobius.gameserver.enums.Team;
|
||||
import com.l2jmobius.gameserver.model.actor.L2Summon;
|
||||
import com.l2jmobius.gameserver.model.actor.instance.L2PcInstance;
|
||||
import com.l2jmobius.gameserver.model.skills.AbnormalVisualEffect;
|
||||
import com.l2jmobius.gameserver.model.zone.ZoneId;
|
||||
import com.l2jmobius.gameserver.network.OutgoingPackets;
|
||||
|
||||
/**
|
||||
* @author Sdw
|
||||
*/
|
||||
public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
private final L2Summon _summon;
|
||||
private final L2PcInstance _attacker;
|
||||
private final int _val;
|
||||
private final byte[] _masks = new byte[]
|
||||
{
|
||||
(byte) 0x00,
|
||||
(byte) 0x0C,
|
||||
(byte) 0x0C,
|
||||
(byte) 0x00,
|
||||
(byte) 0x00
|
||||
};
|
||||
|
||||
private int _initSize = 0;
|
||||
private int _blockSize = 0;
|
||||
|
||||
private int _clanCrest = 0;
|
||||
private int _clanLargeCrest = 0;
|
||||
private int _allyCrest = 0;
|
||||
private int _allyId = 0;
|
||||
private int _clanId = 0;
|
||||
private int _statusMask = 0;
|
||||
private final String _title;
|
||||
private final Set<AbnormalVisualEffect> _abnormalVisualEffects;
|
||||
|
||||
public SummonInfo(L2Summon summon, L2PcInstance attacker, int val)
|
||||
{
|
||||
_summon = summon;
|
||||
_attacker = attacker;
|
||||
_title = (summon.getOwner() != null) && summon.getOwner().isOnline() ? summon.getOwner().getName() : "";
|
||||
_val = val;
|
||||
_abnormalVisualEffects = summon.getCurrentAbnormalVisualEffects();
|
||||
|
||||
if (summon.getTemplate().getDisplayId() != summon.getTemplate().getId())
|
||||
{
|
||||
_masks[2] |= 0x10;
|
||||
addComponentType(NpcInfoType.NAME);
|
||||
}
|
||||
|
||||
addComponentType(NpcInfoType.ATTACKABLE, NpcInfoType.UNKNOWN1, NpcInfoType.TITLE, NpcInfoType.ID, NpcInfoType.POSITION, NpcInfoType.ALIVE, NpcInfoType.RUNNING);
|
||||
|
||||
if (summon.getHeading() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.HEADING);
|
||||
}
|
||||
|
||||
if ((summon.getStat().getPAtkSpd() > 0) || (summon.getStat().getMAtkSpd() > 0))
|
||||
{
|
||||
addComponentType(NpcInfoType.ATK_CAST_SPEED);
|
||||
}
|
||||
|
||||
if (summon.getRunSpeed() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.SPEED_MULTIPLIER);
|
||||
}
|
||||
|
||||
if ((summon.getWeapon() > 0) || (summon.getArmor() > 0))
|
||||
{
|
||||
addComponentType(NpcInfoType.EQUIPPED);
|
||||
}
|
||||
|
||||
if (summon.getTeam() != Team.NONE)
|
||||
{
|
||||
addComponentType(NpcInfoType.TEAM);
|
||||
}
|
||||
|
||||
if (summon.isInsideZone(ZoneId.WATER) || summon.isFlying())
|
||||
{
|
||||
addComponentType(NpcInfoType.SWIM_OR_FLY);
|
||||
}
|
||||
|
||||
if (summon.isFlying())
|
||||
{
|
||||
addComponentType(NpcInfoType.FLYING);
|
||||
}
|
||||
|
||||
if (summon.getMaxHp() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.MAX_HP);
|
||||
}
|
||||
|
||||
if (summon.getMaxMp() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.MAX_MP);
|
||||
}
|
||||
|
||||
if (summon.getCurrentHp() <= summon.getMaxHp())
|
||||
{
|
||||
addComponentType(NpcInfoType.CURRENT_HP);
|
||||
}
|
||||
|
||||
if (summon.getCurrentMp() <= summon.getMaxMp())
|
||||
{
|
||||
addComponentType(NpcInfoType.CURRENT_MP);
|
||||
}
|
||||
|
||||
if (!_abnormalVisualEffects.isEmpty())
|
||||
{
|
||||
addComponentType(NpcInfoType.ABNORMALS);
|
||||
}
|
||||
|
||||
if (summon.getTemplate().getWeaponEnchant() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.ENCHANT);
|
||||
}
|
||||
|
||||
if (summon.getTransformationDisplayId() > 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.TRANSFORMATION);
|
||||
}
|
||||
|
||||
if (summon.isShowSummonAnimation())
|
||||
{
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
_clanCrest = summon.getOwner().getAppearance().getVisibleClanCrestId();
|
||||
_clanLargeCrest = summon.getOwner().getAppearance().getVisibleClanLargeCrestId();
|
||||
_allyCrest = summon.getOwner().getAppearance().getVisibleAllyId();
|
||||
_allyId = summon.getOwner().getAppearance().getVisibleAllyCrestId();
|
||||
|
||||
addComponentType(NpcInfoType.CLAN);
|
||||
}
|
||||
|
||||
addComponentType(NpcInfoType.COLOR_EFFECT);
|
||||
|
||||
// TODO: Confirm me
|
||||
if (summon.isInCombat())
|
||||
{
|
||||
_statusMask |= 0x01;
|
||||
}
|
||||
if (summon.isDead())
|
||||
{
|
||||
_statusMask |= 0x02;
|
||||
}
|
||||
if (summon.isTargetable())
|
||||
{
|
||||
_statusMask |= 0x04;
|
||||
}
|
||||
|
||||
_statusMask |= 0x08;
|
||||
|
||||
if (_statusMask != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.VISUAL_STATE);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected byte[] getMasks()
|
||||
{
|
||||
return _masks;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onNewMaskAdded(NpcInfoType component)
|
||||
{
|
||||
calcBlockSize(_summon, component);
|
||||
}
|
||||
|
||||
private void calcBlockSize(L2Summon summon, NpcInfoType type)
|
||||
{
|
||||
switch (type)
|
||||
{
|
||||
case ATTACKABLE:
|
||||
case UNKNOWN1:
|
||||
{
|
||||
_initSize += type.getBlockLength();
|
||||
break;
|
||||
}
|
||||
case TITLE:
|
||||
{
|
||||
_initSize += type.getBlockLength() + (_title.length() * 2);
|
||||
break;
|
||||
}
|
||||
case NAME:
|
||||
{
|
||||
_blockSize += type.getBlockLength() + (summon.getName().length() * 2);
|
||||
break;
|
||||
}
|
||||
default:
|
||||
{
|
||||
_blockSize += type.getBlockLength();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean write(PacketWriter packet)
|
||||
{
|
||||
OutgoingPackets.SUMMON_INFO.writeId(packet);
|
||||
|
||||
packet.writeD(_summon.getObjectId());
|
||||
packet.writeC(_val); // 0=teleported 1=default 2=summoned
|
||||
packet.writeH(37); // mask_bits_37
|
||||
packet.writeB(_masks);
|
||||
|
||||
// Block 1
|
||||
packet.writeC(_initSize);
|
||||
|
||||
if (containsMask(NpcInfoType.ATTACKABLE))
|
||||
{
|
||||
packet.writeC(_summon.isAutoAttackable(_attacker) ? 0x01 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN1))
|
||||
{
|
||||
packet.writeD(0x00); // unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.TITLE))
|
||||
{
|
||||
packet.writeS(_title);
|
||||
}
|
||||
|
||||
// Block 2
|
||||
packet.writeH(_blockSize);
|
||||
if (containsMask(NpcInfoType.ID))
|
||||
{
|
||||
packet.writeD(_summon.getTemplate().getDisplayId() + 1000000);
|
||||
}
|
||||
if (containsMask(NpcInfoType.POSITION))
|
||||
{
|
||||
packet.writeD(_summon.getX());
|
||||
packet.writeD(_summon.getY());
|
||||
packet.writeD(_summon.getZ());
|
||||
}
|
||||
if (containsMask(NpcInfoType.HEADING))
|
||||
{
|
||||
packet.writeD(_summon.getHeading());
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN2))
|
||||
{
|
||||
packet.writeD(0x00); // Unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.ATK_CAST_SPEED))
|
||||
{
|
||||
packet.writeD(_summon.getPAtkSpd());
|
||||
packet.writeD(_summon.getMAtkSpd());
|
||||
}
|
||||
if (containsMask(NpcInfoType.SPEED_MULTIPLIER))
|
||||
{
|
||||
packet.writeE((float) _summon.getStat().getMovementSpeedMultiplier());
|
||||
packet.writeE(_summon.getStat().getAttackSpeedMultiplier());
|
||||
}
|
||||
if (containsMask(NpcInfoType.EQUIPPED))
|
||||
{
|
||||
packet.writeD(_summon.getWeapon());
|
||||
packet.writeD(_summon.getArmor()); // Armor id?
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.ALIVE))
|
||||
{
|
||||
packet.writeC(_summon.isDead() ? 0x00 : 0x01);
|
||||
}
|
||||
if (containsMask(NpcInfoType.RUNNING))
|
||||
{
|
||||
packet.writeC(_summon.isRunning() ? 0x01 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.SWIM_OR_FLY))
|
||||
{
|
||||
packet.writeC(_summon.isInsideZone(ZoneId.WATER) ? 0x01 : _summon.isFlying() ? 0x02 : 0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.TEAM))
|
||||
{
|
||||
packet.writeC(_summon.getTeam().getId());
|
||||
}
|
||||
if (containsMask(NpcInfoType.ENCHANT))
|
||||
{
|
||||
packet.writeD(_summon.getTemplate().getWeaponEnchant());
|
||||
}
|
||||
if (containsMask(NpcInfoType.FLYING))
|
||||
{
|
||||
packet.writeD(_summon.isFlying() ? 0x01 : 00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLONE))
|
||||
{
|
||||
packet.writeD(0x00); // Player ObjectId with Decoy
|
||||
}
|
||||
if (containsMask(NpcInfoType.COLOR_EFFECT))
|
||||
{
|
||||
// No visual effect
|
||||
packet.writeD(0x00); // Unknown
|
||||
}
|
||||
if (containsMask(NpcInfoType.DISPLAY_EFFECT))
|
||||
{
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.TRANSFORMATION))
|
||||
{
|
||||
packet.writeD(_summon.getTransformationDisplayId()); // Transformation ID
|
||||
}
|
||||
if (containsMask(NpcInfoType.CURRENT_HP))
|
||||
{
|
||||
packet.writeD((int) _summon.getCurrentHp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.CURRENT_MP))
|
||||
{
|
||||
packet.writeD((int) _summon.getCurrentMp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.MAX_HP))
|
||||
{
|
||||
packet.writeD(_summon.getMaxHp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.MAX_MP))
|
||||
{
|
||||
packet.writeD(_summon.getMaxMp());
|
||||
}
|
||||
if (containsMask(NpcInfoType.SUMMONED))
|
||||
{
|
||||
packet.writeC(_summon.isShowSummonAnimation() ? 0x02 : 00); // 2 - do some animation on spawn
|
||||
}
|
||||
if (containsMask(NpcInfoType.UNKNOWN12))
|
||||
{
|
||||
packet.writeD(0x00);
|
||||
packet.writeD(0x00);
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME))
|
||||
{
|
||||
packet.writeS(_summon.getName());
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_NPCSTRINGID))
|
||||
{
|
||||
packet.writeD(-1); // NPCStringId for name
|
||||
}
|
||||
if (containsMask(NpcInfoType.TITLE_NPCSTRINGID))
|
||||
{
|
||||
packet.writeD(-1); // NPCStringId for title
|
||||
}
|
||||
if (containsMask(NpcInfoType.PVP_FLAG))
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
packet.writeD(_clanId);
|
||||
packet.writeD(_clanCrest);
|
||||
packet.writeD(_clanLargeCrest);
|
||||
packet.writeD(_allyId);
|
||||
packet.writeD(_allyCrest);
|
||||
}
|
||||
|
||||
if (containsMask(NpcInfoType.VISUAL_STATE))
|
||||
{
|
||||
packet.writeC(_statusMask);
|
||||
}
|
||||
|
||||
if (containsMask(NpcInfoType.ABNORMALS))
|
||||
{
|
||||
packet.writeH(_abnormalVisualEffects.size());
|
||||
for (AbnormalVisualEffect abnormalVisualEffect : _abnormalVisualEffects)
|
||||
{
|
||||
packet.writeH(abnormalVisualEffect.getClientId());
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
@ -62,7 +62,7 @@ public enum NpcInfoType implements IUpdateTypeComponent
|
||||
// 4
|
||||
TITLE_NPCSTRINGID(0x20, 4),
|
||||
PVP_FLAG(0x21, 1),
|
||||
NAME_COLOR(0x22, 4),
|
||||
REPUTATION(0x22, 4),
|
||||
CLAN(0x23, (5 * 4)),
|
||||
ABNORMALS(0x24, 0),
|
||||
VISUAL_STATE(0x25, 1);
|
||||
|
@ -191,20 +191,19 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
L2World.getInstance().forEachVisibleObject(this, L2PcInstance.class, player ->
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
return;
|
||||
}
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
player.sendPacket(new ExPetInfo(this, player, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
if (player == getOwner())
|
||||
{
|
||||
player.sendPacket(new PetInfo(this, 1));
|
||||
}
|
||||
else
|
||||
{
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
player.sendPacket(new SummonInfo(this, player, 1));
|
||||
}
|
||||
});
|
||||
}
|
||||
@ -364,6 +363,8 @@ public abstract class L2Summon extends L2Playable
|
||||
|
||||
public void deleteMe(L2PcInstance owner)
|
||||
{
|
||||
super.deleteMe();
|
||||
|
||||
if (owner != null)
|
||||
{
|
||||
owner.sendPacket(new PetDelete(getSummonType(), getObjectId()));
|
||||
@ -372,16 +373,7 @@ public abstract class L2Summon extends L2Playable
|
||||
{
|
||||
party.broadcastToPartyMembers(owner, new ExPartyPetWindowDelete(this));
|
||||
}
|
||||
}
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
if (owner != null)
|
||||
{
|
||||
|
||||
if (isPet())
|
||||
{
|
||||
owner.setPet(null);
|
||||
@ -391,7 +383,13 @@ public abstract class L2Summon extends L2Playable
|
||||
owner.removeServitor(getObjectId());
|
||||
}
|
||||
}
|
||||
super.deleteMe();
|
||||
|
||||
// pet will be deleted along with all his items
|
||||
if (getInventory() != null)
|
||||
{
|
||||
getInventory().destroyAllItems("pet deleted", getOwner(), this);
|
||||
}
|
||||
decayMe();
|
||||
}
|
||||
|
||||
public void unSummon(L2PcInstance owner)
|
||||
@ -842,7 +840,7 @@ public abstract class L2Summon extends L2Playable
|
||||
// Check if the L2PcInstance is the owner of the Pet
|
||||
if (activeChar == getOwner())
|
||||
{
|
||||
activeChar.sendPacket(new PetInfo(this, 1));
|
||||
activeChar.sendPacket(new PetInfo(this, isDead() ? 0 : 1));
|
||||
// The PetInfo packet wipes the PartySpelled (list of active spells' icons). Re-add them
|
||||
updateEffectIcons(true);
|
||||
if (isPet())
|
||||
|
@ -147,6 +147,11 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class ExPetInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
@ -400,7 +400,7 @@ public class NpcInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_npc.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
}
|
||||
|
@ -65,8 +65,11 @@ public class PetInfo implements IClientOutgoingPacket
|
||||
_maxFed = sum.getLifeTime();
|
||||
}
|
||||
|
||||
// _statusMask |= 0x01; // Auto attackable status
|
||||
// _statusMask |= 0x02; // can be chatted with
|
||||
if (summon.isBetrayed())
|
||||
{
|
||||
_statusMask |= 0x01; // Auto attackable status
|
||||
}
|
||||
_statusMask |= 0x02; // can be chatted with
|
||||
|
||||
if (summon.isRunning())
|
||||
{
|
||||
|
@ -147,6 +147,11 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
addComponentType(NpcInfoType.SUMMONED);
|
||||
}
|
||||
|
||||
if (summon.getReputation() != 0)
|
||||
{
|
||||
addComponentType(NpcInfoType.REPUTATION);
|
||||
}
|
||||
|
||||
if (summon.getOwner().getClan() != null)
|
||||
{
|
||||
_clanId = summon.getOwner().getAppearance().getVisibleClanId();
|
||||
@ -366,9 +371,9 @@ public class SummonInfo extends AbstractMaskPacket<NpcInfoType>
|
||||
{
|
||||
packet.writeC(_summon.getPvpFlag()); // PVP flag
|
||||
}
|
||||
if (containsMask(NpcInfoType.NAME_COLOR))
|
||||
if (containsMask(NpcInfoType.REPUTATION))
|
||||
{
|
||||
packet.writeD(0x00); // Name color
|
||||
packet.writeD(_summon.getReputation()); // Name color
|
||||
}
|
||||
if (containsMask(NpcInfoType.CLAN))
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user