zcxv

Легендарный
Проверенный
Победитель в номинации 2015
Сообщения
562
Розыгрыши
0
Репутация
812
Реакции
1 360
Баллы
1 703
Как и обещал ~неделю назад, выкладываю :Kaede:
Подойдет как для люцеры2, так и для исходников на основе люцеры1 (а-ля сборки фокса). Чистой воды костыль.

ValidatePosition.

MoveBackwardToLocation.

Как сделать без костылей?
Клиент шлет каждые 1200 мс. пакет ValidatePosition (за исключением моментов начала и конца движения, там время не нормированно), требуется контроллировать время пакета (с учетом пинга игрока, конечно же). Так же, в большинстве случае, мы успеваем передвинуться на другой геоблок при обычном движении. Контроль не должен быть жестким, возможны некоторые ошибки, поэтому требуется обязательно заводить счетчик ошибок, по которому мы будем делать синхронизацию server -> client (ValidateLocation).
В зависимости от реализации движения, может потребоваться, почти в обязательном порядке, принимать данные о конце передвижения.
Во всяком случае так сделал я, потому-что у меня игрок двигается сервером каждую гео-ячейку, из-за чего возникает небольшая погрешность.
 
Последнее редактирование:
Загляните, верно ли я удалил?
Код:
public class ValidatePosition extends L2GameClientPacket {

    private int _x, _y, _z, _heading;
    private int _data; // vehicle id

    @Override
    protected void readImpl() {
        _x = readD();
        _y = readD();
        _z = readD();
        _heading = readD();
        _data = readD();
    }

    @Override
    protected void runImpl() {

        final L2PcInstance activeChar = getClient().getActiveChar();
        if ((activeChar == null) || activeChar.isTeleporting() || activeChar.inObserverMode()) {
            return;
        }

        final int realX = activeChar.getX();
        final int realY = activeChar.getY();
        int realZ = activeChar.getZ();

        if ((_x == 0) && (_y == 0)) {
            if (realX != 0) {
                return;
            }
        }

        int dx, dy, dz;
        double diffSq;

        /*if (activeChar.isInBoat())
         {
         if (Config.COORD_SYNCHRONIZE == 2)
         {
         dx = _x - activeChar.getInVehiclePosition().getX();
         dy = _y - activeChar.getInVehiclePosition().getY();
         // dz = _z - activeChar.getInVehiclePosition().getZ();
         diffSq = ((dx * dx) + (dy * dy));
         if (diffSq > 250000)
         {
         sendPacket(new GetOnVehicle(activeChar.getObjectId(), _data, activeChar.getInVehiclePosition()));
         }
         }
         return;
         }*/
        if (activeChar.isFalling(_z)) {
            return; // disable validations during fall to avoid "jumping"
        }

        dx = _x - realX;
        dy = _y - realY;
        dz = _z - realZ;
        diffSq = ((dx * dx) + (dy * dy));

        // Zoey76: TODO: Implement or cleanup.
        // L2Party party = activeChar.getParty();
        // if ((party != null) && (activeChar.getLastPartyPositionDistance(_x, _y, _z) > 150))
        // {
        // activeChar.setLastPartyPosition(_x, _y, _z);
        // party.broadcastToPartyMembers(activeChar, new PartyMemberPosition(activeChar));
        // }
        if (activeChar.isFlying() || activeChar.isInWater() || activeChar.isInsideZone(L2Zone.FLAG_WATER)) {
            activeChar.getPosition().setXYZ(realX, realY, _z);
            if (diffSq > 90000) {
                activeChar.sendPacket(new ValidateLocation(activeChar));
            }
        } else if (diffSq < 360000) // if too large, messes observation
        {
            if (Config.COORD_SYNCHRONIZE == -1) // Only Z coordinate synched to server,
            // mainly used when no geodata but can be used also with geodata
            {
                activeChar.getPosition().setXYZ(realX, realY, _z);
                return;
            }
            if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
            {
                if (!activeChar.isMoving() || !activeChar.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
                {
                    // character is not moving, take coordinates from client
                    if (diffSq < 2500) {
                        activeChar.getPosition().setXYZ(realX, realY, _z);
                    } else {
                        activeChar.getPosition().setXYZ(_x, _y, _z);
                    }
                } else {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                }

                activeChar.setHeading(_heading);
                return;
            }
            // Sync 2 (or other),
            // intended for geodata. Sends a validation packet to client
            // when too far from server calculated true coordinate.
            // Due to geodata/zone errors, some Z axis checks are made. (maybe a temporary solution)
            // Important: this code part must work together with L2Character.updatePosition
            if ((diffSq > 250000) || (Math.abs(dz) > 200)) {
                // if ((_z - activeChar.getClientZ()) < 200 && Math.abs(activeChar.getLastServerPosition().getZ()-realZ) > 70)

                if ((Math.abs(dz) > 200) && (Math.abs(dz) < 1500) && (Math.abs(_z - activeChar.getClientZ()) < 800)) {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                    realZ = _z;
                } else {
                    if (Config.DEVELOPER) {
                        _log.info(activeChar.getName() + ": Synchronizing position Server --> Client");
                    }

                    activeChar.sendPacket(new ValidateLocation(activeChar));
                }
            }
        }

        activeChar.setClientX(_x);
        activeChar.setClientY(_y);
        activeChar.setClientZ(_z);
        activeChar.setClientHeading(_heading); // No real need to validate heading.
        activeChar.setLastServerPosition(realX, realY, realZ);
        /*L2PcInstance player = getClient().getActiveChar();
         if (player == null || player.isTeleporting()) {
         return;
         }
         player.checkSummon();
         int realX = player.getX();
         int realY = player.getY();
         int realZ = player.getZ();

         if (_x == 0 && _y == 0) {
         if (realX != 0) {
         return;
         }
         }
         double dx = _x - realX;
         double dy = _y - realY;
         double dz = _z - realZ;
         double diffSq = (dx * dx + dy * dy);

         if (player.getParty() != null && player.canSendPartyPos()) {
         player.setLastPartyPosition(_x, _y, _z);
         player.getParty().broadcastToPartyMembers(player, new PartyMemberPosition(player));
         }

         if (player.isFlying() || player.isInWater()) {
         player.setHeading(_heading);
         player.getPosition().setXYZ(realX, realY, _z);
         if (diffSq > 90000) {
         player.sendPacket(new ValidateLocation(player));
         }
         } else if (diffSq < 360000) // if too large, messes observation
         {
         switch (Config.COORD_SYNCHRONIZE) {
         case 1:
         if (!player.isMoving()
         || !player.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
         {
         // character is not moving, take coordinates from client
         if (diffSq < 2500) // 50*50 - attack won't work fluently if even small differences are corrected
         {
         player.getPosition().setXYZ(realX, realY, _z);
         } else {
         player.getPosition().setXYZ(_x, _y, _z);
         }
         } else {
         player.getPosition().setXYZ(realX, realY, _z);
         }

         player.setHeading(_heading);
         return;
         case 2:
         if (Config.GEODATA > 0 && (diffSq > 250000 || Math.abs(dz) > 200)) {//player.getTemplate().collisionRadius)) {
         //if ((_z - player.getClientZ()) < 200 && Math.abs(player.getLastServerPosition().getZ()-realZ) > 70)

         if (Math.abs(dz) > 200
         && Math.abs(dz) < 1500
         && Math.abs(_z - player.getClientZ()) < 800) {
         player.getPosition().setXYZ(realX, realY, _z);
         realZ = _z;
         } else {
         player.sendPacket(new ValidateLocation(player));
         }
         }
         break;
         default:
         player.getPosition().setXYZ(realX, realY, _z);
         return;
         }
         }

         player.setClientX(_x);
         player.setClientY(_y);
         player.setClientZ(_z);
         player.setClientHeading(_heading); // No real need to validate heading.
         player.setLastServerPosition(realX, realY, realZ);*/
    }
    /*if (Config.COORD_SYNCHRONIZE == -1) // Only Z coordinate synched to server,
     // mainly used when no geodata but can be used also with geodata
     {
     player.getPosition().setXYZ(realX, realY, _z);
     return;
     }
     if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
     {
     if (!player.isMoving()
     || !player.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
     {
     // character is not moving, take coordinates from client
     if (diffSq < 2500) // 50*50 - attack won't work fluently if even small differences are corrected
     {
     player.getPosition().setXYZ(realX, realY, _z);
     } else {
     player.getPosition().setXYZ(_x, _y, _z);
     }
     } else {
     player.getPosition().setXYZ(realX, realY, _z);
     }
   
     player.setHeading(_heading);
     return;
     }*/
    /*if (Config.GEODATA > 0 && (diffSq > 256 || Math.abs(dz) > 200)) {
     player.sendPacket(new ValidateLocation(player));
     }*/
    // Sync 2 (or other),
    // intended for geodata. Sends a validation packet to client
    // when too far from server calculated true coordinate.
    // Due to geodata/zone errors, some Z axis checks are made. (maybe a temporary solution)
    // Important: this code part must work together with L2Character.updatePosition
            /*if (Config.GEODATA > 0 && (diffSq > 250000 || Math.abs(dz) > 200)) {//player.getTemplate().collisionRadius)) {
     //if ((_z - player.getClientZ()) < 200 && Math.abs(player.getLastServerPosition().getZ()-realZ) > 70)
   
     if (Math.abs(dz) > 200
     && Math.abs(dz) < 1500
     && Math.abs(_z - player.getClientZ()) < 800) {
     player.getPosition().setXYZ(realX, realY, _z);
     System.out.println("##runImpl###1##" + diffSq);
     realZ = _z;
     } else {
     System.out.println("##runImpl###2##" + diffSq);
     player.sendPacket(new ValidateLocation(player));
     }
     }*/
}
Код:
public class ValidatePosition extends L2GameClientPacket {

    private int _x, _y, _z, _heading;
    private int _data;

    @Override
    protected void readImpl() {
        _x = readD();
        _y = readD();
        _z = readD();
        _heading = readD();
        _data = readD();
    }

    @Override
    protected void runImpl() {

        final L2PcInstance activeChar = getClient().getActiveChar();
        if ((activeChar == null) || activeChar.isTeleporting() || activeChar.inObserverMode()) {
            return;
        }

        final int realX = activeChar.getX();
        final int realY = activeChar.getY();
        int realZ = activeChar.getZ();

        if ((_x == 0) && (_y == 0)) {
            if (realX != 0) {
                return;
            }
        }

        int dx, dy, dz;
        double diffSq;

        if (activeChar.isFalling(_z)) {
            return;
        }

        dx = _x - realX;
        dy = _y - realY;
        dz = _z - realZ;
        diffSq = ((dx * dx) + (dy * dy));

        if (activeChar.isFlying() || activeChar.isInWater() || activeChar.isInsideZone(L2Zone.FLAG_WATER)) {
            activeChar.getPosition().setXYZ(realX, realY, _z);
            if (diffSq > 90000) {
                activeChar.sendPacket(new ValidateLocation(activeChar));
            }
        } else if (diffSq < 360000)
        {
            if (Config.COORD_SYNCHRONIZE == -1)           
            {
                activeChar.getPosition().setXYZ(realX, realY, _z);
                return;
            }
            if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
            {
                if (!activeChar.isMoving() || !activeChar.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
                {
                    if (diffSq < 2500)
                    {
                        activeChar.getPosition().setXYZ(realX, realY, _z);
                    } else {
                        activeChar.getPosition().setXYZ(_x, _y, _z);
                    }
                } else {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                }

                activeChar.setHeading(_heading);
                return;
            }
           if ((diffSq > 250000) || (Math.abs(dz) > 200))
           {

                if ((Math.abs(dz) > 200) && (Math.abs(dz) < 1500) && (Math.abs(_z - activeChar.getClientZ()) < 800)) {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                    realZ = _z;
                } else {
                    if (Config.DEVELOPER) {
                        _log.info(activeChar.getName() + ": Synchronizing position Server --> Client");
                    }

                    activeChar.sendPacket(new ValidateLocation(activeChar));
                }
            }
        }
    }
}
 
А вот второй файл, чето не шарю че убрать
Код:
package ru.catssoftware.gameserver.network.clientpackets;

import ru.catssoftware.Config;
import ru.catssoftware.gameserver.ai.CtrlIntention;
import ru.catssoftware.gameserver.geodata.GeoData;
import ru.catssoftware.gameserver.instancemanager.ZoneManager;
import ru.catssoftware.gameserver.model.L2CharPosition;
import ru.catssoftware.gameserver.model.Location;
import ru.catssoftware.gameserver.model.actor.instance.L2PcInstance;
import ru.catssoftware.gameserver.model.zone.L2Zone;
import ru.catssoftware.gameserver.network.serverpackets.StopMove;
import ru.catssoftware.gameserver.util.Util;

public final class MoveBackwardToLocation extends L2GameClientPacket {

    private static final String _C__01_MOVEBACKWARDTOLOC = "[C] 01 MoveBackwardToLoc";
    private int _targetX, _targetY, _targetZ;
    private Integer _moveMovement;
    private int _originX;
    private int _originY;
    private int _originZ;

    @Override
    protected void readImpl() {
        _targetX = readD();
        _targetY = readD();
        _targetZ = readD();
        _originX = readD();
        _originY = readD();
        _originZ = readD();
        if (getByteBuffer().remaining() < 4) {
            return;
        }

        _moveMovement = readD();
    }

    @Override
    protected void runImpl() {
        L2PcInstance activeChar = getClient().getActiveChar();

        if (activeChar == null) {
            return;
        }

        if (System.currentTimeMillis() - activeChar.gCPBJ() < 111) {
            activeChar.sendActionFailed();
            return;
        }
        activeChar.sCPBJ();

        if (activeChar.isOutOfControl() || activeChar.isParalyzed()) {
            ActionFailed();
            return;
        }

        if (activeChar.isDead() || activeChar.isFakeDeath()) {
            ActionFailed();
            return;
        }

        // activeChar.sendMessage("##runImpl#1#" + _targetZ + "###");
        activeChar._inWorld = true;

        if (!activeChar.canUseMovePacket()) {
            ActionFailed();
            return;
        }

        if (_moveMovement == null) {
            logPacket(activeChar, "Bot usage for movement by " + activeChar);
            ActionFailed();
            return;
        }
        // activeChar.sendMessage("##runImpl#2#" + _targetZ + "###");
        if (_targetX == _originX && _targetY == _originY && _targetZ == _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }
        if (_targetX == _originX && _targetY == _originY && _targetZ > _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }
        //activeChar.sendMessage("##runImpl#3#" + _targetZ + "###");

        _targetZ += activeChar.getTemplate().getCollisionHeight();

        if (activeChar.isInBoat()) {
            activeChar.setInBoat(false);
        }

        if (activeChar.getTeleMode() > 0) {
            ActionFailed();
            activeChar.teleToLocation(_targetX, _targetY, _targetZ, false);
            return;
        }

        //activeChar.sendMessage("##runImpl#4#" + _targetZ + "##;##" + _originZ);
        if (_targetZ > _originZ && Math.abs(_originZ - _targetZ) > 700) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 700;
            } else {
                ActionFailed();
                return;
            }
        }

        if (Config.UP_LOC_FIX
                && _targetZ > activeChar.getZ()
                && Math.abs(_targetZ - activeChar.getZ()) > 200) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 1;
            } else {
                if (Util.checkIfInShortRadius(100, activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ, false)) {
                    ActionFailed();
                    return;
                }

                if (Math.abs(_targetZ - activeChar.getZ()) > 300 && !GeoData.getInstance().canSeeTarget(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ)) {
                    ActionFailed();
                    return;
                }
            }
        }

        // activeChar.sendMessage("##runImpl#5#" + _targetZ + "###");
        if (_moveMovement == 0) {
            ActionFailed();
            return;
        }

        /*if (!activeChar.canMoveUse()) {
         ActionFailed();
         return;
         }*/
        if (isTooFar(_targetX - activeChar.getX(), _targetY - activeChar.getY())) {
            ActionFailed();
            return;
        }

        if (Config.NPC_DEWALKED_ZONE && activeChar.isInsideZone(L2Zone.FLAG_PEACE)) {
            checkDeWalkedZone(ZoneManager.getCoordInDwZone(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ));
        }

        if (activeChar.isProtected()) {
            activeChar.setProtection(false);
            activeChar.sendMessage("You are no longer protected from aggressive monsters.");
        }

        activeChar.getPosition().setXYZ(_originX, _originY, _originZ);
        activeChar.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new L2CharPosition(_targetX, _targetY, _targetZ, 0));

        /*if (activeChar.getParty() != null) {
         activeChar.getParty().broadcastToPartyMembers(activeChar, new PartyMemberPosition(activeChar));
         }*/
    }

    private boolean isTooFar(double dx, double dy) {
        return (((dx * dx + dy * dy) > 98010000));
    }

    private void checkDeWalkedZone(Location npc_el) {
        if (npc_el == null) {
            return;
        }
        _targetX = npc_el.getX();
        _targetY = npc_el.getY();
        _targetZ = npc_el.getZ();
    }

    @Override
    public String getType() {
        return _C__01_MOVEBACKWARDTOLOC;
    }
}
 
Загляните, верно ли я удалил?
Код:
public class ValidatePosition extends L2GameClientPacket {

    private int _x, _y, _z, _heading;
    private int _data; // vehicle id

    @Override
    protected void readImpl() {
        _x = readD();
        _y = readD();
        _z = readD();
        _heading = readD();
        _data = readD();
    }

    @Override
    protected void runImpl() {

        final L2PcInstance activeChar = getClient().getActiveChar();
        if ((activeChar == null) || activeChar.isTeleporting() || activeChar.inObserverMode()) {
            return;
        }

        final int realX = activeChar.getX();
        final int realY = activeChar.getY();
        int realZ = activeChar.getZ();

        if ((_x == 0) && (_y == 0)) {
            if (realX != 0) {
                return;
            }
        }

        int dx, dy, dz;
        double diffSq;

        /*if (activeChar.isInBoat())
         {
         if (Config.COORD_SYNCHRONIZE == 2)
         {
         dx = _x - activeChar.getInVehiclePosition().getX();
         dy = _y - activeChar.getInVehiclePosition().getY();
         // dz = _z - activeChar.getInVehiclePosition().getZ();
         diffSq = ((dx * dx) + (dy * dy));
         if (diffSq > 250000)
         {
         sendPacket(new GetOnVehicle(activeChar.getObjectId(), _data, activeChar.getInVehiclePosition()));
         }
         }
         return;
         }*/
        if (activeChar.isFalling(_z)) {
            return; // disable validations during fall to avoid "jumping"
        }

        dx = _x - realX;
        dy = _y - realY;
        dz = _z - realZ;
        diffSq = ((dx * dx) + (dy * dy));

        // Zoey76: TODO: Implement or cleanup.
        // L2Party party = activeChar.getParty();
        // if ((party != null) && (activeChar.getLastPartyPositionDistance(_x, _y, _z) > 150))
        // {
        // activeChar.setLastPartyPosition(_x, _y, _z);
        // party.broadcastToPartyMembers(activeChar, new PartyMemberPosition(activeChar));
        // }
        if (activeChar.isFlying() || activeChar.isInWater() || activeChar.isInsideZone(L2Zone.FLAG_WATER)) {
            activeChar.getPosition().setXYZ(realX, realY, _z);
            if (diffSq > 90000) {
                activeChar.sendPacket(new ValidateLocation(activeChar));
            }
        } else if (diffSq < 360000) // if too large, messes observation
        {
            if (Config.COORD_SYNCHRONIZE == -1) // Only Z coordinate synched to server,
            // mainly used when no geodata but can be used also with geodata
            {
                activeChar.getPosition().setXYZ(realX, realY, _z);
                return;
            }
            if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
            {
                if (!activeChar.isMoving() || !activeChar.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
                {
                    // character is not moving, take coordinates from client
                    if (diffSq < 2500) {
                        activeChar.getPosition().setXYZ(realX, realY, _z);
                    } else {
                        activeChar.getPosition().setXYZ(_x, _y, _z);
                    }
                } else {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                }

                activeChar.setHeading(_heading);
                return;
            }
            // Sync 2 (or other),
            // intended for geodata. Sends a validation packet to client
            // when too far from server calculated true coordinate.
            // Due to geodata/zone errors, some Z axis checks are made. (maybe a temporary solution)
            // Important: this code part must work together with L2Character.updatePosition
            if ((diffSq > 250000) || (Math.abs(dz) > 200)) {
                // if ((_z - activeChar.getClientZ()) < 200 && Math.abs(activeChar.getLastServerPosition().getZ()-realZ) > 70)

                if ((Math.abs(dz) > 200) && (Math.abs(dz) < 1500) && (Math.abs(_z - activeChar.getClientZ()) < 800)) {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                    realZ = _z;
                } else {
                    if (Config.DEVELOPER) {
                        _log.info(activeChar.getName() + ": Synchronizing position Server --> Client");
                    }

                    activeChar.sendPacket(new ValidateLocation(activeChar));
                }
            }
        }

        activeChar.setClientX(_x);
        activeChar.setClientY(_y);
        activeChar.setClientZ(_z);
        activeChar.setClientHeading(_heading); // No real need to validate heading.
        activeChar.setLastServerPosition(realX, realY, realZ);
        /*L2PcInstance player = getClient().getActiveChar();
         if (player == null || player.isTeleporting()) {
         return;
         }
         player.checkSummon();
         int realX = player.getX();
         int realY = player.getY();
         int realZ = player.getZ();

         if (_x == 0 && _y == 0) {
         if (realX != 0) {
         return;
         }
         }
         double dx = _x - realX;
         double dy = _y - realY;
         double dz = _z - realZ;
         double diffSq = (dx * dx + dy * dy);

         if (player.getParty() != null && player.canSendPartyPos()) {
         player.setLastPartyPosition(_x, _y, _z);
         player.getParty().broadcastToPartyMembers(player, new PartyMemberPosition(player));
         }

         if (player.isFlying() || player.isInWater()) {
         player.setHeading(_heading);
         player.getPosition().setXYZ(realX, realY, _z);
         if (diffSq > 90000) {
         player.sendPacket(new ValidateLocation(player));
         }
         } else if (diffSq < 360000) // if too large, messes observation
         {
         switch (Config.COORD_SYNCHRONIZE) {
         case 1:
         if (!player.isMoving()
         || !player.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
         {
         // character is not moving, take coordinates from client
         if (diffSq < 2500) // 50*50 - attack won't work fluently if even small differences are corrected
         {
         player.getPosition().setXYZ(realX, realY, _z);
         } else {
         player.getPosition().setXYZ(_x, _y, _z);
         }
         } else {
         player.getPosition().setXYZ(realX, realY, _z);
         }

         player.setHeading(_heading);
         return;
         case 2:
         if (Config.GEODATA > 0 && (diffSq > 250000 || Math.abs(dz) > 200)) {//player.getTemplate().collisionRadius)) {
         //if ((_z - player.getClientZ()) < 200 && Math.abs(player.getLastServerPosition().getZ()-realZ) > 70)

         if (Math.abs(dz) > 200
         && Math.abs(dz) < 1500
         && Math.abs(_z - player.getClientZ()) < 800) {
         player.getPosition().setXYZ(realX, realY, _z);
         realZ = _z;
         } else {
         player.sendPacket(new ValidateLocation(player));
         }
         }
         break;
         default:
         player.getPosition().setXYZ(realX, realY, _z);
         return;
         }
         }

         player.setClientX(_x);
         player.setClientY(_y);
         player.setClientZ(_z);
         player.setClientHeading(_heading); // No real need to validate heading.
         player.setLastServerPosition(realX, realY, realZ);*/
    }
    /*if (Config.COORD_SYNCHRONIZE == -1) // Only Z coordinate synched to server,
     // mainly used when no geodata but can be used also with geodata
     {
     player.getPosition().setXYZ(realX, realY, _z);
     return;
     }
     if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
     {
     if (!player.isMoving()
     || !player.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
     {
     // character is not moving, take coordinates from client
     if (diffSq < 2500) // 50*50 - attack won't work fluently if even small differences are corrected
     {
     player.getPosition().setXYZ(realX, realY, _z);
     } else {
     player.getPosition().setXYZ(_x, _y, _z);
     }
     } else {
     player.getPosition().setXYZ(realX, realY, _z);
     }
  
     player.setHeading(_heading);
     return;
     }*/
    /*if (Config.GEODATA > 0 && (diffSq > 256 || Math.abs(dz) > 200)) {
     player.sendPacket(new ValidateLocation(player));
     }*/
    // Sync 2 (or other),
    // intended for geodata. Sends a validation packet to client
    // when too far from server calculated true coordinate.
    // Due to geodata/zone errors, some Z axis checks are made. (maybe a temporary solution)
    // Important: this code part must work together with L2Character.updatePosition
            /*if (Config.GEODATA > 0 && (diffSq > 250000 || Math.abs(dz) > 200)) {//player.getTemplate().collisionRadius)) {
     //if ((_z - player.getClientZ()) < 200 && Math.abs(player.getLastServerPosition().getZ()-realZ) > 70)
  
     if (Math.abs(dz) > 200
     && Math.abs(dz) < 1500
     && Math.abs(_z - player.getClientZ()) < 800) {
     player.getPosition().setXYZ(realX, realY, _z);
     System.out.println("##runImpl###1##" + diffSq);
     realZ = _z;
     } else {
     System.out.println("##runImpl###2##" + diffSq);
     player.sendPacket(new ValidateLocation(player));
     }
     }*/
}
Код:
public class ValidatePosition extends L2GameClientPacket {

    private int _x, _y, _z, _heading;
    private int _data;

    @Override
    protected void readImpl() {
        _x = readD();
        _y = readD();
        _z = readD();
        _heading = readD();
        _data = readD();
    }

    @Override
    protected void runImpl() {

        final L2PcInstance activeChar = getClient().getActiveChar();
        if ((activeChar == null) || activeChar.isTeleporting() || activeChar.inObserverMode()) {
            return;
        }

        final int realX = activeChar.getX();
        final int realY = activeChar.getY();
        int realZ = activeChar.getZ();

        if ((_x == 0) && (_y == 0)) {
            if (realX != 0) {
                return;
            }
        }

        int dx, dy, dz;
        double diffSq;

        if (activeChar.isFalling(_z)) {
            return;
        }

        dx = _x - realX;
        dy = _y - realY;
        dz = _z - realZ;
        diffSq = ((dx * dx) + (dy * dy));

        if (activeChar.isFlying() || activeChar.isInWater() || activeChar.isInsideZone(L2Zone.FLAG_WATER)) {
            activeChar.getPosition().setXYZ(realX, realY, _z);
            if (diffSq > 90000) {
                activeChar.sendPacket(new ValidateLocation(activeChar));
            }
        } else if (diffSq < 360000)
        {
            if (Config.COORD_SYNCHRONIZE == -1)          
            {
                activeChar.getPosition().setXYZ(realX, realY, _z);
                return;
            }
            if (Config.COORD_SYNCHRONIZE == 1) // Trusting also client x,y coordinates (should not be used with geodata)
            {
                if (!activeChar.isMoving() || !activeChar.validateMovementHeading(_heading)) // Heading changed on client = possible obstacle
                {
                    if (diffSq < 2500)
                    {
                        activeChar.getPosition().setXYZ(realX, realY, _z);
                    } else {
                        activeChar.getPosition().setXYZ(_x, _y, _z);
                    }
                } else {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                }

                activeChar.setHeading(_heading);
                return;
            }
           if ((diffSq > 250000) || (Math.abs(dz) > 200))
           {

                if ((Math.abs(dz) > 200) && (Math.abs(dz) < 1500) && (Math.abs(_z - activeChar.getClientZ()) < 800)) {
                    activeChar.getPosition().setXYZ(realX, realY, _z);
                    realZ = _z;
                } else {
                    if (Config.DEVELOPER) {
                        _log.info(activeChar.getName() + ": Synchronizing position Server --> Client");
                    }

                    activeChar.sendPacket(new ValidateLocation(activeChar));
                }
            }
        }
    }
}

А вот второй файл, чето не шарю че убрать
Код:
package ru.catssoftware.gameserver.network.clientpackets;

import ru.catssoftware.Config;
import ru.catssoftware.gameserver.ai.CtrlIntention;
import ru.catssoftware.gameserver.geodata.GeoData;
import ru.catssoftware.gameserver.instancemanager.ZoneManager;
import ru.catssoftware.gameserver.model.L2CharPosition;
import ru.catssoftware.gameserver.model.Location;
import ru.catssoftware.gameserver.model.actor.instance.L2PcInstance;
import ru.catssoftware.gameserver.model.zone.L2Zone;
import ru.catssoftware.gameserver.network.serverpackets.StopMove;
import ru.catssoftware.gameserver.util.Util;

public final class MoveBackwardToLocation extends L2GameClientPacket {

    private static final String _C__01_MOVEBACKWARDTOLOC = "[C] 01 MoveBackwardToLoc";
    private int _targetX, _targetY, _targetZ;
    private Integer _moveMovement;
    private int _originX;
    private int _originY;
    private int _originZ;

    @Override
    protected void readImpl() {
        _targetX = readD();
        _targetY = readD();
        _targetZ = readD();
        _originX = readD();
        _originY = readD();
        _originZ = readD();
        if (getByteBuffer().remaining() < 4) {
            return;
        }

        _moveMovement = readD();
    }

    @Override
    protected void runImpl() {
        L2PcInstance activeChar = getClient().getActiveChar();

        if (activeChar == null) {
            return;
        }

        if (System.currentTimeMillis() - activeChar.gCPBJ() < 111) {
            activeChar.sendActionFailed();
            return;
        }
        activeChar.sCPBJ();

        if (activeChar.isOutOfControl() || activeChar.isParalyzed()) {
            ActionFailed();
            return;
        }

        if (activeChar.isDead() || activeChar.isFakeDeath()) {
            ActionFailed();
            return;
        }

        // activeChar.sendMessage("##runImpl#1#" + _targetZ + "###");
        activeChar._inWorld = true;

        if (!activeChar.canUseMovePacket()) {
            ActionFailed();
            return;
        }

        if (_moveMovement == null) {
            logPacket(activeChar, "Bot usage for movement by " + activeChar);
            ActionFailed();
            return;
        }
        // activeChar.sendMessage("##runImpl#2#" + _targetZ + "###");
        if (_targetX == _originX && _targetY == _originY && _targetZ == _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }
        if (_targetX == _originX && _targetY == _originY && _targetZ > _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }
        //activeChar.sendMessage("##runImpl#3#" + _targetZ + "###");

        _targetZ += activeChar.getTemplate().getCollisionHeight();

        if (activeChar.isInBoat()) {
            activeChar.setInBoat(false);
        }

        if (activeChar.getTeleMode() > 0) {
            ActionFailed();
            activeChar.teleToLocation(_targetX, _targetY, _targetZ, false);
            return;
        }

        //activeChar.sendMessage("##runImpl#4#" + _targetZ + "##;##" + _originZ);
        if (_targetZ > _originZ && Math.abs(_originZ - _targetZ) > 700) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 700;
            } else {
                ActionFailed();
                return;
            }
        }

        if (Config.UP_LOC_FIX
                && _targetZ > activeChar.getZ()
                && Math.abs(_targetZ - activeChar.getZ()) > 200) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 1;
            } else {
                if (Util.checkIfInShortRadius(100, activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ, false)) {
                    ActionFailed();
                    return;
                }

                if (Math.abs(_targetZ - activeChar.getZ()) > 300 && !GeoData.getInstance().canSeeTarget(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ)) {
                    ActionFailed();
                    return;
                }
            }
        }

        // activeChar.sendMessage("##runImpl#5#" + _targetZ + "###");
        if (_moveMovement == 0) {
            ActionFailed();
            return;
        }

        /*if (!activeChar.canMoveUse()) {
         ActionFailed();
         return;
         }*/
        if (isTooFar(_targetX - activeChar.getX(), _targetY - activeChar.getY())) {
            ActionFailed();
            return;
        }

        if (Config.NPC_DEWALKED_ZONE && activeChar.isInsideZone(L2Zone.FLAG_PEACE)) {
            checkDeWalkedZone(ZoneManager.getCoordInDwZone(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ));
        }

        if (activeChar.isProtected()) {
            activeChar.setProtection(false);
            activeChar.sendMessage("You are no longer protected from aggressive monsters.");
        }

        activeChar.getPosition().setXYZ(_originX, _originY, _originZ);
        activeChar.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new L2CharPosition(_targetX, _targetY, _targetZ, 0));

        /*if (activeChar.getParty() != null) {
         activeChar.getParty().broadcastToPartyMembers(activeChar, new PartyMemberPosition(activeChar));
         }*/
    }

    private boolean isTooFar(double dx, double dy) {
        return (((dx * dx + dy * dy) > 98010000));
    }

    private void checkDeWalkedZone(Location npc_el) {
        if (npc_el == null) {
            return;
        }
        _targetX = npc_el.getX();
        _targetY = npc_el.getY();
        _targetZ = npc_el.getZ();
    }

    @Override
    public String getType() {
        return _C__01_MOVEBACKWARDTOLOC;
    }
}

Код:
public class ValidatePosition extends L2GameClientPacket {

    private int _x, _y, _z, _heading;
    private int _data; // vehicle id

    @Override
    protected void readImpl() {
        _x = readD();
        _y = readD();
        _z = readD();
        _heading = readD();
        _data = readD();
    }

    @Override
    protected void runImpl() {

        final L2PcInstance activeChar = getClient().getActiveChar();
        if ((activeChar == null) || activeChar.isTeleporting() || activeChar.inObserverMode()) {
            return;
        }

        final int realX = activeChar.getX();
        final int realY = activeChar.getY();
        int realZ = activeChar.getZ();

        if ((_x == 0) && (_y == 0)) {
            if (realX != 0) {
                return;
            }
        }

        int dx, dy, dz;
        double diffSq;

        if (activeChar.isFalling(_z)) {
            return; // disable validations during fall to avoid "jumping"
        }

        dx = _x - realX;
        dy = _y - realY;
        dz = _z - realZ;
        diffSq = ((dx * dx) + (dy * dy));

        if (activeChar.isFlying() || activeChar.isInWater() || activeChar.isInsideZone(L2Zone.FLAG_WATER)) {
            if (diffSq > 90000) {
                activeChar.sendPacket(new ValidateLocation(activeChar));
            }
        } else if (diffSq < 360000) // if too large, messes observation
        {
            // Sync 2 (or other),
            // intended for geodata. Sends a validation packet to client
            // when too far from server calculated true coordinate.
            // Due to geodata/zone errors, some Z axis checks are made. (maybe a temporary solution)
            // Important: this code part must work together with L2Character.updatePosition
            if ((diffSq > 250000) || (Math.abs(dz) > 200)) {
                // if ((_z - activeChar.getClientZ()) < 200 && Math.abs(activeChar.getLastServerPosition().getZ()-realZ) > 70)

                if ((Math.abs(dz) > 200) && (Math.abs(dz) < 1500) && (Math.abs(_z - activeChar.getClientZ()) < 800)) {
                    realZ = _z;
                } else {
                    if (Config.DEVELOPER) {
                        _log.info(activeChar.getName() + ": Synchronizing position Server --> Client");
                    }

                    activeChar.sendPacket(new ValidateLocation(activeChar));
                }
            }
        }

        activeChar.setClientX(_x);
        activeChar.setClientY(_y);
        activeChar.setClientZ(_z);
        activeChar.setClientHeading(_heading); // No real need to validate heading.
        activeChar.setLastServerPosition(realX, realY, realZ);
    }
}

Код:
package ru.catssoftware.gameserver.network.clientpackets;

import ru.catssoftware.Config;
import ru.catssoftware.gameserver.ai.CtrlIntention;
import ru.catssoftware.gameserver.geodata.GeoData;
import ru.catssoftware.gameserver.instancemanager.ZoneManager;
import ru.catssoftware.gameserver.model.L2CharPosition;
import ru.catssoftware.gameserver.model.Location;
import ru.catssoftware.gameserver.model.actor.instance.L2PcInstance;
import ru.catssoftware.gameserver.model.zone.L2Zone;
import ru.catssoftware.gameserver.network.serverpackets.StopMove;
import ru.catssoftware.gameserver.util.Util;

public final class MoveBackwardToLocation extends L2GameClientPacket {

    private static final String _C__01_MOVEBACKWARDTOLOC = "[C] 01 MoveBackwardToLoc";
    private int _targetX, _targetY, _targetZ;
    private Integer _moveMovement;
    private int _originX;
    private int _originY;
    private int _originZ;

    @Override
    protected void readImpl() {
        _targetX = readD();
        _targetY = readD();
        _targetZ = readD();
        _originX = readD();
        _originY = readD();
        _originZ = readD();
        if (getByteBuffer().remaining() < 4) {
            return;
        }

        _moveMovement = readD();
    }

    @Override
    protected void runImpl() {
        L2PcInstance activeChar = getClient().getActiveChar();

        if (activeChar == null) {
            return;
        }

        if (System.currentTimeMillis() - activeChar.gCPBJ() < 111) {
            activeChar.sendActionFailed();
            return;
        }
        activeChar.sCPBJ();

        if (activeChar.isOutOfControl() || activeChar.isParalyzed()) {
            ActionFailed();
            return;
        }

        if (activeChar.isDead() || activeChar.isFakeDeath()) {
            ActionFailed();
            return;
        }

        activeChar._inWorld = true;

        if (!activeChar.canUseMovePacket()) {
            ActionFailed();
            return;
        }

        if (_moveMovement == null) {
            logPacket(activeChar, "Bot usage for movement by " + activeChar);
            ActionFailed();
            return;
        }
        
        if (_targetX == _originX && _targetY == _originY && _targetZ == _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }
        if (_targetX == _originX && _targetY == _originY && _targetZ > _originZ) {
            ActionFailed();
            activeChar.sendPacket(new StopMove(activeChar));
            return;
        }

        _targetZ += activeChar.getTemplate().getCollisionHeight();

        if (activeChar.isInBoat()) {
            activeChar.setInBoat(false);
        }

        if (activeChar.getTeleMode() > 0) {
            ActionFailed();
            activeChar.teleToLocation(_targetX, _targetY, _targetZ, false);
            return;
        }

        if (_targetZ > _originZ && Math.abs(_originZ - _targetZ) > 700) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 700;
            } else {
                ActionFailed();
                return;
            }
        }

        if (Config.UP_LOC_FIX
                && _targetZ > activeChar.getZ()
                && Math.abs(_targetZ - activeChar.getZ()) > 200) {
            if (activeChar.isFlying() || activeChar.isInWater()) {
                _targetZ += 1;
            } else {
                if (Util.checkIfInShortRadius(100, activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ, false)) {
                    ActionFailed();
                    return;
                }

                if (Math.abs(_targetZ - activeChar.getZ()) > 300 && !GeoData.getInstance().canSeeTarget(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ)) {
                    ActionFailed();
                    return;
                }
            }
        }

        if (_moveMovement == 0) {
            ActionFailed();
            return;
        }

        if (isTooFar(_targetX - activeChar.getX(), _targetY - activeChar.getY())) {
            ActionFailed();
            return;
        }

        if (Config.NPC_DEWALKED_ZONE && activeChar.isInsideZone(L2Zone.FLAG_PEACE)) {
            checkDeWalkedZone(ZoneManager.getCoordInDwZone(activeChar.getX(), activeChar.getY(), activeChar.getZ(), _targetX, _targetY, _targetZ));
        }

        if (activeChar.isProtected()) {
            activeChar.setProtection(false);
            activeChar.sendMessage("You are no longer protected from aggressive monsters.");
        }

        activeChar.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new L2CharPosition(_targetX, _targetY, _targetZ, 0));
    }

    private boolean isTooFar(double dx, double dy) {
        return (((dx * dx + dy * dy) > 98010000));
    }

    private void checkDeWalkedZone(Location npc_el) {
        if (npc_el == null) {
            return;
        }
        _targetX = npc_el.getX();
        _targetY = npc_el.getY();
        _targetZ = npc_el.getZ();
    }

    @Override
    public String getType() {
        return _C__01_MOVEBACKWARDTOLOC;
    }
}

В следующий раз я этого делать не буду. Все описано в первом посте.
 

Похожие темы

Ответы
0
Просмотры
Ответы
5
Просмотры
Ответы
2
Просмотры
Назад
Сверху Снизу