首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Bukkit PlayerJoinEvent错误

Bukkit PlayerJoinEvent错误
EN

Stack Overflow用户
提问于 2016-01-05 23:43:00
回答 1查看 469关注 0票数 0

我在做一个迷你游戏。如果有2个玩家在线,将开始倒计时。我正在用我的2个帐户测试这一点。当一个账号登录时,我会得到一把钻石剑。那很好。但是当我使用第二个帐户登录时,倒计时将不会开始,并且我得到一个错误。我不知道问题出在哪里。你能帮帮我吗?非常感谢。

这是错误:

代码语言:javascript
复制
[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:

代码语言:javascript
复制
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方法:

代码语言:javascript
复制
public void startCountdown() {
    StartCountdown.timeUntilStart = 60;
    startCountdownId = getServer()
            .getScheduler()
            .scheduleSyncRepeatingTask(this, new StartCountdown(this), 20l, 20l);
EN

回答 1

Stack Overflow用户

发布于 2016-01-06 04:31:58

在你的堆栈跟踪中,我可以读到你的事件方法"onPlayerJoin“中得到了一个NullPointerException。

我看到了以下几点:

代码语言:javascript
复制
public static Minigame plugin;

public PlayerJoin(Minigame pl) {
    super(pl);
}

你得到了两个不同的"Minigame“对象。一个是您给MListener的,另一个是未初始化的。这应该是你的问题所在。因此,"plugin.startCountdown();“调用会导致异常。在未初始化('null')的对象上调用startCountdown()方法。

有两个选项可以解决这个问题:

  • 初始化插件变量
  • 调用"startCountdown()“on "pl"

因此,使用第一个解决方案:

代码语言:javascript
复制
public PlayerJoin(Minigame pl) {
    super(pl);
    plugin = pl;
}

我不推荐这样做,因为处理https://en.wikipedia.org/wiki/Static_variable变量很麻烦。

采用第二种解决方案:

我假设您可以在某个地方访问"pl“对象(通过getter或直接调用)。请在您的EventListener中使用以下代码:

代码语言:javascript
复制
 [pl/getPl()/getPlugin()].startCountdown();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34615601

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档