我正在做一个迷你游戏。如果有2位玩家在线,则倒数开始。我正在用我的2个帐户进行测试。当1个帐户登录时,我会得到一把钻石剑。没关系。但是,当我使用第二个帐户登录时,倒数计时不会开始,并且出现错误。我不知道是什么问题。你能帮我么?非常感谢你。
这是错误:
[15:41:29 ERROR]: Could not pass event PlayerJoinEvent to Minigame v1.0.0
org.bukkit.event.EventException
at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.ja
va:302) ~[craftbukkit.jar:git-Bukkit-53fac9f]
at org.bukkit.plugin.RegisteredListener.callEvent(RegisteredListener.jav
a:62) ~[craftbukkit.jar:git-Bukkit-53fac9f]
at org.bukkit.plugin.SimplePluginManager.fireEvent(SimplePluginManager.j
ava:501) [craftbukkit.jar:git-Bukkit-53fac9f]
at org.bukkit.plugin.SimplePluginManager.callEvent(SimplePluginManager.j
ava:486) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.PlayerList.onPlayerJoin(PlayerList.java:
282) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.PlayerList.a(PlayerList.java:142) [craft
bukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.LoginListener.b(LoginListener.java:115)
[craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.LoginListener.c(LoginListener.java:53) [
craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.NetworkManager.a(NetworkManager.java:222
) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.ServerConnection.c(SourceFile:168) [craf
tbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.MinecraftServer.B(MinecraftServer.java:7
44) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.DedicatedServer.B(DedicatedServer.java:3
35) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.MinecraftServer.A(MinecraftServer.java:6
28) [craftbukkit.jar:git-Bukkit-53fac9f]
at net.minecraft.server.v1_8_R3.MinecraftServer.run(MinecraftServer.java
:536) [craftbukkit.jar:git-Bukkit-53fac9f]
at java.lang.Thread.run(Unknown Source) [?:1.8.0_60]
Caused by: java.lang.NullPointerException
at me.KevinGDev.Listeners.Player.PlayerJoin.onPlayerJoin(PlayerJoin.java
:41) ~[?:?]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0
_60]
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0
_60]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1
.8.0_60]
at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.8.0_60]
at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.ja
va:300) ~[craftbukkit.jar:git-Bukkit-53fac9f]
... 14 more
这是我的PlayerJoinEvent:
public class PlayerJoin extends MListener {
public static Minigame plugin;
public PlayerJoin(Minigame pl) {
super(pl);
}
@EventHandler
public void onPlayerJoin(PlayerJoinEvent event) {
Player player = event.getPlayer();
LocationUtilities.teleportToSpawn(player);
InventoryUtilities.clearInventory(player);
ItemStack is = new ItemStack(Material.DIAMOND_SWORD);
ItemMeta im = is.getItemMeta();
im.setDisplayName(ChatColor.GREEN + "Kits");
is.setItemMeta(im);
player.getInventory().addItem(is);
if(Bukkit.getServer().getOnlinePlayers().size() >= 2) {
ChatUtilties.broadcast("Enough players. Starting countdown!");
plugin.startCountdown();
}
}
PlayerJoinEvent位于PlayerJoin类中。
startCountdown方法位于Minigame类(主类)中。
startCountdown方法:
public void startCountdown() {
StartCountdown.timeUntilStart = 60;
startCountdownId = getServer()
.getScheduler()
.scheduleSyncRepeatingTask(this, new StartCountdown(this), 20l, 20l);
最佳答案
在您的堆栈跟踪中,我可以看到您在事件方法“ onPlayerJoin”中得到了NullPointerException。
我看到以下内容:
public static Minigame plugin;
public PlayerJoin(Minigame pl) {
super(pl);
}
您有两个不同的“迷你游戏”对象。您提供给MListener的一个和未初始化的一个。那应该是你的问题。
“ plugin.startCountdown();”因此,调用导致Exception。您可以对未初始化的对象(“ null”)调用startCountdown()方法。
有两种解决方法:
初始化插件变量
在“ pl”上调用“ startCountdown()”
因此,采用第一个解决方案:
public PlayerJoin(Minigame pl) {
super(pl);
plugin = pl;
}
我不建议这样做,因为它处理https://en.wikipedia.org/wiki/Static_variable变量比较麻烦。
第二种解决方案:
我认为对您来说,有可能(通过getter或直接调用)访问“ pl”对象。在您的EventListener中使用它:
[pl/getPl()/getPlugin()].startCountdown();