我在做一个迷你游戏。如果有2个玩家在线,将开始倒计时。我正在用我的2个帐户测试这一点。当一个账号登录时,我会得到一把钻石剑。那很好。但是当我使用第二个帐户登录时,倒计时将不会开始,并且我得到一个错误。我不知道问题出在哪里。你能帮帮我吗?非常感谢。
这是错误:
[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);发布于 2016-01-06 04:31:58
在你的堆栈跟踪中,我可以读到你的事件方法"onPlayerJoin“中得到了一个NullPointerException。
我看到了以下几点:
public static Minigame plugin;
public PlayerJoin(Minigame pl) {
super(pl);
}你得到了两个不同的"Minigame“对象。一个是您给MListener的,另一个是未初始化的。这应该是你的问题所在。因此,"plugin.startCountdown();“调用会导致异常。在未初始化('null')的对象上调用startCountdown()方法。
有两个选项可以解决这个问题:
因此,使用第一个解决方案:
public PlayerJoin(Minigame pl) {
super(pl);
plugin = pl;
}我不推荐这样做,因为处理https://en.wikipedia.org/wiki/Static_variable变量很麻烦。
采用第二种解决方案:
我假设您可以在某个地方访问"pl“对象(通过getter或直接调用)。请在您的EventListener中使用以下代码:
[pl/getPl()/getPlugin()].startCountdown();https://stackoverflow.com/questions/34615601
复制相似问题