Jump to content

[1.7.10] [SOLVED] Custom model is invisible


Recommended Posts

I literally have no idea what I did wrong... It does error with the texture though.

 

The Error:

20:49:40] [server thread/ERROR] [FML]: A TileEntity type com.fire.testmod.TileEntity.TileEntityTestCustomModel has throw an exception trying to write state. It will not persist. Report this to the mod author
java.lang.RuntimeException: class com.fire.testmod.TileEntity.TileEntityTestCustomModel is missing a mapping! This is a bug!
at net.minecraft.tileentity.TileEntity.writeToNBT(TileEntity.java:96) ~[TileEntity.class:?]
at net.minecraft.world.chunk.storage.AnvilChunkLoader.writeChunkToNBT(AnvilChunkLoader.java:395) [AnvilChunkLoader.class:?]
at net.minecraft.world.chunk.storage.AnvilChunkLoader.saveChunk(AnvilChunkLoader.java:204) [AnvilChunkLoader.class:?]
at net.minecraft.world.gen.ChunkProviderServer.safeSaveChunk(ChunkProviderServer.java:287) [ChunkProviderServer.class:?]
at net.minecraft.world.gen.ChunkProviderServer.saveChunks(ChunkProviderServer.java:340) [ChunkProviderServer.class:?]
at net.minecraft.world.WorldServer.saveAllChunks(WorldServer.java:863) [WorldServer.class:?]
at net.minecraft.server.MinecraftServer.saveAllWorlds(MinecraftServer.java:370) [MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer.stopServer(MinecraftServer.java:405) [MinecraftServer.class:?]
at net.minecraft.server.integrated.IntegratedServer.stopServer(IntegratedServer.java:266) [integratedServer.class:?]
at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:538) [MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer$2.run(MinecraftServer.java:752) [MinecraftServer$2.class:?]

 

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

I literally have no idea what I did wrong... It does error with the texture though.

 

The Error:

20:49:40] [server thread/ERROR] [FML]: A TileEntity type com.fire.testmod.TileEntity.TileEntityTestCustomModel has throw an exception trying to write state. It will not persist. Report this to the mod author
java.lang.RuntimeException: class com.fire.testmod.TileEntity.TileEntityTestCustomModel is missing a mapping! This is a bug!
at net.minecraft.tileentity.TileEntity.writeToNBT(TileEntity.java:96) ~[TileEntity.class:?]
at net.minecraft.world.chunk.storage.AnvilChunkLoader.writeChunkToNBT(AnvilChunkLoader.java:395) [AnvilChunkLoader.class:?]
at net.minecraft.world.chunk.storage.AnvilChunkLoader.saveChunk(AnvilChunkLoader.java:204) [AnvilChunkLoader.class:?]
at net.minecraft.world.gen.ChunkProviderServer.safeSaveChunk(ChunkProviderServer.java:287) [ChunkProviderServer.class:?]
at net.minecraft.world.gen.ChunkProviderServer.saveChunks(ChunkProviderServer.java:340) [ChunkProviderServer.class:?]
at net.minecraft.world.WorldServer.saveAllChunks(WorldServer.java:863) [WorldServer.class:?]
at net.minecraft.server.MinecraftServer.saveAllWorlds(MinecraftServer.java:370) [MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer.stopServer(MinecraftServer.java:405) [MinecraftServer.class:?]
at net.minecraft.server.integrated.IntegratedServer.stopServer(IntegratedServer.java:266) [integratedServer.class:?]
at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:538) [MinecraftServer.class:?]
at net.minecraft.server.MinecraftServer$2.run(MinecraftServer.java:752) [MinecraftServer$2.class:?]

 

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

These are all of my other things:

 

MainRegistry.java

package com.fire.testmod;

import com.fire.testmod.Blocks.TestCustomModel;
import com.fire.testmod.Blocks.TestMultisidedBlock;
import com.fire.testmod.Blocks.TestOre;
import com.fire.testmod.Items.TestIngot;
import com.fire.testmod.Items.TestItem;
import com.fire.testmod.Proxy.CommonProxy;
import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import cpw.mods.fml.common.Mod;
import cpw.mods.fml.common.Mod.EventHandler;
import cpw.mods.fml.common.Mod.Instance;
import cpw.mods.fml.common.SidedProxy;
import cpw.mods.fml.common.event.FMLInitializationEvent;
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.registry.GameRegistry;
import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;

@Mod(modid = Strings.MODID, name = Strings.NAME, version = Strings.VERSION)
public class MainRegistry {

// Proxy
@SidedProxy(clientSide="com.fire.testmod.Proxy.ClientProxy", serverSide="com.fire.testmod.Proxy.CommonProxy")
public static CommonProxy proxy;

// Instance
@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

//////////////////// -- Names -- ////////////////////
// Items
public static Item TestItem;
public static Item TestIngot;

// Tools

// Armour

// Blocks
public static Block TestOre;
public static Block TestMultisidedBlock;
public static Block TestCustomModel;

// Other

@EventHandler
public void PreLoad(FMLPreInitializationEvent event){
	//////////////////// -- Creation -- ////////////////////
	// Items
	TestItem = new TestItem().setUnlocalizedName("TestItem").setTextureName(Strings.MODID + ":TestItem").setCreativeTab(CreativeTabs.tabMaterials);
	TestIngot = new TestIngot().setUnlocalizedName("TestIngot").setTextureName(Strings.MODID + ":TestIngot").setCreativeTab(CreativeTabs.tabMaterials);

	// Tools

	// Armour

	// Blocks
	TestOre = new TestOre(Material.rock).setBlockName("TestOre").setBlockTextureName(Strings.MODID + ":TestOre").setCreativeTab(CreativeTabs.tabBlock);
	TestMultisidedBlock = new TestMultisidedBlock(Material.gourd).setBlockName("TestMultisidedBlock").setBlockTextureName(Strings.MODID + ":TestMultisidedBlock").setCreativeTab(CreativeTabs.tabBlock);
	TestCustomModel = new TestCustomModel(Material.rock).setBlockName("TestCustomModel").setBlockTextureName(Strings.MODID + ":textures/models/TestCustomModel.png").setCreativeTab(CreativeTabs.tabBlock);

	// Other

	//////////////////// -- Registering -- ////////////////////
	// Items
	GameRegistry.registerItem(TestItem, TestItem.getUnlocalizedName());
	GameRegistry.registerItem(TestIngot, TestIngot.getUnlocalizedName());

	// Tools

	// Armour

	// Blocks
	GameRegistry.registerBlock(TestOre, TestOre.getUnlocalizedName());
	GameRegistry.registerBlock(TestMultisidedBlock, TestMultisidedBlock.getUnlocalizedName());
	GameRegistry.registerBlock(TestCustomModel, TestCustomModel.getUnlocalizedName());
	//GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "Test Custom Model");

	// Other

}

@EventHandler
public void Load(FMLInitializationEvent event){
	//////////////////// -- Crafting -- ////////////////////
	// Items
	GameRegistry.addRecipe(new ItemStack(TestItem, 4), new Object[]{"T", "T", 'T', TestIngot});

	// Tools

	// Armour

	// Blocks

	// Other

	//////////////////// -- Smelting -- ////////////////////
	// Items
	GameRegistry.addSmelting(TestOre, new ItemStack(TestIngot), 0.7F);

	// Tools

	// Armour

	// Blocks

	// Other
}

@EventHandler
public void PostLoad(FMLPostInitializationEvent event){

}
}

 

TileEntityTestCustomModel.java

package com.fire.testmod.TileEntity;

import net.minecraft.tileentity.TileEntity;

public class TileEntityTestCustomModel extends TileEntity {

}

 

RenderTestCustomModel.java

package com.fire.testmod.Renderers;

import org.lwjgl.opengl.GL11;

import com.fire.testmod.Strings;
import com.fire.testmod.Models.ModelTestCustomModel;

import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
import net.minecraft.entity.Entity;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ResourceLocation;

public class RenderTestCustomModel extends TileEntitySpecialRenderer {

ResourceLocation texture = new ResourceLocation(Strings.MODID + ":textures/models/TestCustomModel.png");

private ModelTestCustomModel model;

public RenderTestCustomModel(){
	this.model = new ModelTestCustomModel();
}

@Override
public void renderTileEntityAt(TileEntity entity, double x, double y, double z, float f) {
	GL11.glPushMatrix();
		GL11.glTranslated(x + 0.5, y + 1.5, z + 0.5);
		GL11.glRotated(180, 0, 0, 1);

		this.bindTexture(texture);

		GL11.glPushMatrix();
			this.model.render((Entity)null, 0, -0.1F, 0, 0, 0, 0.0625F);
		GL11.glPopMatrix();
	GL11.glPopMatrix();
}

}

 

ModelTestCustomModel.java

package com.fire.testmod.Models;

import net.minecraft.client.model.ModelBase;
import net.minecraft.client.model.ModelRenderer;
import net.minecraft.entity.Entity;

public class ModelTestCustomModel extends ModelBase
{
  //fields
    ModelRenderer Shape2;
  
  public ModelTestCustomModel()
  {
    textureWidth = 32;
    textureHeight = 32;
    
      Shape2 = new ModelRenderer(this, 0, 0);
      Shape2.addBox(0F, 0F, 0F, 1, 16, 16);
      Shape2.setRotationPoint(0F, 8F, -8F);
      Shape2.setTextureSize(32, 32);
      Shape2.mirror = true;
      setRotation(Shape2, 0F, 0F, 0F);
  }
  
  public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
  {
    super.render(entity, f, f1, f2, f3, f4, f5);
    setRotationAngles(entity, f, f1, f2, f3, f4, f5);
    Shape2.render(f5);
  }
  
  private void setRotation(ModelRenderer model, float x, float y, float z)
  {
    model.rotateAngleX = x;
    model.rotateAngleY = y;
    model.rotateAngleZ = z;
  }
  
  public void setRotationAngles(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
  {
    super.setRotationAngles(f, f1, f2, f3, f4, f5, entity);
  }

}

 

TestCustomModel.java

package com.fire.testmod.Blocks;

import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import net.minecraft.block.BlockContainer;
import net.minecraft.block.material.Material;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.world.World;

public class TestCustomModel extends BlockContainer {

public TestCustomModel(Material material) {
	super(material);
	this.setHardness(5.0F);
	this.setResistance(0.5F);
}

public int getRenderType(){
	return -1;
}

public boolean isOpaqueCube(){
	return false;
}

public boolean renderAsNormalBlock(){
	return false;
}

@Override
public TileEntity createNewTileEntity(World p_149915_1_, int p_149915_2_) {
	return new TileEntityTestCustomModel();
}

}

 

Client Proxy

package com.fire.testmod.Proxy;

import com.fire.testmod.Renderers.RenderTestCustomModel;
import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import cpw.mods.fml.client.registry.ClientRegistry;
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;

public class ClientProxy extends CommonProxy {
public void registerRenderInfo(){
	TileEntitySpecialRenderer render0 = new RenderTestCustomModel();
	ClientRegistry.bindTileEntitySpecialRenderer(TileEntityTestCustomModel.class, render0);
}
}

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

These are all of my other things:

 

MainRegistry.java

package com.fire.testmod;

import com.fire.testmod.Blocks.TestCustomModel;
import com.fire.testmod.Blocks.TestMultisidedBlock;
import com.fire.testmod.Blocks.TestOre;
import com.fire.testmod.Items.TestIngot;
import com.fire.testmod.Items.TestItem;
import com.fire.testmod.Proxy.CommonProxy;
import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import cpw.mods.fml.common.Mod;
import cpw.mods.fml.common.Mod.EventHandler;
import cpw.mods.fml.common.Mod.Instance;
import cpw.mods.fml.common.SidedProxy;
import cpw.mods.fml.common.event.FMLInitializationEvent;
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.registry.GameRegistry;
import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;

@Mod(modid = Strings.MODID, name = Strings.NAME, version = Strings.VERSION)
public class MainRegistry {

// Proxy
@SidedProxy(clientSide="com.fire.testmod.Proxy.ClientProxy", serverSide="com.fire.testmod.Proxy.CommonProxy")
public static CommonProxy proxy;

// Instance
@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

//////////////////// -- Names -- ////////////////////
// Items
public static Item TestItem;
public static Item TestIngot;

// Tools

// Armour

// Blocks
public static Block TestOre;
public static Block TestMultisidedBlock;
public static Block TestCustomModel;

// Other

@EventHandler
public void PreLoad(FMLPreInitializationEvent event){
	//////////////////// -- Creation -- ////////////////////
	// Items
	TestItem = new TestItem().setUnlocalizedName("TestItem").setTextureName(Strings.MODID + ":TestItem").setCreativeTab(CreativeTabs.tabMaterials);
	TestIngot = new TestIngot().setUnlocalizedName("TestIngot").setTextureName(Strings.MODID + ":TestIngot").setCreativeTab(CreativeTabs.tabMaterials);

	// Tools

	// Armour

	// Blocks
	TestOre = new TestOre(Material.rock).setBlockName("TestOre").setBlockTextureName(Strings.MODID + ":TestOre").setCreativeTab(CreativeTabs.tabBlock);
	TestMultisidedBlock = new TestMultisidedBlock(Material.gourd).setBlockName("TestMultisidedBlock").setBlockTextureName(Strings.MODID + ":TestMultisidedBlock").setCreativeTab(CreativeTabs.tabBlock);
	TestCustomModel = new TestCustomModel(Material.rock).setBlockName("TestCustomModel").setBlockTextureName(Strings.MODID + ":textures/models/TestCustomModel.png").setCreativeTab(CreativeTabs.tabBlock);

	// Other

	//////////////////// -- Registering -- ////////////////////
	// Items
	GameRegistry.registerItem(TestItem, TestItem.getUnlocalizedName());
	GameRegistry.registerItem(TestIngot, TestIngot.getUnlocalizedName());

	// Tools

	// Armour

	// Blocks
	GameRegistry.registerBlock(TestOre, TestOre.getUnlocalizedName());
	GameRegistry.registerBlock(TestMultisidedBlock, TestMultisidedBlock.getUnlocalizedName());
	GameRegistry.registerBlock(TestCustomModel, TestCustomModel.getUnlocalizedName());
	//GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "Test Custom Model");

	// Other

}

@EventHandler
public void Load(FMLInitializationEvent event){
	//////////////////// -- Crafting -- ////////////////////
	// Items
	GameRegistry.addRecipe(new ItemStack(TestItem, 4), new Object[]{"T", "T", 'T', TestIngot});

	// Tools

	// Armour

	// Blocks

	// Other

	//////////////////// -- Smelting -- ////////////////////
	// Items
	GameRegistry.addSmelting(TestOre, new ItemStack(TestIngot), 0.7F);

	// Tools

	// Armour

	// Blocks

	// Other
}

@EventHandler
public void PostLoad(FMLPostInitializationEvent event){

}
}

 

TileEntityTestCustomModel.java

package com.fire.testmod.TileEntity;

import net.minecraft.tileentity.TileEntity;

public class TileEntityTestCustomModel extends TileEntity {

}

 

RenderTestCustomModel.java

package com.fire.testmod.Renderers;

import org.lwjgl.opengl.GL11;

import com.fire.testmod.Strings;
import com.fire.testmod.Models.ModelTestCustomModel;

import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
import net.minecraft.entity.Entity;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ResourceLocation;

public class RenderTestCustomModel extends TileEntitySpecialRenderer {

ResourceLocation texture = new ResourceLocation(Strings.MODID + ":textures/models/TestCustomModel.png");

private ModelTestCustomModel model;

public RenderTestCustomModel(){
	this.model = new ModelTestCustomModel();
}

@Override
public void renderTileEntityAt(TileEntity entity, double x, double y, double z, float f) {
	GL11.glPushMatrix();
		GL11.glTranslated(x + 0.5, y + 1.5, z + 0.5);
		GL11.glRotated(180, 0, 0, 1);

		this.bindTexture(texture);

		GL11.glPushMatrix();
			this.model.render((Entity)null, 0, -0.1F, 0, 0, 0, 0.0625F);
		GL11.glPopMatrix();
	GL11.glPopMatrix();
}

}

 

ModelTestCustomModel.java

package com.fire.testmod.Models;

import net.minecraft.client.model.ModelBase;
import net.minecraft.client.model.ModelRenderer;
import net.minecraft.entity.Entity;

public class ModelTestCustomModel extends ModelBase
{
  //fields
    ModelRenderer Shape2;
  
  public ModelTestCustomModel()
  {
    textureWidth = 32;
    textureHeight = 32;
    
      Shape2 = new ModelRenderer(this, 0, 0);
      Shape2.addBox(0F, 0F, 0F, 1, 16, 16);
      Shape2.setRotationPoint(0F, 8F, -8F);
      Shape2.setTextureSize(32, 32);
      Shape2.mirror = true;
      setRotation(Shape2, 0F, 0F, 0F);
  }
  
  public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
  {
    super.render(entity, f, f1, f2, f3, f4, f5);
    setRotationAngles(entity, f, f1, f2, f3, f4, f5);
    Shape2.render(f5);
  }
  
  private void setRotation(ModelRenderer model, float x, float y, float z)
  {
    model.rotateAngleX = x;
    model.rotateAngleY = y;
    model.rotateAngleZ = z;
  }
  
  public void setRotationAngles(Entity entity, float f, float f1, float f2, float f3, float f4, float f5)
  {
    super.setRotationAngles(f, f1, f2, f3, f4, f5, entity);
  }

}

 

TestCustomModel.java

package com.fire.testmod.Blocks;

import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import net.minecraft.block.BlockContainer;
import net.minecraft.block.material.Material;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.world.World;

public class TestCustomModel extends BlockContainer {

public TestCustomModel(Material material) {
	super(material);
	this.setHardness(5.0F);
	this.setResistance(0.5F);
}

public int getRenderType(){
	return -1;
}

public boolean isOpaqueCube(){
	return false;
}

public boolean renderAsNormalBlock(){
	return false;
}

@Override
public TileEntity createNewTileEntity(World p_149915_1_, int p_149915_2_) {
	return new TileEntityTestCustomModel();
}

}

 

Client Proxy

package com.fire.testmod.Proxy;

import com.fire.testmod.Renderers.RenderTestCustomModel;
import com.fire.testmod.TileEntity.TileEntityTestCustomModel;

import cpw.mods.fml.client.registry.ClientRegistry;
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;

public class ClientProxy extends CommonProxy {
public void registerRenderInfo(){
	TileEntitySpecialRenderer render0 = new RenderTestCustomModel();
	ClientRegistry.bindTileEntitySpecialRenderer(TileEntityTestCustomModel.class, render0);
}
}

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

Show your main mod class and your proxy classes.

 

That said, this:

	public static void init(FMLInitializationEvent event){
	GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "TestCustomModel");
}

Belongs nowhere in the TileEntityTestCustom class.  It belongs in your main class along side all your other registration code.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Show your main mod class and your proxy classes.

 

That said, this:

	public static void init(FMLInitializationEvent event){
	GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "TestCustomModel");
}

Belongs nowhere in the TileEntityTestCustom class.  It belongs in your main class along side all your other registration code.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Show your main mod class and your proxy classes.

 

That said, this:

	public static void init(FMLInitializationEvent event){
	GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "TestCustomModel");
}

Belongs nowhere in the TileEntityTestCustom class.  It belongs in your main class along side all your other registration code.

 

I just edited it with the client proxy now as well for you

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

Show your main mod class and your proxy classes.

 

That said, this:

	public static void init(FMLInitializationEvent event){
	GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "TestCustomModel");
}

Belongs nowhere in the TileEntityTestCustom class.  It belongs in your main class along side all your other registration code.

 

I just edited it with the client proxy now as well for you

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

public static MainRegistry instance = new MainRegistry();

 

No, bad modder.  Do not instanciate your own main class.  That's what the @instance annotation is for, so Forge instantiates your class.

 

//GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "Test Custom Model");

 

Why is this line commented?

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

public static MainRegistry instance = new MainRegistry();

 

No, bad modder.  Do not instanciate your own main class.  That's what the @instance annotation is for, so Forge instantiates your class.

 

//GameRegistry.registerTileEntity(TileEntityTestCustomModel.class, "Test Custom Model");

 

Why is this line commented?

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

It's commented because I honestly have no idea what to do now. I was just testing it. Also, I do have @Instance. What should I do instead of what I am doing?

 

@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

It's commented because I honestly have no idea what to do now. I was just testing it. Also, I do have @Instance. What should I do instead of what I am doing?

 

@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

There are so many different tutorials about making Custom Models that I have no idea what to believe. Every single tutorial brings me to this same problem though: The block is invisible. I got it to work ONCE, and now It's not working again.

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

There are so many different tutorials about making Custom Models that I have no idea what to believe. Every single tutorial brings me to this same problem though: The block is invisible. I got it to work ONCE, and now It's not working again.

I am on my journey of making a remake of matmos, as explained here.

Link to comment
Share on other sites

Also, I do have @Instance. What should I do instead of what I am doing?

 

@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

 

Your code: WRONG

 

Correct code:

 

@Instance(Strings.MODID)
public static MainRegistry instance; //FORGE DOES IT FOR YOU

 

As for the TE registration, what you have is (essentially) correct.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Also, I do have @Instance. What should I do instead of what I am doing?

 

@Instance(Strings.MODID)
public static MainRegistry instance = new MainRegistry();

 

Your code: WRONG

 

Correct code:

 

@Instance(Strings.MODID)
public static MainRegistry instance; //FORGE DOES IT FOR YOU

 

As for the TE registration, what you have is (essentially) correct.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

You never call

registerRenderInfo

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

You never call

registerRenderInfo

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Guest
This topic is now closed to further replies.


  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • [03Jun2024 15:23:40.010] [main/INFO] [cpw.mods.modlauncher.Launcher/MODLAUNCHER]: ModLauncher running: args [--username, LondonDumbden, --version, 1.20.1-forge-47.2.32, --gameDir, C:\Users\London Bunden\AppData\Roaming\.minecraft, --assetsDir, C:\Users\London Bunden\AppData\Roaming\.minecraft\assets, --assetIndex, 5, --uuid, da3510f9b4b4427bb78304c88f4c534a, --accessToken, ????????, --clientId, ZTIxMjA2NTctYmIxZS00ZWQzLWFkZDEtMmMxMGQzMjQyNjBj, --xuid, 2535420262661734, --userType, msa, --versionType, release, --quickPlayPath, C:\Users\London Bunden\AppData\Roaming\.minecraft\quickPlay\java\1717446216838.json, --launchTarget, forgeclient, --fml.forgeVersion, 47.2.32, --fml.mcVersion, 1.20.1, --fml.forgeGroup, net.minecraftforge, --fml.mcpVersion, 20230612.114412] [03Jun2024 15:23:40.017] [main/INFO] [cpw.mods.modlauncher.Launcher/MODLAUNCHER]: ModLauncher 10.0.9+10.0.9+main.dcd20f30 starting: java version 17.0.8 by Microsoft; OS Windows 11 arch amd64 version 10.0 [03Jun2024 15:23:42.057] [main/INFO] [net.minecraftforge.fml.loading.ImmediateWindowHandler/]: Loading ImmediateWindowProvider fmlearlywindow [03Jun2024 15:23:42.159] [main/INFO] [EARLYDISPLAY/]: Trying GL version 4.6 [03Jun2024 15:23:42.401] [main/INFO] [EARLYDISPLAY/]: Requested GL version 4.6 got version 4.6 [03Jun2024 15:23:42.494] [main/INFO] [mixin-transmog/]: Mixin Transmogrifier is definitely up to no good... [03Jun2024 15:23:42.524] [main/INFO] [mixin-transmog/]: crimes against java were committed [03Jun2024 15:23:42.630] [pool-2-thread-1/INFO] [EARLYDISPLAY/]: GL info: NVIDIA GeForce RTX 3070/PCIe/SSE2 GL version 4.6.0 NVIDIA 555.85, NVIDIA Corporation [03Jun2024 15:23:43.075] [main/INFO] [gg.essential.loader.stage1.EssentialLoaderBase/]: Starting Essential Loader (stage2) version 1.6.2 (285f951adc7537f49ae3ef9fc0d2fd3e) [stable] [03Jun2024 15:23:43.104] [main/INFO] [mixin-transmog/]: Original mixin transformation service successfully crobbed by mixin-transmogrifier! [03Jun2024 15:23:43.162] [main/INFO] [mixin/]: SpongePowered MIXIN Subsystem Version=0.8.5 Source=union:/C:/Users/London%20Bunden/AppData/Roaming/.minecraft/mods/Connector-1.0.0-beta.43+1.20.1.jar%23266%23270!/ Service=ModLauncher Env=CLIENT [03Jun2024 15:23:44.312] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file C:\Users\London Bunden\AppData\Roaming\.minecraft\libraries\net\minecraftforge\fmlcore\1.20.1-47.2.32\fmlcore-1.20.1-47.2.32.jar is missing mods.toml file [03Jun2024 15:23:44.317] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file C:\Users\London Bunden\AppData\Roaming\.minecraft\libraries\net\minecraftforge\javafmllanguage\1.20.1-47.2.32\javafmllanguage-1.20.1-47.2.32.jar is missing mods.toml file [03Jun2024 15:23:44.323] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file C:\Users\London Bunden\AppData\Roaming\.minecraft\libraries\net\minecraftforge\lowcodelanguage\1.20.1-47.2.32\lowcodelanguage-1.20.1-47.2.32.jar is missing mods.toml file [03Jun2024 15:23:44.329] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file C:\Users\London Bunden\AppData\Roaming\.minecraft\libraries\net\minecraftforge\mclanguage\1.20.1-47.2.32\mclanguage-1.20.1-47.2.32.jar is missing mods.toml file [03Jun2024 15:23:44.862] [main/WARN] [net.minecraftforge.jarjar.selection.JarSelector/]: Attempted to select two dependency jars from JarJar which have the same identification: Mod File:  and Mod File: . Using Mod File:  [03Jun2024 15:23:44.864] [main/WARN] [net.minecraftforge.jarjar.selection.JarSelector/]: Attempted to select a dependency jar for JarJar which was passed in as source: curios. Using Mod File: C:\Users\London Bunden\AppData\Roaming\.minecraft\mods\curios-forge-5.9.1+1.20.1.jar [03Jun2024 15:23:44.864] [main/INFO] [net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator/]: Found 75 dependencies adding them to mods collection [03Jun2024 15:23:49.089] [main/INFO] [gg.essential.loader.stage2.util.KFFMerger/]: Found Kotlin-containing mod Jar[union:/C:/Users/London%20Bunden/AppData/Roaming/.minecraft/essential/libraries/forge_1.20.1/kotlin-for-forge-4.3.0-slim.jar%23280!/], checking whether we need to upgrade it.. [03Jun2024 15:23:49.091] [main/INFO] [gg.essential.loader.stage2.util.KFFMerger/]: Found outdated Kotlin core libs 0.0.0 (we ship 1.9.23) [03Jun2024 15:23:49.092] [main/INFO] [gg.essential.loader.stage2.util.KFFMerger/]: Found outdated Kotlin Coroutines libs 0.0.0 (we ship 1.8.0) [03Jun2024 15:23:49.092] [main/INFO] [gg.essential.loader.stage2.util.KFFMerger/]: Found outdated Kotlin Serialization libs 0.0.0 (we ship 1.6.3) [03Jun2024 15:23:49.095] [main/INFO] [gg.essential.loader.stage2.util.KFFMerger/]: Generating jar with updated Kotlin at C:\Users\LONDON~1\AppData\Local\Temp\kff-updated-kotlin-14765634657383373807-4.3.0-slim.jar [03Jun2024 15:23:49.974] [main/ERROR] [net.minecraftforge.fml.loading.LanguageLoadingProvider/LOADING]: Missing language kotlinforforge version [3,) wanted by Cobblemon-forge-1.5.2+1.20.1.jar [03Jun2024 15:23:49.989] [main/ERROR] [net.minecraftforge.fml.loading.ModSorter/LOADING]: Missing or unsupported mandatory dependencies:     Mod ID: 'curios', Requested by: 'radiantgear', Expected range: '[7,)', Actual version: '5.9.1+1.20.1'     Mod ID: 'minecraft', Requested by: 'radiantgear', Expected range: '[1.20.5,1.21)', Actual version: '1.20.1'     Mod ID: 'forge', Requested by: 'radiantgear', Expected range: '[50,)', Actual version: '47.2.32' [03Jun2024 15:23:50.434] [main/INFO] [dev.su5ed.sinytra.connector.service.hacks.ModuleLayerMigrator/]: Successfully made module authlib transformable [03Jun2024 15:23:51.112] [main/ERROR] [dev.su5ed.sinytra.connector.loader.ConnectorEarlyLoader/]: Skipping early mod setup due to previous error [03Jun2024 15:23:51.115] [main/INFO] [cpw.mods.modlauncher.LaunchServiceHandler/MODLAUNCHER]: Launching target 'forgeclient' with arguments [--version, 1.20.1-forge-47.2.32, --gameDir, C:\Users\London Bunden\AppData\Roaming\.minecraft, --assetsDir, C:\Users\London Bunden\AppData\Roaming\.minecraft\assets, --uuid, da3510f9b4b4427bb78304c88f4c534a, --username, LondonDumbden, --assetIndex, 5, --accessToken, ????????, --clientId, ZTIxMjA2NTctYmIxZS00ZWQzLWFkZDEtMmMxMGQzMjQyNjBj, --xuid, 2535420262661734, --userType, msa, --versionType, release, --quickPlayPath, C:\Users\London Bunden\AppData\Roaming\.minecraft\quickPlay\java\1717446216838.json]  
    • When I try to install the forge installer it comes with several files instead of just one in executable java format
    • 0 I have recently started with Java and the implementation of Minecraft mods. I am currently working on a mod for 1.20.4-49.0.31 I'm trying to get the content of each slot in the console to be displayed when the inventory is opened, which works. In addition, I wanted to do the same with chests (in this case containers). However, I get in the output that there is Air at every slot of the chest, even if the chest is filled. Does anyone have experience with similar problems and could help me? package net.kaan.sortingmod; import net.minecraft.client.Minecraft; import net.minecraft.client.gui.screens.Screen; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; import net.minecraft.client.gui.screens.inventory.InventoryScreen; import net.minecraft.client.gui.screens.inventory.ContainerScreen; import net.minecraft.client.gui.screens.inventory.FurnaceScreen; import net.minecraft.world.entity.player.Player; import net.minecraft.world.inventory.AbstractContainerMenu; import net.minecraft.world.inventory.InventoryMenu; import net.minecraft.world.item.ItemStack; import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.client.event.ScreenEvent; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; @Mod(SortingMod.MODID) public class SortingMod { public static final String MODID = "sortingmod"; public SortingMod() { // Register the client setup method FMLJavaModLoadingContext.get().getModEventBus().addListener(this::doClientStuff); // Register this class for Forge events MinecraftForge.EVENT_BUS.register(this); } private void doClientStuff(final FMLClientSetupEvent event) { // Any client-side setup can be done here } @SubscribeEvent public void onScreenOpen(ScreenEvent.Opening event) { Screen screen = event.getScreen(); if (screen instanceof InventoryScreen) { System.out.println("Player opened their inventory."); assert Minecraft.getInstance().player != null; printInventoryItems(Minecraft.getInstance().player); } else if (screen instanceof ContainerScreen) { System.out.println("Player opened a chest."); printContainerItems((ContainerScreen) screen); } } private void printInventoryItems(Player player) { AbstractContainerMenu menu = player.inventoryMenu; for (int i = 0; i < menu.slots.size(); i++) { ItemStack stack = menu.getSlot(i).getItem(); if (!stack.isEmpty()) { System.out.println("Slot " + i + ": " + stack.getCount() + "x " + stack.getHoverName().getString()); } } } private void printContainerItems(ContainerScreen screen) { AbstractContainerMenu menu = screen.getMenu(); System.out.println(menu.slots.size()); for (int i = 0; i < menu.slots.size(); i++) { ItemStack stack = menu.getSlot(i).getItem(); System.out.println("Slot " + i + ": " + stack.getCount() + "x " + stack.getHoverName().getString()); } } }  
    • I am wanting to add an axe to my mod though I do not want it to have a recipe, the reason for this being that I want you to only be able to find it in a structure. I have looked on both here and elsewhere on the internet and have found nothing... How would this be done?    (Video for reference.)    
  • Topics

×
×
  • Create New...

Important Information

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