mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-09 11:44:19 +01:00
#601: Implement Player#sendExperienceChange
By: anhcraft <huynhduyanh123123@gmail.com>
This commit is contained in:
parent
f8d1ea3c68
commit
d862f0fa87
1 changed files with 21 additions and 0 deletions
|
@ -47,6 +47,7 @@ import net.minecraft.server.PacketPlayOutBlockChange;
|
||||||
import net.minecraft.server.PacketPlayOutChat;
|
import net.minecraft.server.PacketPlayOutChat;
|
||||||
import net.minecraft.server.PacketPlayOutCustomPayload;
|
import net.minecraft.server.PacketPlayOutCustomPayload;
|
||||||
import net.minecraft.server.PacketPlayOutCustomSoundEffect;
|
import net.minecraft.server.PacketPlayOutCustomSoundEffect;
|
||||||
|
import net.minecraft.server.PacketPlayOutExperience;
|
||||||
import net.minecraft.server.PacketPlayOutMap;
|
import net.minecraft.server.PacketPlayOutMap;
|
||||||
import net.minecraft.server.PacketPlayOutNamedSoundEffect;
|
import net.minecraft.server.PacketPlayOutNamedSoundEffect;
|
||||||
import net.minecraft.server.PacketPlayOutPlayerInfo;
|
import net.minecraft.server.PacketPlayOutPlayerInfo;
|
||||||
|
@ -946,6 +947,7 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setLevel(int level) {
|
public void setLevel(int level) {
|
||||||
|
Preconditions.checkArgument(level >= 0, "Experience level must not be negative (%s)", level);
|
||||||
getHandle().expLevel = level;
|
getHandle().expLevel = level;
|
||||||
getHandle().lastSentExp = -1;
|
getHandle().lastSentExp = -1;
|
||||||
}
|
}
|
||||||
|
@ -957,9 +959,28 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setTotalExperience(int exp) {
|
public void setTotalExperience(int exp) {
|
||||||
|
Preconditions.checkArgument(exp >= 0, "Total experience points must not be negative (%s)", exp);
|
||||||
getHandle().expTotal = exp;
|
getHandle().expTotal = exp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendExperienceChange(float progress) {
|
||||||
|
sendExperienceChange(progress, getLevel());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendExperienceChange(float progress, int level) {
|
||||||
|
Preconditions.checkArgument(progress >= 0.0 && progress <= 1.0, "Experience progress must be between 0.0 and 1.0 (%s)", progress);
|
||||||
|
Preconditions.checkArgument(level >= 0, "Experience level must not be negative (%s)", level);
|
||||||
|
|
||||||
|
if (getHandle().playerConnection == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
PacketPlayOutExperience packet = new PacketPlayOutExperience(progress, getTotalExperience(), level);
|
||||||
|
getHandle().playerConnection.sendPacket(packet);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public float getExhaustion() {
|
public float getExhaustion() {
|
||||||
return getHandle().getFoodData().exhaustionLevel;
|
return getHandle().getFoodData().exhaustionLevel;
|
||||||
|
|
Loading…
Reference in a new issue