🇨🇳 中文 (Chinese - China)
🇨🇳 中文 (Chinese - China)
外观
🇨🇳 中文 (Chinese - China)
🇨🇳 中文 (Chinese - China)
外观
本页面基于这个版本编写:
1.21.4
本页面基于这个版本编写:
1.21.4
方块是构成 Minecraft 世界的主要组成部分——和 Minecraft 的其他一切一样,是储存在注册表中的。
如果你已经完成了创建你的第一个物品,那么这一过程会非常熟悉——你会需要创建一个注册方块以及方块物品的方法。
你应该把这个方块放在叫做 ModBlocks
的类中(也可以是其他你想要的名称)。
Mojang 对原版方块的处理方法和这个也非常相似,你可以参考 Blocks
类看看他们是怎么做的。
public class ModBlocks {
public static Block register(Block block, RegistryKey<Block> blockKey, boolean shouldRegisterItem) {
// Sometimes, you may not want to register an item for the block.
// Eg: if it's a technical block like `minecraft:air` or `minecraft:end_gateway`
if (shouldRegisterItem) {
// Items need to be registered with a different type of registry key, but the ID
// can be the same.
RegistryKey<Item> itemKey = RegistryKey.of(RegistryKeys.ITEM, blockKey.getValue());
BlockItem blockItem = new BlockItem(block, new Item.Settings().registryKey(itemKey));
Registry.register(Registries.ITEM, itemKey, blockItem);
}
return Registry.register(Registries.BLOCK, blockKey, block);
}
}
像物品一样,你需要确保类被加载,这样所有包含方块实体的静态字段都会初始化。
你可以添加一个 initialize
方法,并在模组的初始化中调用以进行静态初始化。
INFO
如果不知道什么是静态初始化,那么这里说下,这是初始化类中的所有静态字段的过程。 JVM 加载类时,以及创建类的任何实例之前,都会完成这一过程。
public class ModBlocks {
// ...
public static void initialize() {}
}
public class FabricDocsReferenceBlocks implements ModInitializer {
@Override
public void onInitialize() {
ModBlocks.initialize();
}
}
和物品类似,方块会在构造函数中接收一个 Block.Settings
类,指定了方块的属性,例如其声音效果和挖掘等级。
这里不会把所有选项都提到——可以查看类本身来看看各种选项,应该能直接懂的。
这里为作举例,我们会创建一个拥有和泥土的相同属性但材料不同的方块。
TIP
可以使用 AbstractBlock.Settings.copy(AbstractBlock block)
从已存在的方块中复制 settings,这种情况下,可以使用 Blocks.DIRT
以从泥土中复制 settings,但是为作举例,我们使用 builder。
public static final RegistryKey<Block> CONDENSED_DIRT_KEY = RegistryKey.of(
RegistryKeys.BLOCK,
Identifier.of(FabricDocsReference.MOD_ID, "condensed_dirt")
);
public static final Block CONDENSED_DIRT = register(
new Block(AbstractBlock.Settings.create().registryKey(CONDENSED_DIRT_KEY).sounds(BlockSoundGroup.GRASS)),
CONDENSED_DIRT_KEY,
true
);
我们上一步创建过 regisger
方法,要自动创建方块物品,我们在方法的 shouldRegisterItem
参数中传入 true
。
由于 BlockItem
是自动创建和注册的,要将其添加到物品组中,必须使用 Block.asItem()
方法来获得 BlockItem
实例。
例如,我们使用在自定义物品组页面中创建的自定义物品组。
public static final RegistryKey<Block> CONDENSED_OAK_LOG_KEY = RegistryKey.of(
RegistryKeys.BLOCK,
Identifier.of(FabricDocsReference.MOD_ID, "condensed_oak_log")
);
public static final Block CONDENSED_OAK_LOG = register(
new PillarBlock(
AbstractBlock.Settings.create()
.registryKey(CONDENSED_OAK_LOG_KEY)
.sounds(BlockSoundGroup.WOOD)
), CONDENSED_OAK_LOG_KEY, true
);
你应该注意到,你的方块现在在创造模式物品栏中,并且可以放在世界中!
但是还有点问题——方块物品没有命名,方块没有纹理、方块模型和物品模型。
要添加翻译,必须在你的翻译文件——assets/<mod id here>/lang/en_us.json
中创建翻译键。(类似地,中文翻译可添加到 assets/<0>/lang/zh_cn.json
。)
Minecraft 会在创造模式物品栏中,以及其他显示方块名称的地方(例如命令反馈)中显示这个翻译。
{
"block.mod_id.condensed_dirt": "Condensed Dirt"
}
你可以重启游戏,或者构建你的模组,然后在游戏里按 F3 + T 以重新加载资源文件——你将会看到方块在创造模式物品栏里或者其他地方(例如统计屏幕)中有个名字了。
所有方块纹理都可以在 assets/<mod id here>/textures/block
文件夹中找到——“Condensed Dirt”方块的示例纹理可以自由使用。
要确保模型在游戏内显示,必须创建方块和物品模型,“Condensed Dirt”方块的方块和物品模型分别可以在下列地方找到:
assets/<mod id here>/models/block/condensed_dirt.json
assets/<mod id here>/models/item/condensed_dirt.json
物品模型很简单,只需要继承方块模型即可,因为大多数方块模型都支持在 GUI 中渲染。
Not Found: /home/runner/work/fabric-docs/fabric-docs/reference/latest/src/main/resources/assets/fabric-docs-reference/models/item/condensed_dirt.json
但是,在我们的例子中,方块模型就必须继承 block/cube_all
模型。
Not Found: /home/runner/work/fabric-docs/fabric-docs/reference/latest/src/main/resources/assets/fabric-docs-reference/models/block/condensed_dirt.json
载入游戏,你可能会发现模型还是缺失。 这是因为,你还需要添加方块状态定义。
方块状态定义用于指示游戏基于当前方块的状态要渲染哪个模型。
示例方块没有复杂的方块状态,只需要定义一项。
这个方块应该位于 assets/mod_id/blockstates
文件夹内,名字应该匹配在 ModBlocks
类中注册方块时使用的方块 ID。 例如,方块 ID 是 condensed_dirt
,那么文件名称就是 condensed_dirt.json
。
Not Found: /home/runner/work/fabric-docs/fabric-docs/reference/latest/src/main/resources/assets/fabric-docs-reference/blockstates/condensed_dirt.json
方块状态很复杂,会在之后的页面方块状态中详述。
重启游戏,或者按下F3 + T重新加载资源文件以应用更改——你应该能看到方块在物品栏内的纹理,以及在世界中呈现:
在生存模式下破坏方块时,你可能看到方块不会掉落——你可能想要这个功能,但是要让方块被破坏时掉落为物品,必须要实现其战利品表——战利品表文件应置于 data/<mod id here>/loot_table/blocks/
文件夹中。
INFO
对战利品表的更深入理解,可参考 Minecraft Wiki - 战利品表页面。
{
"type": "minecraft:block",
"pools": [
{
"rolls": 1,
"entries": [
{
"type": "minecraft:item",
"name": "fabric-docs-reference:condensed_dirt"
}
],
"conditions": [
{
"condition": "minecraft:survives_explosion"
}
]
}
]
}
这个战利品表提供了方块在被破坏以及被爆炸破坏时掉落的单个方块物品。
你可能也想要让方块只能被特定类型的方块挖掘——例如,可能想让你的方块用锹挖掘更快。
所有的工具标签都位于 data/minecraft/tags/block/mineable/
文件夹内——其中文件的名称取决于使用的工具的类型,是以下之一:
hoe.json
(锄)axe.json
(斧)pickaxe.json
(镐)shovel.json
(锹)文件的内容很简单,是要添加到标签中的物品的列表。
这个例子会将“Condensed Dirt”方块添加到 shovel
标签中。
{
"replace": false,
"values": ["fabric-docs-reference:condensed_dirt"]
}
如果应使用工具来挖掘此方块,则需要在方块属性(Block.Settings
)中添加.requiresTool()
,并添加相应的挖掘标签。
类似地,data/minecraft/tags/block/
文件夹内也可以找到挖掘等级,并遵循以下格式:
needs_stone_tool.json
- 最低需要石质工具needs_iron_tool.json
- 最低需要铁质工具needs_diamond_tool.json
- 最低需要钻石工具文件与挖掘工具文件的格式相同——要添加到标签中的物品的列表。
如果将多个方块添加到你的模组中,可能需要考虑使用数据生成来自动化创建方块和物品模型、方块状态定义和战利品表。