【Java】让我们来制作Minecraft 1.16.1的Mod吧【基础文件】
本文是一系列解释性文章之一。
進階篇
基本档案
基本となるファイル類を設定していきます。前回でコピペしたファイル群があるので、これらを自分用に変更していきます。
パッケージ名
パッケージ命名規約を読むと、所持するドメインを名前空間として用いることで、競合を避けることが求められるとのことです。しかしドメインを所持していないので、以下のようにしました。
D:\projects\mc_liveinwater\src\main\java
└ com
└ example
└ examplemod
└ ExampleMod.java
D:\projects\mc_liveinwater\src\main\java
└ jp
└ koteko
└ liveinwater
└ LiveInWater.java
资产文件夹、数据文件夹
创建一个名为 assets\liveinwater 的文件夹,用于存放纹理和音效等文件; 创建一个名为 data\liveinwater 的文件夹,用于存放配方和掉落表等文件。
D:\projects\mc_liveinwater\src\main\resources
├ assets
│ └ liveinwater
├ data
│ └ liveinwater
├ META-INF
│ └ mods.toml
└ pack.mcmeta
pack.mcmeta可以被改写成“资源包.mcmeta”。
pack.mcmeta文件是记录资源包详细信息的文件。请参考维基了解更多详细信息。由于是1.15以后的版本,所以pack_format为5。注释行是不必要的,进行删除。
{
"pack": {
"description": "live in water Mod resources",
"pack_format": 5
}
}
mods.toml
mods.toml ファイルはMod情報を記載するファイルです。
依存などの情報に加え、mod導入時の画面に表示される情報もここに含まれるため、必要に応じて変更しましょう。
長いですが、各項目の説明がコメントで書かれているだけなのでよく読んで適切に設定しましょう。mandatory は必須、 optional は任意項目です。
# This is an example mods.toml file. It contains the data relating to the loading mods.
# There are several mandatory fields (#mandatory), and many more that are optional (#optional).
# The overall format is standard TOML format, v0.5.0.
# Note that there are a couple of TOML lists in this file.
# Find more information on toml format here: https://github.com/toml-lang/toml
# The name of the mod loader type to load - for regular FML @Mod mods it should be javafml
modLoader="javafml" #mandatory
# A version range to match for said mod loader - for regular FML @Mod it will be the forge version
loaderVersion="[32,)" #mandatory This is typically bumped every Minecraft version by Forge. See our download page for lists of versions.
# The license for you mod. This is mandatory metadata and allows for easier comprehension of your redistributive properties.
# Review your options at https://choosealicense.com/. All rights reserved is the default copyright stance, and is thus the default here.
license="MIT License"
# A URL to refer people to when problems occur with this mod
#issueTrackerURL="http://my.issue.tracker/" #optional
# A list of mods - how many allowed here is determined by the individual mod loader
[[mods]] #mandatory
# The modid of the mod
modId="liveinwater" #mandatory
# The version number of the mod - there's a few well known ${} variables useable here or just hardcode it
version="${file.jarVersion}" #mandatory
# A display name for the mod
displayName="live in water Mod" #mandatory
# A URL to query for updates for this mod. See the JSON update specification <here>
#updateJSONURL="http://myurl.me/" #optional
# A URL for the "homepage" for this mod, displayed in the mod UI
#displayURL="http://example.com/" #optional
# A file name (in the root of the mod JAR) containing a logo for display
#logoFile="examplemod.png" #optional
# A text field displayed in the mod UI
#credits="Thanks for this example mod goes to Java" #optional
# A text field displayed in the mod UI
#authors="Love, Cheese and small house plants" #optional
# The description text for the mod (multi line!) (#mandatory)
description='''
live in water
– deep, silent, sea.
'''
# A dependency - use the . to indicate dependency for a specific modid. Dependencies are optional.
[[dependencies.liveinwater]] #optional
# the modid of the dependency
modId="forge" #mandatory
# Does this dependency have to exist - if not, ordering below must be specified
mandatory=true #mandatory
# The version range of the dependency
versionRange="[32,)" #mandatory
# An ordering relationship for the dependency - BEFORE or AFTER required if the relationship is not mandatory
ordering="NONE"
# Side this dependency is applied on - BOTH, CLIENT or SERVER
side="BOTH"
# Here's another dependency
[[dependencies.liveinwater]]
modId="minecraft"
mandatory=true
versionRange="[1.16.1]"
ordering="NONE"
side="BOTH"
licenseについては、いずれ配布を考えるなら、コメントにある参考ページなどをよく読み、きちんと設定するべきでしょう。(私は詳しくないので一旦 MIT License としておきました。)
そのほか必須でないものは適宜コメントアウトしました。
メインファイル
LiveInWater.java是Mod的主要类(最初是ExampleMod.java)。我们会清除不明显使用的部分,以使其更简洁。
package jp.koteko.liveinwater;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.eventbus.api.SubscribeEvent;
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
import net.minecraftforge.fml.event.lifecycle.InterModEnqueueEvent;
import net.minecraftforge.fml.event.lifecycle.InterModProcessEvent;
import net.minecraftforge.fml.event.server.FMLServerStartingEvent;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
@Mod("liveinwater")
public class LiveInWater
{
private static final Logger LOGGER = LogManager.getLogger();
public LiveInWater() {
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::setup);
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::enqueueIMC);
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::processIMC);
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::doClientStuff);
MinecraftForge.EVENT_BUS.register(this);
}
private void setup(final FMLCommonSetupEvent event)
{
LOGGER.info("SETUP START");
LOGGER.info("SETUP END");
}
private void doClientStuff(final FMLClientSetupEvent event) {
// do something that can only be done on the client
}
private void enqueueIMC(final InterModEnqueueEvent event)
{
// some example code to dispatch IMC to another mod
}
private void processIMC(final InterModProcessEvent event)
{
// some example code to receive and process InterModComms from other mods
}
@SubscribeEvent
public void onServerStarting(FMLServerStartingEvent event) {
LOGGER.info("server starting");
}
}
ファイル名(LiveInWater.java)とクラス名(public class LiveInWater)およびコンストラクタ(public LiveInWater())が一致していることを確かめましょう。またmodIdの指定(@Mod(“liveinwater”))が上で編集したmods.toml での指定と同じであるか確認しましょう。
このクラスが行っていることのイメージとしては、4つのライフサイクルをレールに乗せて、そのレールをForge上に挿入してやる感じです。これらの扱いはまだ詳しくないので一応4つ残しておきます。
また末尾の方にブロックを登録するコードがあったと思いますが、これは別にクラスを用意したほうがすっきりするのでこのファイル上では削除しました。
启动确认
请参考
构建您的Mod – Forge文档
[Java] 创建Minecraft的Mod 1.14.4【0. 基本文件】
创建Minecraft 1.14.4 Forge Mod的第二部分【基本文件的布置】