mirror of
https://github.com/Melledy/Grasscutter.git
synced 2024-11-24 00:11:31 +00:00
Custom Y position on MarkMapReq
This commit is contained in:
parent
4b68031019
commit
e80a14b7dc
@ -15,26 +15,41 @@ import emu.grasscutter.server.packet.send.PacketSceneEntityAppearNotify;
|
|||||||
|
|
||||||
@Opcodes(PacketOpcodes.MarkMapReq)
|
@Opcodes(PacketOpcodes.MarkMapReq)
|
||||||
public class HandlerMarkMapReq extends PacketHandler {
|
public class HandlerMarkMapReq extends PacketHandler {
|
||||||
|
|
||||||
|
private static boolean isInt(String str) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
int x = Integer.parseInt(str);
|
||||||
|
return true; // String is an Integer
|
||||||
|
} catch (NumberFormatException e) {
|
||||||
|
return false; // String is not an Integer
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||||
MarkMapReq req = MarkMapReq.parseFrom(payload);
|
MarkMapReq req = MarkMapReq.parseFrom(payload);
|
||||||
|
|
||||||
if (req.getOp() != Operation.Add) {
|
if (req.getOp() != Operation.Add) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
session.getPlayer().getPos().setX(req.getMark().getPos().getX());
|
session.getPlayer().getPos().setX(req.getMark().getPos().getX());
|
||||||
session.getPlayer().getPos().setZ(req.getMark().getPos().getZ());
|
session.getPlayer().getPos().setZ(req.getMark().getPos().getZ());
|
||||||
session.getPlayer().getPos().setY(300);
|
|
||||||
|
session.getPlayer().getPos()
|
||||||
Grasscutter.getLogger().info("Player [" + session.getPlayer().getUid() + ":" + session.getPlayer().getNickname() + "] tp to " + session.getPlayer().getPos() + " Scene id: " + req.getMark().getSceneId());
|
.setY(isInt(req.getMark().getName()) ? Integer.parseInt(req.getMark().getName()) : 300);
|
||||||
|
|
||||||
|
Grasscutter.getLogger().info("Player [" + session.getPlayer().getUid() + ":" + session.getPlayer().getNickname()
|
||||||
|
+ "] tp to " + session.getPlayer().getPos() + " Scene id: " + req.getMark().getSceneId());
|
||||||
|
|
||||||
if (req.getMark().getSceneId() != session.getPlayer().getSceneId()) {
|
if (req.getMark().getSceneId() != session.getPlayer().getSceneId()) {
|
||||||
session.getPlayer().getWorld().transferPlayerToScene(session.getPlayer(), req.getMark().getSceneId(), session.getPlayer().getPos());
|
session.getPlayer().getWorld().transferPlayerToScene(session.getPlayer(), req.getMark().getSceneId(),
|
||||||
|
session.getPlayer().getPos());
|
||||||
} else {
|
} else {
|
||||||
session.getPlayer().getScene().broadcastPacket(new PacketSceneEntityAppearNotify(session.getPlayer()));
|
session.getPlayer().getScene().broadcastPacket(new PacketSceneEntityAppearNotify(session.getPlayer()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user