Pour ajouter un bloc à votre mod, vous devrez enregistrer une nouvelle instance de la classe Block
. Pour avoir plus de contrôle sur votre bloc, vous pourrez créer une classe de bloc personnalisée. Nous verrons également comment ajouter un modèle de bloc.
Pour commencer, créez une instance de Block
dans la classe principale de votre mod. Le constructeur de Block
utilise le builder FabricBlockSettings pour définir les propriétés de base du bloc, telles que la dureté et la résistance aux explosions.
public class ExampleMod implements ModInitializer { // une instance de notre nouveau bloc public static final Block EXAMPLE_BLOCK = new Block(FabricBlockSettings.of(Material.METAL).build()); [...] }
Enregistrer des blocs est la même chose qu'enregistrer des objets. Appelez Registry.register
et écrivez les arguments appropriés.
public class ExampleMod implements ModInitializer { // création du bloc […] @Override public void onInitialize() { } }
Votre bloc ne sera pas accessible en tant qu'objet, mais il peut être vu en jeu grâce à la commande /setblock ~ ~ ~ tutorial:example_block
.
Dans la plupart des cas, vous souhaitez être capable de placer votre bloc avec un objet. Pour cela, vous devez enregistrer un BlockItem correspondant dans le registre des objets. Vous pouvez faire cela en enregistrant une instance de BlockItem
sous Registry.ITEM
. Le nom de registre de l'objet devrait normalement être le même que le nom de registre du bloc.
public class ExampleMod implements ModInitializer { // création du bloc […] @Override public void onInitialize() { // enregistrement du bloc [...] } }
Comme vous l'avez probablement remarqué, le bloc est simplement un motif en damier noir et violet en jeu. C'est la façon qu'utilise Minecraft pour vous montrer que le bloc n'a pas de modèle. Faire le modèle d'un bloc est un peu plus difficile que faire le modèle d'un objet. Vous aurez besoin de trois fichiers : un fichier d'états de bloc, un fichier de modèle de bloc et un fichier de modèle d'objet si le bloc a un BlockItem
. Des textures sont également nécessaires si vous n'utilisez pas celles vanilla. Les fichiers doivent être situés ici :
États de bloc : src/main/resources/assets/tutorial/blockstates/example_block.json Modèle de bloc : src/main/resources/assets/tutorial/models/block/example_block.json Modèle d'objet : src/main/resources/assets/tutorial/models/item/example_block.json Texture de bloc : src/main/resources/assets/tutorial/textures/block/example_block.png
Le fichier d'états de bloc détermine quel modèle le bloc doit utiliser en fonction de son état de bloc. Puisque notre bloc a seulement un état, le fichier est aussi simple que cela :
{ "variants": { "": { "model": "tutorial:block/example_block" } } }
Le fichier de modèle de bloc définit la forme et la texture de votre bloc. Nous allons utiliser block/cube_all
, qui nous permettra de définir facilement la même texture sur toutes les faces du bloc.
{ "parent": "block/cube_all", "textures": { "all": "tutorial:block/example_block" } }
Dans la plupart des cas, vous souhaitez que le bloc ait la même apparence tenu en main. Pour cela, vous pouvez créer un fichier de modèle d'objet qui hérite du fichier de modèle de bloc :
{ "parent": "tutorial:block/example_block" }
Chargez Minecraft et votre bloc devrait finalement avoir une texture !
Le bloc doit avoir une table de butin pour que des objets apparaissent lorsque le bloc est détruit. En supposant que vous ayez créé un objet pour votre bloc et que vous l'ayez enregistré avec le même nom que le bloc, le fichier ci-dessous produira un butin de bloc régulier.
{ "type": "minecraft:block", "pools": [ { "rolls": 1, "entries": [ { "type": "minecraft:item", "name": "tutorial:example_block" } ], "conditions": [ { "condition": "minecraft:survives_explosion" } ] } ] }
Lorsqu'il sera détruit en mode survie, le bloc donnera maintenant un objet.
Afin de créer un bloc simple, l'approche ci-dessus fonctionne bien, mais vous souhaitez parfois un bloc spécial ayant des mécaniques uniques. Pour cela, nous allons créer une classe distincte qui étend Block
. La classe nécessite un constructeur qui prend un argument BlockSettings
.
public class ExampleBlock extends Block { public ExampleBlock(Settings settings) { super(settings); } }
Comme nous l'avons fait dans le tutoriel sur les objets, vous pouvez remplacer des méthodes dans la classe du bloc pour avoir des fonctionnalités personnalisées. Disons que vous souhaitez rendre votre bloc transparent :
@Environment(EnvType.CLIENT) public BlockRenderLayer getRenderLayer() { return BlockRenderLayer.TRANSLUCENT; }
Pour ajouter ce bloc dans le jeu, remplacez new Block
par new ExampleBlock
lorsque vous l'enregistrez.
public class ExampleMod implements ModInitializer { // une instance de notre nouveau bloc public static final ExampleBlock EXAMPLE_BLOCK = new ExampleBlock(Block.Settings.of(Material.STONE)); [...] }
Votre bloc personnalisé devrait maintenant être transparent !
Ajouter des états simples à un bloc, comme des entiers et des booléens (en).
Donner à des blocs une entité de bloc pour qu'ils puissent avoir des états avancés, comme des inventaires et des classes (en). Également nécessaire pour de nombreuses choses, comme des interfaces graphiques et du rendu de bloc personnalisé.