mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-12-14 16:04:40 +01:00
Merge branch 'main' into main
This commit is contained in:
@@ -189,35 +189,26 @@ public final class PlayerCommands {
|
||||
description = "Gives the player a specified character", permission = "player.givechar")
|
||||
public static class GiveCharCommand implements CommandHandler {
|
||||
@Override public void execute(GenshinPlayer player, List<String> args) {
|
||||
int target, avatarID, level = 1, ascension = 1;
|
||||
int target, avatarId, level = 1, ascension = 1;
|
||||
|
||||
if(args.size() < 2) {
|
||||
CommandHandler.sendMessage(null, "Usage: givechar <player> <avatarId> [level]");
|
||||
if(args.size() < 1) {
|
||||
CommandHandler.sendMessage(player, "Usage: givechar <player> <avatarId> [level]");
|
||||
return;
|
||||
}
|
||||
|
||||
switch(args.size()) {
|
||||
default:
|
||||
CommandHandler.sendMessage(null, "Usage: givechar <player> <avatarId> [level]");
|
||||
CommandHandler.sendMessage(player, "Usage: givechar <player> <avatarId> [level]");
|
||||
return;
|
||||
case 1:
|
||||
try {
|
||||
avatarID = Integer.parseInt(args.get(0));
|
||||
target = player.getAccount().getPlayerId();
|
||||
} catch (NumberFormatException ignored) {
|
||||
// TODO: Parse from avatar name using GM Handbook.
|
||||
CommandHandler.sendMessage(player, "Invalid avatar id.");
|
||||
return;
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
try {
|
||||
target = Integer.parseInt(args.get(0));
|
||||
if(Grasscutter.getGameServer().getPlayerByUid(target) == null) {
|
||||
target = player.getUid(); level = Integer.parseInt(args.get(1));
|
||||
avatarID = Integer.parseInt(args.get(0));
|
||||
target = player.getUid();
|
||||
level = Integer.parseInt(args.get(1));
|
||||
avatarId = Integer.parseInt(args.get(0));
|
||||
} else {
|
||||
avatarID = Integer.parseInt(args.get(1));
|
||||
avatarId = Integer.parseInt(args.get(1));
|
||||
}
|
||||
} catch (NumberFormatException ignored) {
|
||||
// TODO: Parse from avatar name using GM Handbook.
|
||||
@@ -232,7 +223,7 @@ public final class PlayerCommands {
|
||||
CommandHandler.sendMessage(player, "Invalid player ID."); return;
|
||||
}
|
||||
|
||||
avatarID = Integer.parseInt(args.get(1));
|
||||
avatarId = Integer.parseInt(args.get(1));
|
||||
level = Integer.parseInt(args.get(2));
|
||||
} catch (NumberFormatException ignored) {
|
||||
// TODO: Parse from avatar name using GM Handbook.
|
||||
@@ -244,22 +235,22 @@ public final class PlayerCommands {
|
||||
|
||||
GenshinPlayer targetPlayer = Grasscutter.getGameServer().getPlayerByUid(target);
|
||||
if(targetPlayer == null) {
|
||||
CommandHandler.sendMessage(null, "Player not found."); return;
|
||||
CommandHandler.sendMessage(player, "Player not found."); return;
|
||||
}
|
||||
|
||||
AvatarData avatarData = GenshinData.getAvatarDataMap().get(avatarID);
|
||||
AvatarData avatarData = GenshinData.getAvatarDataMap().get(avatarId);
|
||||
if(avatarData == null) {
|
||||
CommandHandler.sendMessage(null, "Invalid avatar id."); return;
|
||||
CommandHandler.sendMessage(player, "Invalid avatar id."); return;
|
||||
}
|
||||
|
||||
// Calculate ascension level.
|
||||
if (level <= 40) {
|
||||
ascension = (int)Math.ceil(level / 20);
|
||||
} else if (level > 20) {
|
||||
ascension = (int)Math.ceil(level / 10) - 3;
|
||||
ascension = (int) Math.ceil(level / 20f);
|
||||
} else {
|
||||
ascension = (int) Math.ceil(level / 10f) - 3;
|
||||
}
|
||||
|
||||
GenshinAvatar avatar = new GenshinAvatar(avatarID);
|
||||
GenshinAvatar avatar = new GenshinAvatar(avatarId);
|
||||
avatar.setLevel(level);
|
||||
avatar.setPromoteLevel(ascension);
|
||||
|
||||
@@ -280,7 +271,7 @@ public final class PlayerCommands {
|
||||
int target = Integer.parseInt(args.get(0));
|
||||
int avatarID = Integer.parseInt(args.get(1));
|
||||
int level = 1; if(args.size() > 2) level = Integer.parseInt(args.get(2));
|
||||
int ascension = 1;
|
||||
int ascension;
|
||||
|
||||
GenshinPlayer targetPlayer = Grasscutter.getGameServer().getPlayerByUid(target);
|
||||
if(targetPlayer == null) {
|
||||
@@ -294,9 +285,9 @@ public final class PlayerCommands {
|
||||
|
||||
// Calculate ascension level.
|
||||
if (level <= 40) {
|
||||
ascension = (int)Math.ceil(level / 20);
|
||||
} else if (level > 20) {
|
||||
ascension = (int)Math.ceil(level / 10) - 3;
|
||||
ascension = (int) Math.ceil(level / 20f);
|
||||
} else {
|
||||
ascension = (int) Math.ceil(level / 10f) - 3;
|
||||
}
|
||||
|
||||
GenshinAvatar avatar = new GenshinAvatar(avatarID);
|
||||
@@ -465,7 +456,7 @@ public final class PlayerCommands {
|
||||
@Override
|
||||
public void execute(GenshinPlayer player, List<String> args) {
|
||||
if(args.size() < 1) {
|
||||
CommandHandler.sendMessage(null, "Usage: setworldlevel <level>"); return;
|
||||
CommandHandler.sendMessage(player, "Usage: setworldlevel <level>"); return;
|
||||
}
|
||||
|
||||
try {
|
||||
@@ -503,21 +494,18 @@ public final class PlayerCommands {
|
||||
@Override
|
||||
public void execute(GenshinPlayer player, List<String> args) {
|
||||
if(args.size() < 1) {
|
||||
CommandHandler.sendMessage(null, "Usage: changescene <scene id>"); return;
|
||||
CommandHandler.sendMessage(player, "Usage: changescene <scene id>"); return;
|
||||
}
|
||||
|
||||
int sceneId = 0;
|
||||
|
||||
try {
|
||||
sceneId = Integer.parseInt(args.get(0));
|
||||
int sceneId = Integer.parseInt(args.get(0));
|
||||
boolean result = player.getWorld().transferPlayerToScene(player, sceneId, player.getPos());
|
||||
|
||||
if (!result) {
|
||||
CommandHandler.sendMessage(null, "Scene does not exist or you are already in it");
|
||||
}
|
||||
} catch (Exception e) {
|
||||
return;
|
||||
}
|
||||
|
||||
boolean result = player.getWorld().transferPlayerToScene(player, sceneId, player.getPos());
|
||||
|
||||
if (!result) {
|
||||
CommandHandler.sendMessage(null, "Scene does not exist or you are already in it");
|
||||
CommandHandler.sendMessage(player, "Usage: changescene <scene id>"); return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -197,7 +197,7 @@ public class ResourceLoader {
|
||||
} else {
|
||||
Map<String, OpenConfigEntry> map = new TreeMap<>();
|
||||
java.lang.reflect.Type type = new TypeToken<Map<String, OpenConfigData[]>>() {}.getType();
|
||||
String[] folderNames = {"BinOutput\\Talent\\EquipTalents\\", "BinOutput\\Talent\\AvatarTalents\\"};
|
||||
String[] folderNames = {"BinOutput/Talent/EquipTalents/", "BinOutput/Talent/AvatarTalents/"};
|
||||
|
||||
for (String name : folderNames) {
|
||||
File folder = new File(Utils.toFilePath(Grasscutter.getConfig().RESOURCE_FOLDER + name));
|
||||
|
||||
@@ -471,7 +471,7 @@ public class InventoryManager {
|
||||
}
|
||||
|
||||
// Consume weapon
|
||||
player.getInventory().removeItem(feed);
|
||||
player.getInventory().removeItem(feed, 1);
|
||||
|
||||
// Get
|
||||
weapon.setRefinement(targetRefineLevel);
|
||||
@@ -804,6 +804,12 @@ public class InventoryManager {
|
||||
// Get talent
|
||||
int currentTalentLevel = avatar.getCoreProudSkillLevel();
|
||||
int nextTalentId = ((avatar.getAvatarId() % 10000000) * 10) + currentTalentLevel + 1;
|
||||
|
||||
if (avatar.getAvatarId() == 10000006) {
|
||||
// Lisa is special in that her talentId starts with 4 instead of 6.
|
||||
nextTalentId = 40 + currentTalentLevel + 1;
|
||||
}
|
||||
|
||||
AvatarTalentData talentData = GenshinData.getAvatarTalentDataMap().get(nextTalentId);
|
||||
|
||||
if (talentData == null) {
|
||||
|
||||
@@ -389,6 +389,10 @@ public final class DispatchServer {
|
||||
"/sdk/upload",
|
||||
new DispatchHttpJsonHandler("{\"code\":0}")
|
||||
);
|
||||
server.createContext( // /perf/config/verify?device_id=xxx&platform=x&name=xxx
|
||||
"/perf/config/verify",
|
||||
new DispatchHttpJsonHandler("{\"code\":0}")
|
||||
);
|
||||
// Start server
|
||||
server.start();
|
||||
Grasscutter.getLogger().info("Dispatch server started on port " + getAddress().getPort());
|
||||
|
||||
@@ -59,6 +59,7 @@ public class PacketPlayerEnterSceneNotify extends GenshinPacket {
|
||||
.setEnterReason(reason.getValue())
|
||||
.addSceneTagIdList(102)
|
||||
.addSceneTagIdList(107)
|
||||
.addSceneTagIdList(109)
|
||||
.addSceneTagIdList(113)
|
||||
.addSceneTagIdList(117)
|
||||
.setUnk1(1)
|
||||
|
||||
Reference in New Issue
Block a user