mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-28 00:45:38 +08:00
Limit co-op teams to 4 avatars max total
This commit is contained in:
parent
3b45ff7d46
commit
51cba69915
@ -60,13 +60,16 @@ public class TeamInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void copyFrom(TeamInfo team, int maxTeamSize) {
|
public void copyFrom(TeamInfo team, int maxTeamSize) {
|
||||||
// Clear
|
// Clone avatar ids from team to copy from
|
||||||
|
List<Integer> avatarIds = new ArrayList<>(team.getAvatars());
|
||||||
|
|
||||||
|
// Clear current avatar list first
|
||||||
this.getAvatars().clear();
|
this.getAvatars().clear();
|
||||||
|
|
||||||
// Copy from team
|
// Copy from team
|
||||||
int len = Math.min(team.getAvatars().size(), maxTeamSize);
|
int len = Math.min(avatarIds.size(), maxTeamSize);
|
||||||
for (int i = 0; i < len; i++) {
|
for (int i = 0; i < len; i++) {
|
||||||
int id = team.getAvatars().get(i);
|
int id = avatarIds.get(i);
|
||||||
this.getAvatars().add(id);
|
this.getAvatars().add(id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -166,7 +166,7 @@ public class TeamManager {
|
|||||||
|
|
||||||
// Methods
|
// Methods
|
||||||
|
|
||||||
public void updateTeamResonances() {
|
private void updateTeamResonances() {
|
||||||
Int2IntOpenHashMap map = new Int2IntOpenHashMap();
|
Int2IntOpenHashMap map = new Int2IntOpenHashMap();
|
||||||
|
|
||||||
this.getTeamResonances().clear();
|
this.getTeamResonances().clear();
|
||||||
@ -196,7 +196,7 @@ public class TeamManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateTeamEntities(GenshinPacket responsePacket) {
|
public void updateTeamEntities(GenshinPacket responsePacket) {
|
||||||
// Sanity check - Should never happen
|
// Sanity check - Should never happen
|
||||||
if (this.getCurrentTeamInfo().getAvatars().size() <= 0) {
|
if (this.getCurrentTeamInfo().getAvatars().size() <= 0) {
|
||||||
return;
|
return;
|
||||||
@ -241,7 +241,7 @@ public class TeamManager {
|
|||||||
// Set new selected character index
|
// Set new selected character index
|
||||||
if (prevSelectedAvatarIndex == -1) {
|
if (prevSelectedAvatarIndex == -1) {
|
||||||
// Previous selected avatar is not in the same spot, we will select the current one in the prev slot
|
// Previous selected avatar is not in the same spot, we will select the current one in the prev slot
|
||||||
prevSelectedAvatarIndex = Math.min(this.currentCharacterIndex, getCurrentTeamInfo().getAvatars().size() - 1);
|
prevSelectedAvatarIndex = Math.min(this.currentCharacterIndex, this.getActiveTeam().size() - 1);
|
||||||
}
|
}
|
||||||
this.currentCharacterIndex = prevSelectedAvatarIndex;
|
this.currentCharacterIndex = prevSelectedAvatarIndex;
|
||||||
|
|
||||||
|
@ -28,7 +28,6 @@ import emu.grasscutter.server.packet.send.PacketPlayerEnterSceneNotify;
|
|||||||
import emu.grasscutter.server.packet.send.PacketSceneEntityAppearNotify;
|
import emu.grasscutter.server.packet.send.PacketSceneEntityAppearNotify;
|
||||||
import emu.grasscutter.server.packet.send.PacketSceneEntityDisappearNotify;
|
import emu.grasscutter.server.packet.send.PacketSceneEntityDisappearNotify;
|
||||||
import emu.grasscutter.server.packet.send.PacketScenePlayerInfoNotify;
|
import emu.grasscutter.server.packet.send.PacketScenePlayerInfoNotify;
|
||||||
import emu.grasscutter.server.packet.send.PacketSceneTeamUpdateNotify;
|
|
||||||
import emu.grasscutter.server.packet.send.PacketSyncScenePlayTeamEntityNotify;
|
import emu.grasscutter.server.packet.send.PacketSyncScenePlayTeamEntityNotify;
|
||||||
import emu.grasscutter.server.packet.send.PacketSyncTeamEntityNotify;
|
import emu.grasscutter.server.packet.send.PacketSyncTeamEntityNotify;
|
||||||
import emu.grasscutter.server.packet.send.PacketWorldPlayerInfoNotify;
|
import emu.grasscutter.server.packet.send.PacketWorldPlayerInfoNotify;
|
||||||
@ -169,7 +168,7 @@ public class World implements Iterable<GenshinPlayer> {
|
|||||||
player.setPeerId(this.getNextPeerId());
|
player.setPeerId(this.getNextPeerId());
|
||||||
player.getTeamManager().setEntityId(getNextEntityId(EntityIdType.TEAM));
|
player.getTeamManager().setEntityId(getNextEntityId(EntityIdType.TEAM));
|
||||||
|
|
||||||
// TODO Update team of all players
|
// Setup team avatars
|
||||||
this.setupPlayerAvatars(player);
|
this.setupPlayerAvatars(player);
|
||||||
|
|
||||||
// Info packet for other players
|
// Info packet for other players
|
||||||
@ -212,18 +211,23 @@ public class World implements Iterable<GenshinPlayer> {
|
|||||||
|
|
||||||
private void updatePlayerInfos(GenshinPlayer paramPlayer) {
|
private void updatePlayerInfos(GenshinPlayer paramPlayer) {
|
||||||
for (GenshinPlayer player : getPlayers()) {
|
for (GenshinPlayer player : getPlayers()) {
|
||||||
// Dont send packets if player is loading in
|
// Dont send packets if player is loading in and filter out joining player
|
||||||
if (!player.hasSentAvatarDataNotify() || player.getSceneLoadState().getValue() < SceneLoadState.INIT.getValue() || player == paramPlayer) {
|
if (!player.hasSentAvatarDataNotify() || player.getSceneLoadState().getValue() < SceneLoadState.INIT.getValue() || player == paramPlayer) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update team of all players since max players has been changed - Probably not the best way to do it
|
||||||
|
if (this.isMultiplayer()) {
|
||||||
|
player.getTeamManager().getMpTeam().copyFrom(player.getTeamManager().getMpTeam(), player.getTeamManager().getMaxTeamSize());
|
||||||
|
player.getTeamManager().updateTeamEntities(null);
|
||||||
|
}
|
||||||
|
|
||||||
// World player info packets
|
// World player info packets
|
||||||
player.getSession().send(new PacketWorldPlayerInfoNotify(this));
|
player.getSession().send(new PacketWorldPlayerInfoNotify(this));
|
||||||
player.getSession().send(new PacketScenePlayerInfoNotify(this));
|
player.getSession().send(new PacketScenePlayerInfoNotify(this));
|
||||||
player.getSession().send(new PacketWorldPlayerRTTNotify(this));
|
player.getSession().send(new PacketWorldPlayerRTTNotify(this));
|
||||||
|
|
||||||
// Team packets
|
// Team packets
|
||||||
player.getSession().send(new PacketSceneTeamUpdateNotify(player));
|
|
||||||
player.getSession().send(new PacketSyncTeamEntityNotify(player));
|
player.getSession().send(new PacketSyncTeamEntityNotify(player));
|
||||||
player.getSession().send(new PacketSyncScenePlayTeamEntityNotify(player));
|
player.getSession().send(new PacketSyncScenePlayTeamEntityNotify(player));
|
||||||
}
|
}
|
||||||
@ -283,6 +287,11 @@ public class World implements Iterable<GenshinPlayer> {
|
|||||||
EntityAvatar entity = new EntityAvatar(this, player.getAvatars().getAvatarById(avatarId));
|
EntityAvatar entity = new EntityAvatar(this, player.getAvatars().getAvatarById(avatarId));
|
||||||
player.getTeamManager().getActiveTeam().add(entity);
|
player.getTeamManager().getActiveTeam().add(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Limit character index in case its out of bounds
|
||||||
|
if (player.getTeamManager().getCurrentCharacterIndex() >= player.getTeamManager().getActiveTeam().size() || player.getTeamManager().getCurrentCharacterIndex() < 0) {
|
||||||
|
player.getTeamManager().setCurrentCharacterIndex(player.getTeamManager().getCurrentCharacterIndex() - 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void removePlayerAvatars(GenshinPlayer player) {
|
private void removePlayerAvatars(GenshinPlayer player) {
|
||||||
|
Loading…
Reference in New Issue
Block a user