るみさんのブログ

Spigotプラグイン開発で、BungeeCordを操作する時に困った話

作成日:2023-04-06 02:04:40
最新更新日:0000-00-00 00:00:00

Spigotプラグイン開発で、BungeeCordを操作する時に困った話です。<BR>
どういうことか?説明しましょう<BR>
<BR>
Spigotプラグインで、棒を右クリックしたらインベントリを使ったメニューを出す<BR>

ダイヤモンドをクリックしたら、「main」という鯖に転送する<BR>
<BR>
というのを作りたかった。つまり、ハイピとかで良くあるインベントリを使ったメニューのあれです()<BR>
簡単そうに見えて、実は結構落とし穴があった;;<BR>
それではやり方を説明します!<BR>
<HR>
<DIV>
<H2>前提条件</H2>
<HR>
・Spigotのプラグインのプロジェクトがある<BR>
・IDEはIntelliJ(違うくても別に弊害はない)<BR>
</DIV>
<DIV>
<H1>やり方</H1>
<HR>
まずは以下のコードを<FONT STYLE="color: red;">メインクラスと同じクラス</FONT>の、実行する関数内に記述します。<BR>
<PRE CLASS="CODEBLOCK" ID="CODEBLOCK">
ByteArrayDataOutput out = ByteStreams.newDataOutput();
out.writeUTF("Connect");
out.writeUTF("移動先の鯖の名前");
player.sendPluginMessage(this, "BungeeCord", out.toByteArray());
</PRE>
つまり、「Menu」というインベントリでダイヤモンドをクリックしたらこれを実行するなら、以下のようにメインクラス内に記述します↓↓<BR>
<PRE CLASS="CODEBLOCK" ID="CODEBLOCK">
@EventHandler
public void onInventoryClick(InventoryClickEvent event) {
if (!event.getView().getTitle().equals("Menu")) { // インベントリのタイトルが"Menu"ではない場合は処理しない
return;
}
event.setCancelled(true); // イベントをキャンセルする(アイテムを移動できなくする)
if (event.getCurrentItem() == null || event.getCurrentItem().getType() == Material.AIR) { // クリックされたアイテムが空気の場合は処理しない
return;
}
Player player = (Player) event.getWhoClicked();
switch (event.getCurrentItem().getType()) {
case DIAMOND:
// ダイヤモンドがクリックされた場合の処理
ByteArrayDataOutput out = ByteStreams.newDataOutput();
out.writeUTF("Connect");
out.writeUTF("移動先の鯖名");
player.sendPluginMessage(this, "BungeeCord", out.toByteArray());
break;
}
}
</PRE>
理解できましたか?<BR>
まあ、この後なぜ私がつまずいて発狂しかけたのか解説します・・・・<BR>
<HR>
</DIV>
つまずいた理由ですが、わたしはこれを別のクラスでやっていました。<BR>
メインクラスから、イベント処理としてOpenMenuというクラスを呼び出していました。<BR>
なぜ動かないのか?それは「player.sendPluginMessage(this, "BungeeCord", out.toByteArray());」にあります。<BR>
「sendPluginMessage」の引数を見てみましょう<BR>
sendPluginMessage(Plugin, Channnel, Byte(?))<BR>
このPluginというのは、私のよくわからないんですが、おそらく自分自身、つまりプラグイン自信の事だと思います、たぶん(?)<BR>
これをわたしはIntelliJの促すがままに「(Plugin) this」といれていました、これが発狂の原因、つまりエラーの原因です。。。<BR>
Pluginはメインクラスで、一番最初に初期化しないといけない?らしいのですが、<BR>
もちろん適当にいれたこのthisは初期化されていないので、エラーが出たわけです<BR>
これのせいで時間を結構消費しました;;<BR>
プラグインは情報も少ないしね、、、<BR>
最後にエラー文を貼っておきます<BR>
<DETAILS>
<SUMMARY>エラー文</SUMMARY><BR>
<TEXTAREA STYLE="width: 100vw; height: 100vh;">
org.bukkit.event.EventException: null
at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.java:310) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at org.bukkit.plugin.RegisteredListener.callEvent(RegisteredListener.java:70) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at org.bukkit.plugin.SimplePluginManager.fireEvent(SimplePluginManager.java:589) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at org.bukkit.plugin.SimplePluginManager.callEvent(SimplePluginManager.java:576) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.PlayerConnection.a(PlayerConnection.java:2436) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.PacketPlayInWindowClick.a(SourceFile:32) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.PacketPlayInWindowClick.a(SourceFile:10) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.PlayerConnectionUtils.lambda$0(PlayerConnectionUtils.java:28) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.TickTask.run(SourceFile:18) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.IAsyncTaskHandler.executeTask(SourceFile:144) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.IAsyncTaskHandlerReentrant.executeTask(SourceFile:23) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.IAsyncTaskHandler.executeNext(SourceFile:118) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.MinecraftServer.bb(MinecraftServer.java:1061) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.MinecraftServer.executeNext(MinecraftServer.java:1054) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.IAsyncTaskHandler.awaitTasks(SourceFile:127) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.MinecraftServer.sleepForTick(MinecraftServer.java:1038) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.MinecraftServer.w(MinecraftServer.java:970) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at net.minecraft.server.v1_16_R3.MinecraftServer.lambda$0(MinecraftServer.java:273) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
at java.lang.Thread.run(Thread.java:831) [?:?]
Caused by: java.lang.ClassCastException: class com.rumisystem.rumi_inventory_menu.OpenMenu cannot be cast to class org.bukkit.plugin.Plugin (com.rumisystem.rumi_inventory_menu.OpenMenu is in unnamed module of loader org.bukkit.plugin.java.PluginClassLoader @735bb56e; org.bukkit.plugin.Plugin is in unnamed module of loader 'app')
at com.rumisystem.rumi_inventory_menu.OpenMenu.onInventoryClick(OpenMenu.java:66) ~[?:?]
at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?]
at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:78) ~[?:?]
at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?]
at java.lang.reflect.Method.invoke(Method.java:567) ~[?:?]
at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.java:306) ~[spigot-1.16.5.jar:3096a-Spigot-9fb885e-af1a232]
... 18 more
</TEXTAREA>
</DETAILS>
<BR>
<BR>
まあ、以上で終わります、コメント欄で補足説明をしてくれるとありがたいです。。。。<BR>
じゃ!<BR>



シェア



コメント欄の復旧は少し待ってね