Jump to content

1.15 entity natural world spawn issue


Hoping1

Recommended Posts

This was originally posted in another thread but I think it makes much more sense as its own question. How do you register entity world spawns in 1.15.1? I looked through Cadiboo's tutorial but he hasn't gotten to that bit yet. The code I have is

public static void registerEntityWorldSpawn(EntityType<?> entity, Biome... biomes) {
  for (Biome biome : biomes) {
    if (biome != null) {
      biome.getSpawns(entity.getClassification()).add(new SpawnListEntry(entity, 10, 2, 10));
    }
  }
}

which is called as 

registerEntityWorldSpawn(HOP_MOB, Biomes.FOREST, Biomes.BIRCH_FOREST, Biomes.DARK_FOREST, Biomes.BIRCH_FOREST_HILLS, Biomes.DARK_FOREST_HILLS, Biomes.FLOWER_FOREST, Biomes.TALL_BIRCH_FOREST);

in a

@SubscribeEvent
public static void registerEntities(final RegistryEvent.Register<EntityType<?>> event) {}

which is itself in a 

@Mod.EventBusSubscriber(bus=Mod.EventBusSubscriber.Bus.MOD)
public static class RegistryEvents{}

Within my main mod class. Sorry for the odd format but it felt the cleanest way to share my code. I know enough java to know that it isn't some basic syntax error, and anyway, when I run it I don't get any errors. The issue is the mob doesn't spawn naturally at all. I can spawn it in fine with my custom spawn egg and it works perfectly, so the issue is only with natural world spawns. The method I'm using, as seen above, was taken from a 1.14 tutorial released in July 2019, so the reason it doesn't work definitely has to do with something specific to 1.15. That's all the useful info I have, unfortunately. And if I'm wrong in any of my assumptions please let me know. Thanks!

Link to comment
Share on other sites

6 hours ago, Hoping1 said:

if (biome != null) {

You really shouldn’t need this check.

Please show your full code or link a GitHub.

  • Like 1

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

That line can't possibly be the reason it's broken unless I'm very confused about java. I got it from a tutorial but it makes sense to me. As for the full code, prepare for a wall of text:

EntitiesList.java

package com.hoping1.hopingmod.lists;

import com.hoping1.hopingmod.HopingMod;
import com.hoping1.hopingmod.entities.HopMob;

import net.minecraft.entity.EntityClassification;
import net.minecraft.entity.EntityType;
import net.minecraft.item.Item;
import net.minecraft.item.ItemGroup;
import net.minecraft.item.SpawnEggItem;
import net.minecraft.util.ResourceLocation;
import net.minecraft.world.biome.Biome;
import net.minecraft.world.biome.Biome.SpawnListEntry;
import net.minecraft.world.biome.Biomes;
import net.minecraftforge.event.RegistryEvent;

public class EntitiesList {
    public static EntityType<?> HOP_MOB = EntityType.Builder.create(HopMob::new, EntityClassification.CREATURE).build(HopingMod.modid+":hop_mob").setRegistryName(new ResourceLocation(HopingMod.modid, "hop_mob"));
    public static Item registerEntitySpawnEgg(EntityType<?> type, int color1, int color2, String name) {
        SpawnEggItem item = new SpawnEggItem(type, color1, color2, new Item.Properties().group(ItemGroup.MISC));
        item.setRegistryName(new ResourceLocation(HopingMod.modid, name));
        return item;
    }
    public static void registerEntitySpawnEggs(final RegistryEvent.Register<Item> event) {
        event.getRegistry().registerAll(
            ItemList.hop_mob_egg = registerEntitySpawnEgg(HOP_MOB, 0x00ffff, 0xaaffaa, "hop_mob_egg")
        );
    }
    public static void registerEntityWorldSpawn(EntityType<?> entity, Biome... biomes) {
        for (Biome biome : biomes) {
            if (biome != null) {
                biome.getSpawns(entity.getClassification()).add(new SpawnListEntry(entity, 1000, 2, 10));
            }
        }
    }
    public static void registerEntityWorldSpawns() {
        registerEntityWorldSpawn(HOP_MOB, Biomes.FOREST, Biomes.BIRCH_FOREST, Biomes.DARK_FOREST, Biomes.BIRCH_FOREST_HILLS, Biomes.DARK_FOREST_HILLS, Biomes.FLOWER_FOREST, Biomes.TALL_BIRCH_FOREST);
    }
}

 

HopingMod.java

package com.hoping1.hopingmod;

import org.apache.logging.log4j.Logger;

import com.hoping1.hopingmod.client.render.HopingRenderRegistry;
import com.hoping1.hopingmod.lists.ArmorMaterialList;
import com.hoping1.hopingmod.lists.BlockList;
import com.hoping1.hopingmod.lists.EntitiesList;
import com.hoping1.hopingmod.lists.ItemList;
import com.hoping1.hopingmod.lists.ToolMaterialList;
import com.hoping1.hopingmod.world.OreGeneration;

import org.apache.logging.log4j.LogManager;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.entity.EntityType;
import net.minecraft.item.ArmorItem;
import net.minecraft.item.BlockItem;
import net.minecraft.item.HoeItem;
import net.minecraft.item.Item;
import net.minecraft.item.ItemGroup;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.event.RegistryEvent;
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.javafmlmod.FMLJavaModLoadingContext;
import net.minecraft.inventory.EquipmentSlotType;

@Mod("hopingmod")
public class HopingMod {
    public static HopingMod instance;
    public static String modid = "hopingmod";
    private static Logger logger = LogManager.getLogger(modid);
    public HopingMod() {
        instance = this;
        FMLJavaModLoadingContext.get().getModEventBus().addListener(this::setup);
        FMLJavaModLoadingContext.get().getModEventBus().addListener(this::clientRegistries);
        MinecraftForge.EVENT_BUS.register(this);
    };
    private void setup(final FMLCommonSetupEvent event) {
        OreGeneration.setupOreGeneration();
        logger.info("Setup method registered");
    };
    private void clientRegistries(final FMLClientSetupEvent event) {
        HopingRenderRegistry.registryEntityRenders();
        logger.info("clientRegistries method registered");
    }
    @Mod.EventBusSubscriber(bus=Mod.EventBusSubscriber.Bus.MOD)
    public static class RegistryEvents{
        @SubscribeEvent
        public static void registerItems(final RegistryEvent.Register<Item> event) {
            event.getRegistry().registerAll(
                ItemList.hoping_item = new Item(new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_item")),
                ItemList.hoping_hoe = new HoeItem(ToolMaterialList.hopingmod, 0.0f, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_hoe")),
                ItemList.hoping_boots = new ArmorItem(ArmorMaterialList.hopingmod, EquipmentSlotType.FEET, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_boots")),
                ItemList.hoping_block = new BlockItem(BlockList.hoping_block, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_block.getRegistryName()),
                ItemList.hoping_ore = new BlockItem(BlockList.hoping_ore, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_ore.getRegistryName()),
                ItemList.hoping_ore_nether = new BlockItem(BlockList.hoping_ore_nether, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_ore_nether.getRegistryName())
            );
            EntitiesList.registerEntitySpawnEggs(event);
            logger.info("Items registered");
        }
        @SubscribeEvent
        public static void registerBlocks(final RegistryEvent.Register<Block> event) {
            event.getRegistry().registerAll(
                BlockList.hoping_block = new Block(Block.Properties.create(Material.IRON).hardnessAndResistance(2.0f, 3.0f).lightValue(5)).setRegistryName(location("hoping_block")),
                BlockList.hoping_ore = new Block(Block.Properties.create(Material.ROCK).hardnessAndResistance(2.0f, 3.0f)).setRegistryName(location("hoping_ore")),
                BlockList.hoping_ore_nether = new Block(Block.Properties.create(Material.ROCK).hardnessAndResistance(2.0f, 3.0f)).setRegistryName(location("hoping_ore_nether"))
            );
            logger.info("blocks registered");
        }
        @SubscribeEvent
        public static void registerEntities(final RegistryEvent.Register<EntityType<?>> event) {
            event.getRegistry().registerAll(EntitiesList.HOP_MOB);
            EntitiesList.registerEntityWorldSpawns();
            logger.info("entities registered");
        }
        private static ResourceLocation location(String name) {
            return new ResourceLocation(modid, name);
        }
    }
}

 

No errors and absolutely everything works perfectly except that the HopMob entities don't spawn naturally. If you want code from other files just ask!

Link to comment
Share on other sites

4 hours ago, Cadiboo said:

Please show your full code or link a GitHub

I think it would be better if you posted your code from github. Let me guess, you followed a tutorial from HarryTalks, right?

Edited by DragonITA

New in Modding? == Still learning!

Link to comment
Share on other sites

40 minutes ago, DragonITA said:

I think it would be better if you posted your code from github. Let me guess, you followed a tutorial from HarryTalks, right?

I don't have a github. And yes, that's the tutorial. Forge documentation is effectively useless and there aren't really any 1.15 tutorials except cadiboo's unfinished one

  • Like 2
Link to comment
Share on other sites

7 hours ago, Hoping1 said:

That line can't possibly be the reason it's broken unless I'm very confused about java. I got it from a tutorial but it makes sense to me.

It’s not the reason it’s broken, it’s just useless code. This is your own internal method that you’re using - you never pass null into your method (and obviously shouldn’t) so the check is pointless. However, if you accidentally do pass null into this method (because an objectholder failed or you forgot to create a biome) you’re not going to want it to just fail silently - you’re going to want to know about it.

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

15 minutes ago, Cadiboo said:

However, if you accidentally do pass null into this method (because an objectholder failed or you forgot to create a biome) you’re not going to want it to just fail silently - you’re going to want to know about it.

Fair enough, I'll change it. Do you know what's wrong with my natural spawn algorithm?

Link to comment
Share on other sites

Some console logs that I think might be pertinent, though I'm not a good enough modder to make anything useful out of them. You can see above the line in the HopingMod.java file where I log the logged message. The logs here look the same here as they do elsewhere, except of course for the logged message.

[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ModList/LOADING]: Dispatching synchronous event LifecycleEvent:LOAD_REGISTRIES
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Firing event for modid forge : RegistryEvent.Register<minecraft:enchantment>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Fired event for modid forge : RegistryEvent.Register<minecraft:enchantment>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Firing event for modid hopingmod : RegistryEvent.Register<minecraft:enchantment>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Fired event for modid hopingmod : RegistryEvent.Register<minecraft:enchantment>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.re.GameData/REGISTRIES]: Applying holder lookups: minecraft:enchantment
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.re.GameData/REGISTRIES]: Holder lookups applied: minecraft:enchantment
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ModList/LOADING]: Dispatching synchronous event LifecycleEvent:LOAD_REGISTRIES
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Firing event for modid forge : RegistryEvent.Register<minecraft:entity_type>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Fired event for modid forge : RegistryEvent.Register<minecraft:entity_type>
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Firing event for modid hopingmod : RegistryEvent.Register<minecraft:entity_type>
[m[32m[18:11:26] [Render thread/INFO] [hopingmod/]: entities registered
[m[36m[18:11:26] [Render thread/DEBUG] [ne.mi.fm.ja.FMLModContainer/LOADING]: Fired event for modid hopingmod : RegistryEvent.Register<minecraft:entity_type>

Can someone please help me?

Link to comment
Share on other sites

3 hours ago, Hoping1 said:

Fair enough, I'll change it. Do you know what's wrong with my natural spawn algorithm?

No, but I’m general static initialisers are bad and you shouldn’t use them. It’s unlikely that this is the cause of it, but you should fix it anyway (you’ll need to create your entity entry but not register it in your item registry event to register it’s spawn egg, then register it in the entity registry event). Have you tried looking at vanilla’s code to see how it gets a creature to spawn? Working back from that code should allow you see why yours isn’t working.

 

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

 
 
 
 
2
26 minutes ago, Cadiboo said:

No, but I’m general static initialisers are bad and you shouldn’t use them. It’s unlikely that this is the cause of it, but you should fix it anyway (you’ll need to create your entity entry but not register it in your item registry event to register it’s spawn egg, then register it in the entity registry event)

I'm confused. You mean don't register the spawn egg until the entity registry event?

 

28 minutes ago, Cadiboo said:

Have you tried looking at vanilla’s code to see how it gets a creature to spawn? Working back from that code should allow you see why yours isn’t working.

No, I haven't. Where do I find the vanilla code?

Link to comment
Share on other sites

1 hour ago, Hoping1 said:

I'm confused. You mean don't register the spawn egg until the entity registry event?

No.

Item Registry Event:

- Create EntityType
- Create and register Spawn Egg

EntityType Registry Event:
- Register EntityType

1 hour ago, Hoping1 said:

No, I haven't. Where do I find the vanilla code?

In External/Referenced Libraries in your IDE. I assume spawning entities would be in ServerWorld.

  • Thanks 1

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

22 minutes ago, Cadiboo said:

No.

Item Registry Event:

- Create EntityType
- Create and register Spawn Egg

EntityType Registry Event:
- Register EntityType

I don't know if this is what you meant but I changed the code so it only declares the HOP_MOB in EntitiesList but doesn't set it to anything until the items registry event (shown below) and just for the heck of it I decided to run AND IT WORKED!! HopMobs are naturally spawning in my world now. THANK you so much, and I'm surprised that the code I took from a 1.14 tutorial is obsolete in that way, of all the possible ways, lol.

public class EntitiesList {
	public static EntityType<?> HOP_MOB;

and

@SubscribeEvent
public static void registerItems(final RegistryEvent.Register<Item> event) {
	event.getRegistry().registerAll(
		ItemList.hoping_item = new Item(new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_item")),
		ItemList.hoping_hoe = new HoeItem(ToolMaterialList.hopingmod, 0.0f, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_hoe")),
		ItemList.hoping_boots = new ArmorItem(ArmorMaterialList.hopingmod, EquipmentSlotType.FEET, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(location("hoping_boots")),
		ItemList.hoping_block = new BlockItem(BlockList.hoping_block, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_block.getRegistryName()),
		ItemList.hoping_ore = new BlockItem(BlockList.hoping_ore, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_ore.getRegistryName()),
		ItemList.hoping_ore_nether = new BlockItem(BlockList.hoping_ore_nether, new Item.Properties().group(ItemGroup.MISC)).setRegistryName(BlockList.hoping_ore_nether.getRegistryName())
	);
	EntitiesList.HOP_MOB = EntityType.Builder.create(HopMob::new, EntityClassification.CREATURE).build(HopingMod.modid+":hop_mob").setRegistryName(new ResourceLocation(HopingMod.modid, "hop_mob"));
	EntitiesList.registerEntitySpawnEggs(event);
	logger.info("Items registered");
}

Hopefully, this helps someone besides me, and again, thank you! You have no idea how long I've been looking for how to fix this lmao

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



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Etumax Royal Honey Price In Pakistan - Get Free Delivery Shop Today Online With Online Shopping in Pakistan Etumax Royal Honey Available At Our Store Online Shopping in Pakistan, 
    • I want to make a tree decorator that will generate a beehive under branches of my tree. I have no idea how to check for branches and make beehives generate because TreeDecorator.Context.logs() is just a block pos and i dont understand how it works. i hope ill get an answer here.
    • Imagine this: you've painstakingly accumulated $97,000 worth of Bitcoin, only to see it vanish into the digital abyss at the hands of cunning scammers. It's a devastating blow, leaving you feeling helpless and betrayed. But fear not, for Lee Ultimate Hacker is here to turn the tide in your favor. After conducting extensive research on cryptocurrency recovery options, I stumbled upon Lee Ultimate Hacker, and it proved to be the most suitable choice for the daunting task at hand. Despite my initial skepticism, they shattered my doubts by successfully retrieving $92,000 of the lost Bitcoin—a feat I once deemed impossible. From the moment I reached out to Lee Ultimate Hacker and provided them with all the pertinent information about the fraudulent transaction, they sprang into action with unwavering determination. True to their word, they delivered on their promise to recover the lost Bitcoin within an impressive timeframe of 24 to 72 hours. Their professionalism, expertise, and commitment to their clients were truly commendable, transforming what seemed like an insurmountable ordeal into a resounding triumph. In my eyes, the investment of both time and money was more than justified by the remarkable outcome achieved by Lee Ultimate Hacker. So, if you've fallen victim to cryptocurrency scams and are grappling with the anguish of lost funds, don't despair. Reach out to Lee Ultimate Hacker and let them work their magic. Their track record of success speaks for itself, and with their assistance, you can reclaim what's rightfully yours and emerge stronger than ever before. Don't let the darkness of cybercrime overshadow your financial future. Take a stand against fraudsters with the help of Lee Ultimate Hacker, and witness the transformation from despair to triumph. Your journey to recovery starts here. LEEULTIMATEHACKER@ AOL. COM or Support @ leeultimatehacker . com. telegram:LEEULTIMATE or wh@tsapp +1  (715) 314  -  9248 https://leeultimatehacker.com Thank you.
    • There's a scheme I got into where they promised to trade Bitcoin for me and take a cut as a commission. Seemed like a good idea at the time. But then, things went south real fast. They ended up transferring   $190,000 worth of my Bitcoin. I was devastated and felt completely helpless. That's when I stumbled upon the Wizard Web Recovery Tool. It was like a beacon of hope amid chaos. With this tool, I could finally start digging into what went wrong and hopefully get my Bitcoin back. Using Wizard Web was surprisingly easy. I just had to plug in some details about my Bitcoin account and let it do its thing. It started scanning the internet, looking for any clues about what happened to my Bitcoin. It felt like having a detective on my side, searching for answers. And guess what? Wizard Web found some leads. It uncovered evidence of the scheme's shady dealings and helped me track down the people responsible for losing my Bitcoin. Armed with this information, I took the case to court. After a long and hard-fought legal battle, the court ruled in my favor. The perpetrators were held accountable for their actions and faced criminal charges for their involvement in the scheme. It was a victory not just for me, but for anyone who's been taken advantage of by these kinds of scams. Thanks to Wizard Web Recovery, I was able to get justice and reclaim what was rightfully mine. It showed me that even in the face of adversity, there's always a way to fight back. And with the right tools and determination, anything is possible.   The following is the contact information for Wizard Web Recovery.   Email: wizard web recovery((@))programmer . net
    • Hello, good morning. I know some programming and I'm interested in mod creation. That's why I've decided to follow a tutorial guide on YouTube by TurtyWurty. https://www.youtube.com/watch?v=DhoX9cmAZqA&t=160s&ab_channel=TurtyWurty I've followed the tutorial perfectly. The problem is that when checking the food, the texture doesn't load for me. However, everything seems fine no matter how much I check. I'm sure it's something trivial, the problem is that I can't find it. Could you help me solve it, please? I leave a zip of my file so you can edit it freely. forge-1.20-Civicraft.rar
  • Topics

×
×
  • Create New...

Important Information

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