mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-12-17 09:25:06 +01:00
Merge branch 'dev-scene'
This commit is contained in:
@@ -104,21 +104,25 @@ public final class GameServer extends MihoyoKcpServer {
|
||||
}
|
||||
|
||||
public void registerPlayer(GenshinPlayer player) {
|
||||
getPlayers().put(player.getId(), player);
|
||||
getPlayers().put(player.getUid(), player);
|
||||
}
|
||||
|
||||
public GenshinPlayer getPlayerById(int id) {
|
||||
return this.getPlayers().get(id);
|
||||
public GenshinPlayer getPlayerByUid(int id) {
|
||||
return this.getPlayerByUid(id, false);
|
||||
}
|
||||
|
||||
public GenshinPlayer forceGetPlayerById(int id) {
|
||||
public GenshinPlayer getPlayerByUid(int id, boolean allowOfflinePlayers) {
|
||||
// Console check
|
||||
if (id == GenshinConstants.SERVER_CONSOLE_UID) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// Get from online players
|
||||
GenshinPlayer player = this.getPlayerById(id);
|
||||
GenshinPlayer player = this.getPlayerByUid(id);
|
||||
|
||||
if (!allowOfflinePlayers) {
|
||||
return player;
|
||||
}
|
||||
|
||||
// Check database if character isnt here
|
||||
if (player == null) {
|
||||
@@ -128,9 +132,9 @@ public final class GameServer extends MihoyoKcpServer {
|
||||
return player;
|
||||
}
|
||||
|
||||
public SocialDetail.Builder getSocialDetailById(int id) {
|
||||
public SocialDetail.Builder getSocialDetailByUid(int id) {
|
||||
// Get from online players
|
||||
GenshinPlayer player = this.forceGetPlayerById(id);
|
||||
GenshinPlayer player = this.getPlayerByUid(id, true);
|
||||
|
||||
if (player == null) {
|
||||
return null;
|
||||
|
||||
@@ -123,7 +123,7 @@ public class GameSession extends MihoyoKcpChannel {
|
||||
// Save
|
||||
getPlayer().onLogout();
|
||||
// Remove from gameserver
|
||||
getServer().getPlayers().remove(getPlayer().getId());
|
||||
getServer().getPlayers().remove(getPlayer().getUid());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -14,8 +14,8 @@ public class HandlerChangeGameTimeReq extends PacketHandler {
|
||||
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||
ChangeGameTimeReq req = ChangeGameTimeReq.parseFrom(payload);
|
||||
|
||||
session.getPlayer().getWorld().changeTime(req.getGameTime());
|
||||
session.getPlayer().sendPacket(new PacketChangeGameTimeRsp(session.getPlayer().getWorld()));
|
||||
session.getPlayer().getScene().changeTime(req.getGameTime());
|
||||
session.getPlayer().sendPacket(new PacketChangeGameTimeRsp(session.getPlayer()));
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -22,12 +22,12 @@ public class HandlerCombatInvocationsNotify extends PacketHandler {
|
||||
case CombatEvtBeingHit:
|
||||
// Handle damage
|
||||
EvtBeingHitInfo hitInfo = EvtBeingHitInfo.parseFrom(entry.getCombatData());
|
||||
session.getPlayer().getWorld().handleAttack(hitInfo.getAttackResult());
|
||||
session.getPlayer().getScene().handleAttack(hitInfo.getAttackResult());
|
||||
break;
|
||||
case EntityMove:
|
||||
// Handle movement
|
||||
EntityMoveInfo moveInfo = EntityMoveInfo.parseFrom(entry.getCombatData());
|
||||
GenshinEntity entity = session.getPlayer().getWorld().getEntityById(moveInfo.getEntityId());
|
||||
GenshinEntity entity = session.getPlayer().getScene().getEntityById(moveInfo.getEntityId());
|
||||
if (entity != null) {
|
||||
entity.getPosition().set(moveInfo.getMotionInfo().getPos());
|
||||
entity.getRotation().set(moveInfo.getMotionInfo().getRot());
|
||||
|
||||
@@ -24,10 +24,10 @@ public class HandlerEnterSceneDoneReq extends PacketHandler {
|
||||
session.send(new PacketPlayerTimeNotify(session.getPlayer())); // Probably not the right place
|
||||
|
||||
// Spawn player in world
|
||||
session.getPlayer().getWorld().spawnPlayer(session.getPlayer());
|
||||
session.getPlayer().getScene().spawnPlayer(session.getPlayer());
|
||||
|
||||
// Spawn other entites already in world
|
||||
session.getPlayer().getWorld().showOtherEntities(session.getPlayer());
|
||||
session.getPlayer().getScene().showOtherEntities(session.getPlayer());
|
||||
|
||||
// Locations
|
||||
session.send(new PacketWorldPlayerLocationNotify(session.getPlayer().getWorld()));
|
||||
|
||||
@@ -15,7 +15,7 @@ public class HandlerEntityAiSyncNotify extends PacketHandler {
|
||||
EntityAiSyncNotify notify = EntityAiSyncNotify.parseFrom(payload);
|
||||
|
||||
if (notify.getLocalAvatarAlertedMonsterListCount() > 0) {
|
||||
session.getPlayer().getWorld().broadcastPacket(new PacketEntityAiSyncNotify(notify));
|
||||
session.getPlayer().getScene().broadcastPacket(new PacketEntityAiSyncNotify(notify));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -20,13 +20,13 @@ public class HandlerEvtCreateGadgetNotify extends PacketHandler {
|
||||
}
|
||||
|
||||
// Sanity check - dont add duplicate entities
|
||||
if (session.getPlayer().getWorld().getEntityById(notify.getEntityId()) != null) {
|
||||
if (session.getPlayer().getScene().getEntityById(notify.getEntityId()) != null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Create entity and summon in world
|
||||
EntityClientGadget gadget = new EntityClientGadget(session.getPlayer().getWorld(), session.getPlayer(), notify);
|
||||
session.getPlayer().getWorld().onPlayerCreateGadget(gadget);
|
||||
EntityClientGadget gadget = new EntityClientGadget(session.getPlayer().getScene(), session.getPlayer(), notify);
|
||||
session.getPlayer().getScene().onPlayerCreateGadget(gadget);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -18,7 +18,7 @@ public class HandlerEvtDestroyGadgetNotify extends PacketHandler {
|
||||
return;
|
||||
}
|
||||
|
||||
session.getPlayer().getWorld().onPlayerDestroyGadget(notify.getEntityId());
|
||||
session.getPlayer().getScene().onPlayerDestroyGadget(notify.getEntityId());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -15,7 +15,7 @@ public class HandlerGetPlayerSocialDetailReq extends PacketHandler {
|
||||
public void handle(GameSession session, byte[] header, byte[] payload) throws Exception {
|
||||
GetPlayerSocialDetailReq req = GetPlayerSocialDetailReq.parseFrom(payload);
|
||||
|
||||
SocialDetail.Builder detail = session.getServer().getSocialDetailById(req.getUid());
|
||||
SocialDetail.Builder detail = session.getServer().getSocialDetailByUid(req.getUid());
|
||||
|
||||
if (detail != null) {
|
||||
detail.setIsFriend(session.getPlayer().getFriendsList().isFriendsWith(req.getUid()));
|
||||
|
||||
@@ -1,12 +1,16 @@
|
||||
package emu.grasscutter.server.packet.recv;
|
||||
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.game.World;
|
||||
import emu.grasscutter.game.props.EnterReason;
|
||||
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.server.game.GameSession;
|
||||
import emu.grasscutter.server.packet.send.PacketPlayerEnterSceneNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSceneEntityAppearNotify;
|
||||
|
||||
@Opcodes(PacketOpcodes.MarkMapReq)
|
||||
@@ -19,14 +23,18 @@ public class HandlerMarkMapReq extends PacketHandler {
|
||||
if (req.getOp() != Operation.Add) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
session.getPlayer().getPos().setX(req.getMark().getPos().getX());
|
||||
session.getPlayer().getPos().setZ(req.getMark().getPos().getZ());
|
||||
session.getPlayer().getPos().setY(300);
|
||||
|
||||
Grasscutter.getLogger().info("Player [" + session.getPlayer().getId() + ":" + session.getPlayer().getNickname() + "] tp to " + session.getPlayer().getPos());
|
||||
Grasscutter.getLogger().info("Player [" + session.getPlayer().getUid() + ":" + session.getPlayer().getNickname() + "] tp to " + session.getPlayer().getPos() + " Scene id: " + req.getMark().getSceneId());
|
||||
|
||||
session.getPlayer().getWorld().broadcastPacket(new PacketSceneEntityAppearNotify(session.getPlayer()));
|
||||
if (req.getMark().getSceneId() != session.getPlayer().getSceneId()) {
|
||||
session.getPlayer().getWorld().transferPlayerToScene(session.getPlayer(), req.getMark().getSceneId(), session.getPlayer().getPos());
|
||||
} else {
|
||||
session.getPlayer().getScene().broadcastPacket(new PacketSceneEntityAppearNotify(session.getPlayer()));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -14,6 +14,7 @@ import emu.grasscutter.server.packet.send.PacketSceneInitFinishRsp;
|
||||
import emu.grasscutter.server.packet.send.PacketScenePlayerInfoNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSceneTeamUpdateNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSceneTimeNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSceneUnlockInfoNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketServerTimeNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSyncScenePlayTeamEntityNotify;
|
||||
import emu.grasscutter.server.packet.send.PacketSyncTeamEntityNotify;
|
||||
@@ -29,13 +30,14 @@ public class HandlerSceneInitFinishReq extends PacketHandler {
|
||||
session.send(new PacketServerTimeNotify());
|
||||
session.send(new PacketWorldPlayerInfoNotify(session.getPlayer().getWorld()));
|
||||
session.send(new PacketWorldDataNotify(session.getPlayer().getWorld()));
|
||||
session.send(new PacketSceneUnlockInfoNotify());
|
||||
session.send(new GenshinPacket(PacketOpcodes.SceneForceUnlockNotify));
|
||||
session.send(new PacketHostPlayerNotify(session.getPlayer().getWorld()));
|
||||
|
||||
session.send(new PacketSceneTimeNotify(session.getPlayer()));
|
||||
session.send(new PacketPlayerGameTimeNotify(session.getPlayer().getWorld(), session.getPlayer()));
|
||||
session.send(new PacketPlayerGameTimeNotify(session.getPlayer()));
|
||||
session.send(new PacketPlayerEnterSceneInfoNotify(session.getPlayer()));
|
||||
session.send(new PacketSceneAreaWeatherNotify(session.getPlayer().getWorld(), session.getPlayer()));
|
||||
session.send(new PacketSceneAreaWeatherNotify(session.getPlayer()));
|
||||
session.send(new PacketScenePlayerInfoNotify(session.getPlayer().getWorld()));
|
||||
session.send(new PacketSceneTeamUpdateNotify(session.getPlayer()));
|
||||
|
||||
|
||||
@@ -57,7 +57,7 @@ public class HandlerSetPlayerBornDataReq extends PacketHandler {
|
||||
}
|
||||
|
||||
// Save account
|
||||
session.getAccount().setPlayerId(player.getId());
|
||||
session.getAccount().setPlayerId(player.getUid());
|
||||
session.getAccount().save();
|
||||
|
||||
// Set character
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.game.GenshinPlayer;
|
||||
import emu.grasscutter.game.World;
|
||||
import emu.grasscutter.net.packet.GenshinPacket;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
@@ -7,11 +8,11 @@ import emu.grasscutter.net.proto.ChangeGameTimeRspOuterClass.ChangeGameTimeRsp;
|
||||
|
||||
public class PacketChangeGameTimeRsp extends GenshinPacket {
|
||||
|
||||
public PacketChangeGameTimeRsp(World world) {
|
||||
public PacketChangeGameTimeRsp(GenshinPlayer player) {
|
||||
super(PacketOpcodes.ChangeGameTimeRsp);
|
||||
|
||||
ChangeGameTimeRsp proto = ChangeGameTimeRsp.newBuilder()
|
||||
.setCurGameTime(world.getTime())
|
||||
.setCurGameTime(player.getScene().getTime())
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
|
||||
@@ -14,7 +14,7 @@ public class PacketGetPlayerAskFriendListRsp extends GenshinPacket {
|
||||
GetPlayerAskFriendListRsp.Builder proto = GetPlayerAskFriendListRsp.newBuilder();
|
||||
|
||||
for (Friendship friendship : player.getFriendsList().getPendingFriends().values()) {
|
||||
if (friendship.getAskerId() == player.getId()) {
|
||||
if (friendship.getAskerId() == player.getUid()) {
|
||||
continue;
|
||||
}
|
||||
proto.addAskFriendList(friendship.toProto());
|
||||
|
||||
@@ -37,7 +37,7 @@ public class PacketGetPlayerFriendListRsp extends GenshinPacket {
|
||||
proto.addFriendList(friendship.toProto());
|
||||
}
|
||||
for (Friendship friendship : player.getFriendsList().getPendingFriends().values()) {
|
||||
if (friendship.getAskerId() == player.getId()) {
|
||||
if (friendship.getAskerId() == player.getUid()) {
|
||||
continue;
|
||||
}
|
||||
proto.addAskFriendList(friendship.toProto());
|
||||
|
||||
@@ -16,8 +16,8 @@ public class PacketGetSceneAreaRsp extends GenshinPacket {
|
||||
this.buildHeader(0);
|
||||
|
||||
GetSceneAreaRsp p = GetSceneAreaRsp.newBuilder()
|
||||
.setSceneId(3)
|
||||
.addAllAreaIdList(Arrays.stream(new int[] {1,2,3,4,5,6,7,8,9,10,11,12,13,14,17,18,19}).boxed().collect(Collectors.toList()))
|
||||
.setSceneId(sceneId)
|
||||
.addAllAreaIdList(Arrays.stream(new int[] {1,2,3,4,5,6,7,8,9,10,11,12,13,14,17,18,19,100,101,102,103,200,210,300}).boxed().collect(Collectors.toList()))
|
||||
.addCityInfoList(CityInfo.newBuilder().setCityId(1).setLevel(1).build())
|
||||
.addCityInfoList(CityInfo.newBuilder().setCityId(2).setLevel(1).build())
|
||||
.addCityInfoList(CityInfo.newBuilder().setCityId(3).setLevel(1).build())
|
||||
|
||||
@@ -11,7 +11,7 @@ public class PacketHostPlayerNotify extends GenshinPacket {
|
||||
super(PacketOpcodes.HostPlayerNotify);
|
||||
|
||||
HostPlayerNotify proto = HostPlayerNotify.newBuilder()
|
||||
.setHostUid(world.getHost().getId())
|
||||
.setHostUid(world.getHost().getUid())
|
||||
.setHostPeerId(world.getHost().getPeerId())
|
||||
.build();
|
||||
|
||||
|
||||
@@ -12,7 +12,7 @@ public class PacketPlayerApplyEnterMpResultNotify extends GenshinPacket {
|
||||
super(PacketOpcodes.PlayerApplyEnterMpResultNotify);
|
||||
|
||||
PlayerApplyEnterMpResultNotify proto = PlayerApplyEnterMpResultNotify.newBuilder()
|
||||
.setTargetUid(target.getId())
|
||||
.setTargetUid(target.getUid())
|
||||
.setTargetNickname(target.getNickname())
|
||||
.setIsAgreed(isAgreed)
|
||||
.setReason(reason)
|
||||
|
||||
@@ -14,7 +14,7 @@ public class PacketPlayerChatNotify extends GenshinPacket {
|
||||
|
||||
ChatInfo info = ChatInfo.newBuilder()
|
||||
.setTime((int) (System.currentTimeMillis() / 1000))
|
||||
.setUid(sender.getId())
|
||||
.setUid(sender.getUid())
|
||||
.setText(message)
|
||||
.build();
|
||||
|
||||
@@ -31,7 +31,7 @@ public class PacketPlayerChatNotify extends GenshinPacket {
|
||||
|
||||
ChatInfo info = ChatInfo.newBuilder()
|
||||
.setTime((int) (System.currentTimeMillis() / 1000))
|
||||
.setUid(sender.getId())
|
||||
.setUid(sender.getUid())
|
||||
.setIcon(emote)
|
||||
.build();
|
||||
|
||||
@@ -48,7 +48,7 @@ public class PacketPlayerChatNotify extends GenshinPacket {
|
||||
|
||||
ChatInfo info = ChatInfo.newBuilder()
|
||||
.setTime((int) (System.currentTimeMillis() / 1000))
|
||||
.setUid(sender.getId())
|
||||
.setUid(sender.getUid())
|
||||
.setSystemHint(systemHint)
|
||||
.build();
|
||||
|
||||
|
||||
@@ -24,17 +24,13 @@ public class PacketPlayerEnterSceneNotify extends GenshinPacket {
|
||||
.setPos(player.getPos().toProto())
|
||||
.setSceneBeginTime(System.currentTimeMillis())
|
||||
.setType(EnterType.EnterSelf)
|
||||
.setTargetUid(player.getId())
|
||||
.setTargetUid(player.getUid())
|
||||
.setEnterSceneToken(player.getEnterSceneToken())
|
||||
.setWorldLevel(player.getWorldLevel())
|
||||
.setEnterReason(EnterReason.Login.getValue())
|
||||
.setIsFirstLoginEnterScene(player.isFirstLoginEnterScene())
|
||||
.addSceneTagIdList(102)
|
||||
.addSceneTagIdList(107)
|
||||
.addSceneTagIdList(113)
|
||||
.addSceneTagIdList(117)
|
||||
.setUnk1(1)
|
||||
.setUnk2("3-" + player.getId() + "-" + (int) (System.currentTimeMillis() / 1000) + "-" + 18402)
|
||||
.setUnk2("3-" + player.getUid() + "-" + (int) (System.currentTimeMillis() / 1000) + "-" + 18402)
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
@@ -57,7 +53,7 @@ public class PacketPlayerEnterSceneNotify extends GenshinPacket {
|
||||
.setPos(newPos.toProto())
|
||||
.setSceneBeginTime(System.currentTimeMillis())
|
||||
.setType(EnterType.EnterSelf)
|
||||
.setTargetUid(target.getId())
|
||||
.setTargetUid(target.getUid())
|
||||
.setEnterSceneToken(player.getEnterSceneToken())
|
||||
.setWorldLevel(target.getWorld().getWorldLevel())
|
||||
.setEnterReason(reason.getValue())
|
||||
@@ -66,7 +62,7 @@ public class PacketPlayerEnterSceneNotify extends GenshinPacket {
|
||||
.addSceneTagIdList(113)
|
||||
.addSceneTagIdList(117)
|
||||
.setUnk1(1)
|
||||
.setUnk2(newScene + "-" + target.getId() + "-" + (int) (System.currentTimeMillis() / 1000) + "-" + 18402)
|
||||
.setUnk2(newScene + "-" + target.getUid() + "-" + (int) (System.currentTimeMillis() / 1000) + "-" + 18402)
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
|
||||
@@ -8,12 +8,12 @@ import emu.grasscutter.net.proto.PlayerGameTimeNotifyOuterClass.PlayerGameTimeNo
|
||||
|
||||
public class PacketPlayerGameTimeNotify extends GenshinPacket {
|
||||
|
||||
public PacketPlayerGameTimeNotify(World world, GenshinPlayer player) {
|
||||
public PacketPlayerGameTimeNotify(GenshinPlayer player) {
|
||||
super(PacketOpcodes.PlayerGameTimeNotify);
|
||||
|
||||
PlayerGameTimeNotify proto = PlayerGameTimeNotify.newBuilder()
|
||||
.setGameTime(world.getTime())
|
||||
.setUid(player.getId())
|
||||
.setGameTime(player.getScene().getTime())
|
||||
.setUid(player.getUid())
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.GenshinConstants;
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.game.GenshinPlayer;
|
||||
import emu.grasscutter.game.inventory.GenshinItem;
|
||||
import emu.grasscutter.net.packet.GenshinPacket;
|
||||
@@ -18,7 +19,7 @@ public class PacketPlayerStoreNotify extends GenshinPacket {
|
||||
|
||||
PlayerStoreNotify.Builder p = PlayerStoreNotify.newBuilder()
|
||||
.setStoreType(StoreType.StorePack)
|
||||
.setWeightLimit(GenshinConstants.LIMIT_ALL);
|
||||
.setWeightLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitAll);
|
||||
|
||||
for (GenshinItem item : player.getInventory()) {
|
||||
Item itemProto = item.toProto();
|
||||
|
||||
@@ -21,7 +21,7 @@ public class PacketPullRecentChatRsp extends GenshinPacket {
|
||||
ChatInfo welcomeEmote = ChatInfo.newBuilder()
|
||||
.setTime((int) (System.currentTimeMillis() / 1000))
|
||||
.setUid(GenshinConstants.SERVER_CONSOLE_UID)
|
||||
.setToUid(player.getId())
|
||||
.setToUid(player.getUid())
|
||||
.setIcon(serverOptions.WelcomeEmotes[Utils.randomRange(0, serverOptions.WelcomeEmotes.length - 1)])
|
||||
.build();
|
||||
|
||||
@@ -32,7 +32,7 @@ public class PacketPullRecentChatRsp extends GenshinPacket {
|
||||
ChatInfo welcomeMotd = ChatInfo.newBuilder()
|
||||
.setTime((int) (System.currentTimeMillis() / 1000))
|
||||
.setUid(GenshinConstants.SERVER_CONSOLE_UID)
|
||||
.setToUid(player.getId())
|
||||
.setToUid(player.getUid())
|
||||
.setText(Grasscutter.getConfig().getServerOptions().WelcomeMotd)
|
||||
.build();
|
||||
|
||||
|
||||
@@ -8,12 +8,12 @@ import emu.grasscutter.net.proto.SceneAreaWeatherNotifyOuterClass.SceneAreaWeath
|
||||
|
||||
public class PacketSceneAreaWeatherNotify extends GenshinPacket {
|
||||
|
||||
public PacketSceneAreaWeatherNotify(World world, GenshinPlayer player) {
|
||||
public PacketSceneAreaWeatherNotify(GenshinPlayer player) {
|
||||
super(PacketOpcodes.SceneAreaWeatherNotify);
|
||||
|
||||
SceneAreaWeatherNotify proto = SceneAreaWeatherNotify.newBuilder()
|
||||
.setWeatherAreaId(1)
|
||||
.setClimateType(world.getClimate().getValue())
|
||||
.setClimateType(player.getScene().getClimate().getValue())
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
|
||||
@@ -18,10 +18,10 @@ public class PacketScenePlayerInfoNotify extends GenshinPacket {
|
||||
GenshinPlayer p = world.getPlayers().get(i);
|
||||
|
||||
ScenePlayerInfo pInfo = ScenePlayerInfo.newBuilder()
|
||||
.setUid(p.getId())
|
||||
.setUid(p.getUid())
|
||||
.setPeerId(p.getPeerId())
|
||||
.setName(p.getNickname())
|
||||
.setSceneId(world.getSceneId())
|
||||
.setSceneId(p.getSceneId())
|
||||
.setOnlinePlayerInfo(p.getOnlinePlayerInfo())
|
||||
.build();
|
||||
|
||||
|
||||
@@ -19,7 +19,7 @@ public class PacketSceneTeamUpdateNotify extends GenshinPacket {
|
||||
for (GenshinPlayer p : player.getWorld().getPlayers()) {
|
||||
for (EntityAvatar entityAvatar : p.getTeamManager().getActiveTeam()) {
|
||||
SceneTeamAvatar.Builder avatarProto = SceneTeamAvatar.newBuilder()
|
||||
.setPlayerId(p.getId())
|
||||
.setPlayerId(p.getUid())
|
||||
.setAvatarGuid(entityAvatar.getAvatar().getGuid())
|
||||
.setSceneId(p.getSceneId())
|
||||
.setEntityId(entityAvatar.getId())
|
||||
|
||||
@@ -0,0 +1,24 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.net.packet.GenshinPacket;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.SceneUnlockInfoNotifyOuterClass.SceneUnlockInfoNotify;
|
||||
import emu.grasscutter.net.proto.SceneUnlockInfoOuterClass.SceneUnlockInfo;
|
||||
|
||||
public class PacketSceneUnlockInfoNotify extends GenshinPacket {
|
||||
|
||||
public PacketSceneUnlockInfoNotify() {
|
||||
super(PacketOpcodes.SceneUnlockInfoNotify); // Rename opcode later
|
||||
|
||||
SceneUnlockInfoNotify proto = SceneUnlockInfoNotify.newBuilder()
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(1))
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(3))
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(4))
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(5))
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(6))
|
||||
.addUnlockInfos(SceneUnlockInfo.newBuilder().setSceneId(7))
|
||||
.build();
|
||||
|
||||
this.setData(proto);
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
package emu.grasscutter.server.packet.send;
|
||||
|
||||
import emu.grasscutter.GenshinConstants;
|
||||
import emu.grasscutter.Grasscutter;
|
||||
import emu.grasscutter.net.packet.GenshinPacket;
|
||||
import emu.grasscutter.net.packet.PacketOpcodes;
|
||||
import emu.grasscutter.net.proto.StoreTypeOuterClass.StoreType;
|
||||
@@ -13,11 +13,11 @@ public class PacketStoreWeightLimitNotify extends GenshinPacket {
|
||||
|
||||
StoreWeightLimitNotify p = StoreWeightLimitNotify.newBuilder()
|
||||
.setStoreType(StoreType.StorePack)
|
||||
.setWeightLimit(GenshinConstants.LIMIT_ALL)
|
||||
.setWeaponCountLimit(GenshinConstants.LIMIT_WEAPON)
|
||||
.setReliquaryCountLimit(GenshinConstants.LIMIT_RELIC)
|
||||
.setMaterialCountLimit(GenshinConstants.LIMIT_MATERIAL)
|
||||
.setFurnitureCountLimit(GenshinConstants.LIMIT_FURNITURE)
|
||||
.setWeightLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitAll)
|
||||
.setWeaponCountLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitWeapon)
|
||||
.setReliquaryCountLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitRelic)
|
||||
.setMaterialCountLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitMaterial)
|
||||
.setFurnitureCountLimit(Grasscutter.getConfig().getServerOptions().InventoryLimitFurniture)
|
||||
.build();
|
||||
|
||||
this.setData(p);
|
||||
|
||||
@@ -17,7 +17,7 @@ public class PacketWorldPlayerInfoNotify extends GenshinPacket {
|
||||
GenshinPlayer p = world.getPlayers().get(i);
|
||||
|
||||
proto.addPlayerInfoList(p.getOnlinePlayerInfo());
|
||||
proto.addPlayerUidList(p.getId());
|
||||
proto.addPlayerUidList(p.getUid());
|
||||
}
|
||||
|
||||
this.setData(proto.build());
|
||||
|
||||
@@ -17,7 +17,7 @@ public class PacketWorldPlayerRTTNotify extends GenshinPacket {
|
||||
for (GenshinPlayer player : world.getPlayers()) {
|
||||
proto.addPlayerRttList(
|
||||
PlayerRTTInfo.newBuilder()
|
||||
.setUid(player.getId())
|
||||
.setUid(player.getUid())
|
||||
.setRtt(10) // TODO - put player ping here
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user