mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-12-19 18:34:49 +01:00
Implement map marking features
Teleport still exists on fish hook mark. Added mapMark-related protos. Map marking data is stored in players collection.
This commit is contained in:
@@ -1,17 +1,22 @@
|
||||
package emu.grasscutter.server.packet.recv;
|
||||
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.game.props.EnterReason;
|
||||
import emu.grasscutter.game.world.World;
|
||||
import emu.grasscutter.game.managers.MapMarkManager.MapMark;
|
||||
import emu.grasscutter.game.managers.MapMarkManager.MapMarksManager;
|
||||
import emu.grasscutter.game.player.Player;
|
||||
import emu.grasscutter.net.packet.Opcodes;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.EnterTypeOuterClass.EnterType;
|
||||
import emu.grasscutter.net.proto.MarkMapReqOuterClass.MarkMapReq;
|
||||
import emu.grasscutter.net.proto.OperationOuterClass.Operation;
|
||||
import emu.grasscutter.net.packet.PacketHandler;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.*;
|
||||
import emu.grasscutter.net.proto.MarkMapReqOuterClass.MarkMapReq;
|
||||
import emu.grasscutter.server.game.GameSession;
|
||||
import emu.grasscutter.server.packet.send.PacketPlayerEnterSceneNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketMarkMapRsp;
|
||||
import emu.grasscutter.server.packet.send.PacketMarkNewNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSceneEntityAppearNotify;
|
||||
import emu.grasscutter.utils.Position;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
@Opcodes(PacketOpcodes.MarkMapReq)
|
||||
public class HandlerMarkMapReq extends PacketHandler {
|
||||
@@ -31,25 +36,51 @@ public class HandlerMarkMapReq extends PacketHandler {
|
||||
@Override
|
||||
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||
MarkMapReq req = MarkMapReq.parseFrom(payload);
|
||||
|
||||
if (req.getOp() != MarkMapReq.Operation.ADD) {
|
||||
return;
|
||||
MarkMapReq.Operation op = req.getOp();
|
||||
Player player = session.getPlayer();
|
||||
MapMarksManager mapMarksManager = player.getMapMarksManager();
|
||||
if (op == MarkMapReq.Operation.ADD) {
|
||||
MapMark newMapMark = new MapMark(req.getMark());
|
||||
// keep teleporting functionality on fishhook mark.
|
||||
if (newMapMark.getMapMarkPointType() == MapMarkPointTypeOuterClass.MapMarkPointType.MAP_MARK_POINT_TYPE_FISH_POOL) {
|
||||
teleport(player, newMapMark);
|
||||
return;
|
||||
}
|
||||
if (mapMarksManager.addMapMark(newMapMark)) {
|
||||
player.save();
|
||||
}
|
||||
} else if (op == MarkMapReq.Operation.MOD) {
|
||||
MapMark newMapMark = new MapMark(req.getMark());
|
||||
if (mapMarksManager.removeMapMark(newMapMark.getPosition())) {
|
||||
if (mapMarksManager.addMapMark(newMapMark)) {
|
||||
player.save();
|
||||
}
|
||||
}
|
||||
} else if (op == MarkMapReq.Operation.DEL) {
|
||||
MapMark newMapMark = new MapMark(req.getMark());
|
||||
if (mapMarksManager.removeMapMark(newMapMark.getPosition())) {
|
||||
player.save();
|
||||
}
|
||||
} else if (op == MarkMapReq.Operation.GET) {
|
||||
// no-op
|
||||
}
|
||||
// send all marks to refresh client map view.
|
||||
HashMap<String, MapMark> mapMarks = mapMarksManager.getAllMapMarks();
|
||||
session.send(new PacketMarkMapRsp(player, mapMarks));
|
||||
}
|
||||
|
||||
session.getPlayer().getPos().setX(req.getMark().getPos().getX());
|
||||
session.getPlayer().getPos().setZ(req.getMark().getPos().getZ());
|
||||
|
||||
session.getPlayer().getPos()
|
||||
.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()) {
|
||||
session.getPlayer().getWorld().transferPlayerToScene(session.getPlayer(), req.getMark().getSceneId(),
|
||||
session.getPlayer().getPos());
|
||||
private void teleport(Player player, MapMark mapMark) {
|
||||
// Increased height means you can fly to the top of dragonspine now,
|
||||
// at the cost of slightly longer falling to your destination.
|
||||
float y = 700;
|
||||
float x = mapMark.getPosition().getX();
|
||||
float z = mapMark.getPosition().getZ();
|
||||
player.getPos().set(x, y, z);
|
||||
if (mapMark.getSceneId() != player.getSceneId()) {
|
||||
player.getWorld().transferPlayerToScene(player, mapMark.getSceneId(),
|
||||
player.getPos());
|
||||
} else {
|
||||
session.getPlayer().getScene().broadcastPacket(new PacketSceneEntityAppearNotify(session.getPlayer()));
|
||||
player.getScene().broadcastPacket(new PacketSceneEntityAppearNotify(player));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,43 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.game.managers.MapMarkManager.MapMark;
|
||||
import emu.grasscutter.game.player.Player;
|
||||
import emu.grasscutter.net.packet.BasePacket;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.*;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
public class PacketMarkMapRsp extends BasePacket {
|
||||
|
||||
public PacketMarkMapRsp(Player player, HashMap<String, MapMark> mapMarks) {
|
||||
super(PacketOpcodes.MarkMapRsp);
|
||||
|
||||
MarkMapRspOuterClass.MarkMapRsp.Builder proto = MarkMapRspOuterClass.MarkMapRsp.newBuilder();
|
||||
proto.setRetcode(0);
|
||||
|
||||
if (mapMarks != null) {
|
||||
for (MapMark mapMark: mapMarks.values()) {
|
||||
MapMarkPointOuterClass.MapMarkPoint.Builder markPoint = MapMarkPointOuterClass.MapMarkPoint.newBuilder();
|
||||
markPoint.setSceneId(mapMark.getSceneId());
|
||||
markPoint.setName(mapMark.getName());
|
||||
|
||||
VectorOuterClass.Vector.Builder positionVector = VectorOuterClass.Vector.newBuilder();
|
||||
positionVector.setX(mapMark.getPosition().getX());
|
||||
positionVector.setY(mapMark.getPosition().getY());
|
||||
positionVector.setZ(mapMark.getPosition().getZ());
|
||||
markPoint.setPos(positionVector.build());
|
||||
|
||||
markPoint.setPointType(mapMark.getMapMarkPointType());
|
||||
markPoint.setFromType(mapMark.getMapMarkFromType());
|
||||
markPoint.setMonsterId(mapMark.getMonsterId());
|
||||
markPoint.setQuestId(mapMark.getQuestId());
|
||||
|
||||
proto.addMarkList(markPoint.build());
|
||||
}
|
||||
}
|
||||
|
||||
MarkMapRspOuterClass.MarkMapRsp data = proto.build();
|
||||
this.setData(data);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.game.player.Player;
|
||||
import emu.grasscutter.net.packet.BasePacket;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.*;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class PacketMarkNewNotify extends BasePacket {
|
||||
|
||||
public PacketMarkNewNotify(Player player, int markNewType, ArrayList<Integer> idList) {
|
||||
super(PacketOpcodes.MarkNewNotify);
|
||||
|
||||
MarkNewNotifyOuterClass.MarkNewNotify.Builder proto = MarkNewNotifyOuterClass.MarkNewNotify.newBuilder();
|
||||
proto.setMarkNewType(markNewType);
|
||||
for (Integer id: idList) {
|
||||
proto.addIdList(id);
|
||||
}
|
||||
|
||||
MarkNewNotifyOuterClass.MarkNewNotify data = proto.build();
|
||||
this.setData(data);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user