Jump to content

Recommended Posts

Posted

So, I've been working with creating a custom entity and that's going fairly well. Unfortunately, I cannot find the necessary methods to spawn entities procedurally during world generation. All of the methods that Minecraft uses to register entities in vanilla are protected methods, so I can't use those. I also have struggled to find reputable source code to take a look at on GitHub for registering entities to world spawning for 1.15.2, as it seems to be very different from previous versions. Is it possible that someone could refer me to a repo that does it elegantly or just to the necessary methods I should use?

 

Thanks 

Posted

Take a look at the method getSpawns in the Biome class. You can use that to add your entity into the spawnlist for each biomes.

Posted
1 hour ago, Ilyemu said:

Take a look at the method getSpawns in the Biome class. You can use that to add your entity into the spawnlist for each biomes.

Yes, like lIyemu said, you can use the getSpawns method for every biome. You can iterate through them all by using java stream.

 

You can then to .add and add your entity. Allow me to show you an example:

 

package <idk, whatever package name you want>;

import <wherever you keep static references to your entities>;
import net.minecraft.entity.EntityClassification;
import net.minecraft.world.biome.Biome.SpawnListEntry;
import net.minecraftforge.registries.ForgeRegistries;

public class ModEntitySpawn {

	public static void spawnMobs() {

		ForgeRegistries.BIOMES.getValues().stream()
          		//This is just some randsom filtering but do whatever you want her, or dont filter at all 
          		//if you want your entity to appear anywhere.
				.filter(biome -> biome.getRegistryName().toString().equals("minecraft:mushroom_fields")
						|| biome.getRegistryName().toString().equals("minecraft:mushroom_fields_field_shore"))
				
          		//this is the main dish
				.forEach(biome -> {
					biome.getSpawns(EntityClassification.<depends on what you want>)
                      		//min and max refer to number of entities in a group.
							.add(new SpawnListEntry(<static reference to your entity>, <weight>, <min>, <max>));
				});

	}

}

 

Then you have to register it in your event subscriber:

 

@SubscribeEvent
public static void onLoadSpawns (FMLCommonSetupEvent event) {
	ModEntitySpawn.spawnMobs();
}

 

 

I hope this is helpful! good luck!

  • Like 1
Posted
5 minutes ago, chubel10 said:

 

 



		ForgeRegistries.BIOMES.getValues().stream()
          		//This is just some randsom filtering but do whatever you want her, or dont filter at all 
          		//if you want your entity to appear anywhere.
				.filter(biome -> biome.getRegistryName().toString().equals("minecraft:mushroom_fields")
						|| biome.getRegistryName().toString().equals("minecraft:mushroom_fields_field_shore"))
				

 

Instead of doing checks via their registry name, maybe you can try using their registered biome instance, should avoid the problem of mismatch string in the future.

  • Like 1
  • 1 year later...
Posted

Been hopping around the forums lately and can't really get a concrete answer on how to make your custom entity spawn in a particular biome. The code I have registers the entity placement using EntitySpawnPlacementRegistry.register() and adds a new SpawnListEntry to all biomes, for testing purposes, and is then put in a FMLCommonSetupEvent event. However, when I launch the game, I see no entities spawn even though I have it to where it should spawn in all biomes. Below is the code that I have. Also please excuse any bad formatting :) All help is appreciated!

Note: The SpawnListEntry I used uses the same values that a Minecraft Sheep does besides the entity of course.

EventSpawnRocky.java

public class EventSpawnRocky 
{
    @SubscribeEvent
    public static void spawnRocky(FMLCommonSetupEvent event)
    {
        DeferredWorkQueue.runLater(new Runnable() {

            @Override
            public void run() {
                ForgeRegistries.BIOMES.getValues().stream()
                .forEach(
                        biome -> 
                        {
                            List<Biome.SpawnListEntry> creatures = biome.getSpawns(EntityClassification.CREATURE);
                            creatures.add(new SpawnListEntry(ModEntities.rocky, 12, 4, 4));
                        });
            }}
                );
    }
}

MainModClass - Things we care about in setup_common, which is a FMLCommonSetupEvent

		DeferredWorkQueue.runLater(new Runnable()
		{
			@Override
			public void run() 
			{
				EntitySpawnPlacementRegistry.register(ModEntities.rocky,
						EntitySpawnPlacementRegistry.PlacementType.ON_GROUND,
						Heightmap.Type.MOTION_BLOCKING_NO_LEAVES,
						EntityRocky::spawnConditions);
			}
		}); 

and

MinecraftForge.EVENT_BUS.register(EventSpawnRocky.class);

spawnConditions from EntityRocky.java - I have it returning true for now.

	public static boolean spawnConditions(EntityType<EntityRocky> rocky, IWorld world, SpawnReason reason, BlockPos blockPos, Random rand) 
	{
		return true;
	}
  • Guest locked this topic
Guest
This topic is now closed to further replies.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • hello i am wanting to know if anyone can help me with this crash happened when i tried to go to bed on server https://pastebin.com/CezfAbAh
    • I accidentally posted this in the ForgeGradle subforum, super sorry. I meant to post it in the regular modders forum. Hopefully it can still reach the right people!
    • I've been trying to make an addon mod for create, but setting up dependencies and trying to add the mod into my mod environment has proven a little difficult for me. Ive been searching this forum and I've seen problems that were close to mine but not exactly mine, searching the error output just yields  people having trouble with their own modid, not an addons. The error while loading Minecraft,  "mods.toml missing metadata of modid create" and  "The Mod File C:Users\user1\data\<mod>\build\resources\main has mods that were not found" My build.gradle file plugins { id 'eclipse' id 'idea' id 'maven-publish' id 'net.minecraftforge.gradle' version '[6.0,6.2)' id 'org.parchmentmc.librarian.forgegradle' version '1.+' } version = mod_version group = mod_group_id base { archivesName = mod_id } // Mojang ships Java 17 to end users in 1.18+, so your mod should target Java 17. java.toolchain.languageVersion = JavaLanguageVersion.of(17) println "Java: ${System.getProperty 'java.version'}, JVM: ${System.getProperty 'java.vm.version'} (${System.getProperty 'java.vendor'}), Arch: ${System.getProperty 'os.arch'}" minecraft { mappings channel: 'parchment', version: '2023.09.03-1.20.1' copyIdeResources = true runs { configureEach { workingDirectory project.file('run') property 'forge.logging.markers', 'REGISTRIES' property 'forge.logging.console.level', 'debug' property 'mixin.env.remapRefMap', 'true' property 'mixin.env.refMapRemappingFile', "${projectDir}/build/createSrgToMcp/output.srg" mods { "${mod_id}" { source sourceSets.main } } } client { // ... mods { other_mod { // ... } // Configures the 'example' mod create { // Add a source set to a mod's sources source sourceSets.main // Merges this configuration and specifies whether to overwrite existing properties merge mods.other_mod, true } } } server { property 'forge.enabledGameTestNamespaces', mod_id args '--nogui' } // This run config launches GameTestServer and runs all registered gametests, then exits. // By default, the server will crash when no gametests are provided. // The gametest system is also enabled by default for other run configs under the /test command. gameTestServer { property 'forge.enabledGameTestNamespaces', mod_id } data { // example of overriding the workingDirectory set in configureEach above workingDirectory project.file('run-data') // Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources. args '--mod', mod_id, '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/') } } } // Include resources generated by data generators. sourceSets.main.resources { srcDir 'src/generated/resources' } repositories { maven { url = 'https://maven.tterrag.com/' } } dependencies { // Specify the version of Minecraft to use. // Any artifact can be supplied so long as it has a "userdev" classifier artifact and is a compatible patcher artifact. // The "userdev" classifier will be requested and setup by ForgeGradle. // If the group id is "net.minecraft" and the artifact id is one of ["client", "server", "joined"], // then special handling is done to allow a setup of a vanilla dependency without the use of an external repository. minecraft "net.minecraftforge:forge:1.20.1-47.3.22" implementation fg.deobf("com.simibubi.create:create-${create_minecraft_version}:${create_version}:slim") { transitive = false } implementation fg.deobf("com.jozufozu.flywheel:flywheel-forge-${flywheel_minecraft_version}:${flywheel_version}") implementation fg.deobf("com.tterrag.registrate:Registrate:${registrate_version}") // Example mod dependency with JEI - using fg.deobf() ensures the dependency is remapped to your development mappings // The JEI API is declared for compile time use, while the full JEI artifact is used at runtime // compileOnly fg.deobf("mezz.jei:jei-${mc_version}-common-api:${jei_version}") // compileOnly fg.deobf("mezz.jei:jei-${mc_version}-forge-api:${jei_version}") // runtimeOnly fg.deobf("mezz.jei:jei-${mc_version}-forge:${jei_version}") // Example mod dependency using a mod jar from ./libs with a flat dir repository // This maps to ./libs/coolmod-${mc_version}-${coolmod_version}.jar // The group id is ignored when searching -- in this case, it is "blank" // implementation fg.deobf("blank:coolmod-${mc_version}:${coolmod_version}") // For more info: // http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html // http://www.gradle.org/docs/current/userguide/dependency_management.html } // This block of code expands all declared replace properties in the specified resource targets. // A missing property will result in an error. Properties are expanded using ${} Groovy notation. // When "copyIdeResources" is enabled, this will also run before the game launches in IDE environments. // See https://docs.gradle.org/current/dsl/org.gradle.language.jvm.tasks.ProcessResources.html tasks.named('processResources', ProcessResources).configure { var replaceProperties = [ minecraft_version: minecraft_version, minecraft_version_range: minecraft_version_range, forge_version: forge_version, forge_version_range: forge_version_range, loader_version_range: loader_version_range, mod_id: mod_id, mod_name: mod_name, mod_license: mod_license, mod_version: mod_version, mod_authors: mod_authors, mod_description: mod_description, ] inputs.properties replaceProperties filesMatching(['META-INF/mods.toml', 'pack.mcmeta']) { expand replaceProperties + [project: project] } } // Example for how to get properties into the manifest for reading at runtime. tasks.named('jar', Jar).configure { manifest { attributes([ 'Specification-Title' : mod_id, 'Specification-Vendor' : mod_authors, 'Specification-Version' : '1', // We are version 1 of ourselves 'Implementation-Title' : project.name, 'Implementation-Version' : project.jar.archiveVersion, 'Implementation-Vendor' : mod_authors, 'Implementation-Timestamp': new Date().format("yyyy-MM-dd'T'HH:mm:ssZ") ]) } // This is the preferred method to reobfuscate your jar file finalizedBy 'reobfJar' } // However if you are in a multi-project build, dev time needs unobfed jar files, so you can delay the obfuscation until publishing by doing: // tasks.named('publish').configure { // dependsOn 'reobfJar' // } // Example configuration to allow publishing using the maven-publish plugin publishing { publications { register('mavenJava', MavenPublication) { artifact jar } } } tasks.withType(JavaCompile).configureEach { options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation } -And my mods.toml file  modLoader="javafml" #mandatory loaderVersion="[47,)" license="MIT" [[mods]] modId="mechmod" version="0.0.1" displayName="Create: Mechs" authors="Affe" [[dependencies.mechmod]] modId="create" mandatory=true versionRange="[0,)" ordering="NONE" side="BOTH" [[dependencies.mechmod]] modId="forge" mandatory=true versionRange="[47.1.3,)" ordering="NONE" side="BOTH" [[dependencies.mechmod]] modId="minecraft" mandatory=true versionRange="[1.20,1.21)" ordering="NONE" side="BOTH" [[dependencies.mechmod]] modId="flywheel" mandatory=true versionRange="[0.6.11,0.6.12)" ordering="AFTER" side="CLIENT" I thought I had implemented the code from the "depending on create" section from their github correctly. But I assume I haven't implemented something that is needed. But I don't know what or where. I can also provide any file you think will help with your diagnosis. Any help would be appreciated, cheers!   
    • Yo i might be a lil bit late but on 1.20.6 you can call BuiltInRegistries.ITEMS.getTagOrEmpty(*required tag*) to get an iterable of item holders, this might be possible on 1.18.2 as well. Then you get the items using for(Holder<Item> holder: iterable) or the .forEach(Consumer<Holder<Item>>) method, or convert the iterable to array/list/collection. When you get the holders, use the .get() method to get the items
    • I'm troubleshooting some mods that I want for a single player world in 1.21.4 and I was having trouble with a resource library config crashing my game so I tried another mod and the library config for that was causing crashes as well. I've updated java and forge recently. Both of these dependency mods have caused Exit Code: -1 but I'm using the crash report for the mod that I was originally wanting to use. https://pastebin.com/82FZPwS2
  • Topics

×
×
  • Create New...

Important Information

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