4
7

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Spigot(Paper) 2020年度 プラグインの作り方 入門#01(環境構築編)

Last updated at Posted at 2020-07-16

今回はMinecraftのSpigotMC(以下、Spigot)というカスタムサーバーを使ってオリジナルのプラグインを作りたいと思います。
具体的にオリジナルのプラグインを作成しながらプラグイン作りの全体像を理解する助けになればなと思っています。

できるだけ丁寧に解説したいのですが、どうしても前知識が必要になってしまう部分もあると思います・・・。
他の入門サイトでJavaの環境構築を終えつつJavaの基本の文法、if文やfor文等の制御構文,クラスやメソッドをぼんやり理解してHello Worldを出したけど、次何をしたらいいかわからない!という方にとって一歩踏み出せるような、そんな内容を目指します。
(自信が無い、まだ終わってない人は一番かんたんなJava入門, Java入門 等を片手に読み進めましょう!)

この記事で、もし、間違っている部分があればご指摘くださいっ!
では、始めましょうー!

※本記事は編集中です....

次の記事→(Spigot(Paper) 2020年度 プラグイン作り方 入門#02(サブタイトル未定))

この記事の目標

  • Spigotプラグインの環境構築ができる
  • プロジェクトの作成

#環境構築
鬼門の環境構築です・・・!

基本的なJava自体の開発環境は揃っていると思いますが、まだ一度もしたことが無いという方はJava入門記事を参考にJavaの開発環境を一度構築してみてください。
以下は、Spigot(Paper)プラグインの開発環境を構築する注意点等を纏めてます。
焦らずゆっくり行いましょう!

##エディタ(IDE)について
エディタはどれでも大丈夫です。
この記事ではIntelliJ IDEA 2019.3.5 を使います。
執筆時点で一番新しいIntelliJ IDEA 2020.1.1がリリースされていますが、うまくいかないという方はIntelliJ IDEA 2019.3.5 で行ってください。
image.png

##JDKのバージョンの注意点
開発に使用するJDKは、大きく分けてOracleのJDKとOpenJDKの2種類がありますが、どちらでも大丈夫です。
しかし、バージョンは気を付ける必要があります。(重要!)

①Spigotを実行するJavaのバージョン ≧ ②プラグインコンパイル時に使うJava(javac)のバージョン

になっている必要があるのです。
コンパイルに使うJavaのバージョンの方が高いとプラグインが正常に読み込まれない可能性があります。
もし、「プラグインはビルドできたのに、プラグイン読み込み時にエラーが起きて正常に読み込まれない」という方がいたら、Javaのバージョンを見直してみてください。(ここで躓いてしまう方もいましたので・・・。)
とは言っても、基本的に①Spigotの実行でJava SE 7以下は使われていないはず (2020/5/30 時点)なので、②プラグインコンパイル時に使うJava(javac)に、Java SE 8の Oracle JDK(ダウンロードリンク)を選んでおくと、特に問題は起こらないと思います。
よくわからない!という方は Java SE 8 の Oracle JDK をダウンロードしてインストールしておきましょう。

###Java(①Spigotを実行するJava)のバージョン確認方法
コマンドプロンプトを立ち上げてjava -versionを実行します。
1.8.0となっていますが、Java 8のことです。

C:\Users\ユーザー名>java -version
java version "1.8.0_251"
Java(TM) SE Runtime Environment (build 1.8.0_251-b08)
Java HotSpot(TM) 64-Bit Server VM (build 25.251-b08, mixed mode)

バージョンが表示されない場合は
javaコマンドへのパスが通っていない可能性があります。
(javaコマンドへのパスの通し方はhttps://www.javadrive.jp/start/install/index4.html を参照)

C:\Users\ユーザー名>java -version
'java' は、内部コマンドまたは外部コマンド、
操作可能なプログラムまたはバッチ ファイルとして認識されていません。

###Java(②プラグインコンパイル時に使うJava)のバージョン確認方法
IntelliJ IDEA Communityでは、プロジェクト毎にJDKを選択することができます。

プロジェクトは、アプリケーションを構成するすべてのものを保持するディレクトリです。
https://pleiades.io/help/idea/working-with-projects.html より引用)

1.JDKのバージョンを確認したいプロジェクトを開きます。
2.上のメニューから ファイル→プロジェクトの構造→プロジェクトを開きます。
image.png

##Gradle
入門ではjavacコマンド等を使ってclassファイルにコンパイル・実行をしたかもしれませんが、プラグイン作成では依存関係や必要なファイルが多いので管理が大変です。
なので、ビルドにはGradleを使用します。
Gradleとは、様々なソースファイルや依存関係を管理し一つのjarファイルにコンパイル・ビルドするためのツールです。

GradleはIntelliJ IDEAに最初からついてくるので新たにインストールする必要は無いです。

##テストサーバーの用意
作成したプラグインをテストするためのサーバーが必要です。
この記事ではSpigotを使用します。
バージョンは最新の1.15.2を使用します。
フォークにPaperMCがありますがそちらでも大丈夫です。
(Spigotサーバーの建て方はhttps://blog.mkserver.jp/2019/05/19/spigot-server-build/ を参照)

##執筆時点の環境
私の執筆時点での環境です。

ツールの項目 バージョン
IDE IntelliJ IDEA Community Edition 2019.3.5
JDK Oracle JDK 1.8.0_251"
ビルドツール Gradle
テストサーバー Spigot MC 1.15.2
OS Windows 10 1909

#Spigotプラグインプロジェクトの新規作成
Spigot向けプラグインを作り始めましょう!
今回はマイクラログイン時にチャット欄にHello Minecraft Plugin!!を出すことが目標です。
##Minecraft Developmentのインストール
開発を始める前に、Minecraft Developmentがインストールされてない方はインストールしておきましょう。
image.png
image.png
「Minecraft」を検索してMinecraft Evelopmentが見つかったら、Installをクリックしてインストールします。
インストールが完了したら、一度IntelliJ IDEAを終了して、リスタートしてください。
Minecraft DevelopmentはSpigotプラグインのひな形を作成してくれるIntelliJ IDEAの拡張機能です。

##IntelliJ IDEAを開く

IntelliJ IDEAを開きましょう!新規プロジェクトの作成をクリック。
image.png

##Spigotプラグインの新規作成

Spigot Plugin にチェックを入れてプロジェクト SDK:から目的のJDKを選択します。
ここで選択するJDKはプラグインコンパイル時に使うJavaです。
image.png

名称未設定 4.png

  • グループIDはプラグインが所属するグループの名前です。
    名前が他のプラグインと被らないようにしましょう。
    com.github.rnlin.tanosii にしました。

  • アーティファクトIDはプラグインを区別するための名前です。
    originalplugin にしました。

  • バージョンはプラグインの初期のバージョンです。
    特にこだわりが無ければそのままで大丈夫です。
    ちなみにSNAPSHOTはこのバージョンはまだ開発途上という意味で慣例的に使われます。

最後にMaven → Gradle を選択して次へをクリックします。

名称未設定 5.png

殆ど変更しなくても大丈夫です。
一か所だけMain Class Namecom.github.rnlin.tanosii.originalplugin.Originalplugin になっていますが、OriginalPlugin に変更します。
せっかくなのでJavaのコーディング規約に合わせました!コーディング規約はこれからも見る癖をつけておきましょう...!(私も頑張ります...)
(Javaのネーミング規約:https://future-architect.github.io/coding-standards/documents/forJava/ を参照)

下のOriginal Settingの方はお好みに設定してください。
この項目はplugin.ymlに書き込まれる設定項目で、後で変更することもできます。
私は説明Autohrsだけ設定しました!
次へをクリックします。

名称未設定 5.png
プロジェクト名とプロジェクトを保存するフォルダを設定します。
プロジェクト名はアーティファクトID(originalplugin)と同じものにしました。
保存するフォルダはわかりやすいところにしましょう!
完了をクリックします。

おめでとうございます!!
環境構築とプロジェクトの作成はこれで終わりです!

4
7
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
7

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?