Jump to content

1.16.5 Loot Tables


Huntpor

Recommended Posts

I am able to Generate new Blocks and Items into my very simple mod ( just has Copper Ore ) while I learn. When it comes to those items I am able to generate the texture just fine, but I get a little stuck how how to allow the new blocks to generate their own item. Is Loot tables the correct thing? or should I be looking for something else? Don't even know where to begin, so details would be helpful. 

 

Thank you in advice. 

 

Edited by Huntpor
Link to comment
Share on other sites

1 hour ago, Huntpor said:

I am able to Generate new Blocks and Items into my very simple mod ( just has Copper Ore ) while I learn. When it comes to those items I am able to generate the texture just fine, but I get a little stuck how how to allow the new blocks to generate their own item. Is Loot tables the correct thing? or should I be looking for something else? Don't even know where to begin, so details would be helpful. 

 

Thank you in advice. 

 

i just tell you the best way i think is a loot table

Link to comment
Share on other sites

26 minutes ago, Huntpor said:

@Luis_ST Okay, but how would I start that? Like where do the folders need to be to get my server to see the Loot table? 

you could write the loot tables by hand, but forge provides a more developer friendly way of adding loot tables through data generators.

here's the docs for data generation: https://mcforge.readthedocs.io/en/1.16.x/datagen/intro/

 

but basically what you'll want to do is:

1- Subscribe to the GatherDataEvent in the Mod Event bus, there you can get the DataGenerator from the event parameter

2- You can register your Data Providers to the DataGenerator using DataGenerator#addProvider(), passing a new instance of your data Provider

3- Then you'll need a Data Provider for the mod's loot tables. You can create a new class that extends LootTableProvider.

3.1- in your LootTableProvider, add a constructor that takes a Data Generator and simply calls super, passing the data generator

3.2- You'll want to override the getTables methods, to return your instance of lootTables. all you need to do is return an ImmutableList of Pairs. the Pairs are composed of the LootTable constructor (We'll look at how to create the lootTables in a few steps), and the corresponding LootParameterSet (e.g.: for items that drops when you break a block: LootParameterSets.BLOCK)

3.3- You'll need to override the validate method, and honestly, the code for this is only boilerplate, so you can copy it like I did:

    @Override
    protected void validate(Map<ResourceLocation, LootTable> map, ValidationTracker validationtracker) {
        final Set<ResourceLocation> modLootTableIds =
            LootTables
                .getReadOnlyLootTables()
                .stream()
                .filter(lootTable -> lootTable.getNamespace().equals(Main.MOD_ID))
                .collect(Collectors.toSet());

        for (ResourceLocation id : Sets.difference(modLootTableIds, map.keySet()))
            validationtracker.addProblem("Missing mod loot table: " + id);

        map.forEach((id, lootTable) ->
            LootTableManager.validateLootTable(validationtracker, id, lootTable));
    }

3.4- Finally, override getName() and simply return your modid suffixed with "_lootTables"

 

4- Okay, now to writing the actual loot tables: you can create a class that overrides BlockLootTables (call it ModBlockLootTables for instance)

4.1- override addTables(), and in here you register the lootTables, the superclass has a lot of usefull helper methods, such as registerDropSelfLootTable, which makes the block drop itself as an item when broken.

4.2- override the getKnownBlocks() method, the code is also very boilerplatey, so here it is:

    @Override
    protected Iterable<Block> getKnownBlocks() {
        return StreamSupport
            .stream(ForgeRegistries.BLOCKS.spliterator(), false)
            .filter(
                entry -> entry.getRegistryName() != null &&
                    entry.getRegistryName().getNamespace().equals(Main.MOD_ID)
            ).collect(Collectors.toSet());
    }

 

5- Don't forget to add the construcor of this class to the List you're returning in the LootTablesProvider, in getTables

 

Regarding folder structure:

create a data package under your main src path, where you'd keep the init, block, and items folder

under I like to create a class DataGenerators, which handles the gatherData event.

then inside the data package, add two packages, one "client", and one "server"

in client you'd add any dataProvider that's client specific: such as a model provider, or a localization provider

in server you'd keep the common data providers: such as recipes, tags, and lootTables

the Custom LootTablesProvider class should go inside the data.server package

inside server add a loot package, whre you'll kep different lootTables, such as the Custom BlockLootTables class

 

EDIT: oh, and after you're done with the data folder, and after every change you make to it, you need to run the runData task, to actually generate the data, any data that is generated will be under the generated [main] folder

 

if you'd like some example code, take a look at my repo: https://github.com/jvcmarcenes/effetewood

Hope I've helped, if you still have any questions, please ask them

Edited by kiou.23
  • Thanks 1
Link to comment
Share on other sites

18 hours ago, Luis_ST said:

@kiou.23

 

 

if you konw json its the better way you also can overide the loot tables with a datapack

so i think its the better way.

and I didn't know that there was this possibility. but I'm open to new things.

the whole point of the Data Generators is for the dev to not waste time writing (copying and pasting) repetitive json

it automates the whole process of generating data.

sometimes it is better to write the json by hand, but if the project is quite big, looking into Data Generators is definetelly the way to go, not only for loot tables, but for everything that uses json erally, such as block and item models, blockstates, lang files, recipe files and tags.

it does save a lot of time, I can guarantee that

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.