Difference between revisions of "Datageneration/Tags/1.17"

From Forge Community Wiki
(Copy Datageneration/Tags to MC1.17 archive)
 
(No difference)

Latest revision as of 05:49, 6 December 2021

This page is under construction.

This page is incomplete, and needs more work. Feel free to edit and improve this page!

Tags can be generated by extending the ItemTagsProvider for Items or BlockTagsProvider for Blocks. For Custom Objects you would need to expand TagsProvider and give it the Object you want tags for. For the registration of you Tags you need to override the TagsProvider#addTags method.


Information

You can still use TagsProvider for Items and Blocks but you would need to implement a lot of stuff that is already done in ItemTagsProvider and BlockTagsProvider

Items/Blocks

First you should make a Tag$Named with ItemTags#bind for Items or BlockTags#bind for blocks, this will take the name of you Tag, see Tags#Conventions for more info. After you have the Tag$Named you can start with the actual creation of the Tag, you would first call TagsProvider#tag which takes the tag as an argument, this returns a TagsProvider$TagAppender. Now you can with TagsProvider$TagAppender#add add one or more Items/Blocks or other Tags to your own Tags.

Example for an Item Tag:

Tag.Named<Item> copperTag = ItemTags.bind("forge:ore/copper");
tag(copperTag).add(Init.COPPER_ORE_ITEM.get());


Custom Type for Tags

TBD