Jump to content

[1.16.4]Received invalid biome id: -1


kyazuki

Recommended Posts

I added a custom biome and a custom world type which generates only the said biome.

Upon generating a new world, (and entering/walking around) the landscapes are generated as expected, but the message "Received invalid biome id: -1" shows up repeatedlly on the console, and the game is laggy.

The F3 debug screen shows the biome as Ocean, instead of my custom biome.

Saving the world and re-entering causes the newly generated chunks to be generated from the seed with vanilla biomes.

 

How do I fix this?

 

@Mod(TestMod.MODID)
@Mod.EventBusSubscriber(modid = TestMod.MODID, bus = Mod.EventBusSubscriber.Bus.MOD)
public class TestMod {
  public static final String MODID = "testmod";
  public static final Biome TEST_BIOME = TestWorldBiomeMaker.makeTestBiome();
  public static final TestWorldType TEST_WORLD = new TestWorldType();

  public TestWorld() {
    registerWorldType();
  }

  public static <T extends IForgeRegistryEntry<T>> T setup(final T entry, final String name) {
    return setup(entry, new ResourceLocation(MODID, name));
  }

  public static <T extends IForgeRegistryEntry<T>> T setup(final T entry, final ResourceLocation registryName) {
    entry.setRegistryName(registryName);
    return entry;
  }

  @SubscribeEvent
  public static void registerBiome(RegistryEvent.Register<Biome> event) {
    setup(TEST_BIOME, "test_biome");
    ForgeRegistries.BIOMES.register(TEST_BIOME);
  }

  public static void registerWorldType() {
    setup(TEST_WORLD, "test_world");
    ForgeRegistries.WORLD_TYPES.register(TEST_WORLD);
  }
}

 

Edited by kyazuki
Link to comment
Share on other sites

I can't fix...

Is it correct?

@Mod(TestMod.MODID)
@Mod.EventBusSubscriber(modid = TestMod.MODID, bus = Mod.EventBusSubscriber.Bus.MOD)
public class TestMod {
  public static final String MODID = "testmod";
  public static final Biome TEST_BIOME;
  public static final TestWorldType TEST_WORLD;

  public TestWorld() {
  }

  public static <T extends IForgeRegistryEntry<T>> T setup(final T entry, final String name) {
    return setup(entry, new ResourceLocation(MODID, name));
  }

  public static <T extends IForgeRegistryEntry<T>> T setup(final T entry, final ResourceLocation registryName) {
    entry.setRegistryName(registryName);
    return entry;
  }

  @SubscribeEvent
  public static void registerBiome(RegistryEvent.Register<Biome> event) {
    TEST_BIOME = TestWorldBiomeMaker.makeTestBiome();
    setup(TEST_BIOME, "test_biome");
    ForgeRegistries.BIOMES.register(TEST_BIOME);
  }

  @SubscribeEvent
  public static void registerWorldType(RegistryEvent.Register<ForgeWorldType> event) {
    TEST_WORLD = new TestWorldType();
    setup(TEST_WORLD, "test_world");
    ForgeRegistries.WORLD_TYPES.register(TEST_WORLD);
  }
}

 

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.