Jump to content

[1.12.2] IBakedModel help


BeardlessBrady

Recommended Posts

I am trying to use an IBakedModel to create a dynamic model for an item. I've been looking at GreyGhosts examples but I start getting confused here: https://github.com/TheGreyGhost/MinecraftByExample/blob/master/src/main/java/minecraftbyexample/mbe15_item_dynamic_item_model/ChessboardFinalisedModel.java#L135

From then on there are tons of numbers which to me don't really have any correlation as to where they came from so I can't quite understand how to do it in my own implementation.

 

Any help would be appreciated, thanks!

Link to comment
Share on other sites

3 hours ago, BeardlessBrady said:

I am trying to use an IBakedModel to create a dynamic model for an item. I've been looking at GreyGhosts examples but I start getting confused here: https://github.com/TheGreyGhost/MinecraftByExample/blob/master/src/main/java/minecraftbyexample/mbe15_item_dynamic_item_model/ChessboardFinalisedModel.java#L135

From then on there are tons of numbers which to me don't really have any correlation as to where they came from so I can't quite understand how to do it in my own implementation.

 

Any help would be appreciated, thanks!

You’ve said that your problem is that your confused, do you want links to some documentation? Or do u want to post your code and your logs and go from there?

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

4 hours ago, BeardlessBrady said:

Any help would be appreciated, thanks!

It would be helpful if you told us which numbers specifically.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

Link to comment
Share on other sites

Alright, my confusion is about GreyGhost's example here:

https://github.com/TheGreyGhost/MinecraftByExample/blob/master/src/main/java/minecraftbyexample/mbe15_item_dynamic_item_model/ChessboardFinalisedModel.java#L135

 

and here:

https://github.com/TheGreyGhost/MinecraftByExample/blob/master/src/main/java/minecraftbyexample/mbe15_item_dynamic_item_model/ChessboardFinalisedModel.java#L212

 

I'm not understanding how all the math on those lines and below are calculated and it is very overwhelming. I'm trying to figure out how to used IBakedModels.

 

Link to comment
Share on other sites

14 minutes ago, BeardlessBrady said:

1/16 is the thickness of the Item ie one pixel.

The next number indicates the center of the item(0-1) so .5 is the literal center.

The max is the farthest position(farthest from 0) and the min is the closest position(closest to 0). These represent how far in the start and the end are in the z direction.

22 minutes ago, BeardlessBrady said:

These are a little bit beyond me, but basically it is just creating the faces for the baked model. It might be easier to experiment with those values to figure out what they do exactly. But it looks like dimensions of some kind.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

Link to comment
Share on other sites

Thats the problem, I wouldnt even know where to start with experimenting with that. What I'm trying to accomplish it creating an item that has 3 layers. Each layer has different variants. I was going to use JSON overrides and predicates but for some reason with that you can only override the entire model not just a layer of one so that requires me to create every combination of each layer. IBakedModel's seem more flexible but this example of how it works just flies over my head. ]

Link to comment
Share on other sites

Its easier to make just all different overlays and then overlay them onto the item using IBakedModel.

 

So my item has 6 different layers overlayed onto it. For each layer I have made the different json models and textures, I have not done any combinations, those are done in code.

 

Ill just share my code with you, I think its pretty self explaining, but some comments are there making it easy to understand:

 

@Override
	public void registerGun(IForgeRegistry<Item> registry, ItemGun gun)
	{
		super.registerGun(registry, gun);
		
		registeredGuns.add(gun);
		
		ModelResourceLocation main = new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/gun", "inventory");
		ModelLoader.setCustomModelResourceLocation(gun, 0, main);
		
		ArrayList<ModelResourceLocation> list = new ArrayList<ModelResourceLocation>();
		list.add(main);
		
		int i;
		int j;
		Attachment attachment;
		
		for(i = 0; i < EnumAttachmentType.values().length; ++i) //All layers
		{
			for(j = 0; j < Attachment.getAmmountForSlot(i); ++j) //All attachments per layer
			{
				if(gun.canSetAttachment(i, j)) //Check if attachment is compatible
				{
					attachment = Attachment.getAttachment(i, j);
					
					if(attachment != null && attachment.shouldLoadModel()) //null-attachment exists, as well as some which are not visible
					{
						list.add(new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/" + attachment.getModelRL(), "inventory")); //Add MRL to the list
					}
				}
			}
		}
		
		ModelBakery.registerItemVariants(gun, list.toArray(new ModelResourceLocation[list.size()])); //Register all attachment MRLs found so that they will be loaded
	}
@SubscribeEvent
	public void modelBake(ModelBakeEvent event)
	{
		int i;
		int j;
		Attachment attachment;
		ModelResourceLocation mrl;
		IBakedModel main;
		
		IBakedModel[][] models; //These are the attachment models which will be passed onto the gun model for use
		
		for(ItemGun gun : ProxyClient.registeredGuns) //Cycle through all guns
		{
			models = new IBakedModel[EnumAttachmentType.values().length][];
			
			for(i = 0; i < models.length; ++i) //This represents the layers
			{
				models[i] = new IBakedModel[Attachment.getAmmountForSlot(i)];
				
				for(j = 0; j < Attachment.getAmmountForSlot(i); ++j) //Ammount of attachments for each layer
				{
					if(gun.canSetAttachment(i, j)) //Check if compatible
					{
						attachment = Attachment.getAttachment(i, j);
						
						if(attachment != null && attachment.shouldLoadModel()) //Make sure its not null-attachment and the model is needed
						{
							models[i][j] = event.getModelRegistry().getObject(new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/" + attachment.getModelRL(), "inventory")); //Add attachment model to the array
						}
					}
				}
			}
			
			mrl = new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/gun", "inventory"); //This is the MRL of the main item (gun)
			
			main = event.getModelRegistry().getObject(mrl); //Get the model of the gun
			
			event.getModelRegistry().putObject(mrl, new BakedModelGun(main, models)); //Replace model of the gun with custom IBakedModel and pass all the attachment models to it
		}
	}
public class BakedModelGun implements IBakedModel
{
	/*
	 * The only usage of this class is the item overrides list:
	 * Basically get the itemstack, pass it onto the modelFinal, then return modelFinal for rendering,
	 * so that during the rendering you have information about the itemstack
	 */
	private final IBakedModel modelMain;
	private final BakedModelGunFinalized modelFinal;
	private final OverridesList overridesList;
	
	public BakedModelGun(IBakedModel modelMain, IBakedModel[][] attachmentModels)
	{
		this.modelMain = modelMain;
		this.modelFinal = new BakedModelGunFinalized(this.modelMain, attachmentModels);
		this.overridesList = new OverridesList(this);
	}
	
	public BakedModelGunFinalized getModelFinal()
	{
		return modelFinal;
	}

	@Override
	public ItemOverrideList getOverrides()
	{
		return this.overridesList;
	}

	@Override
	public TextureAtlasSprite getParticleTexture()
	{
		return this.modelMain.getParticleTexture();
	}

	@Override
	public List<BakedQuad> getQuads(IBlockState arg0, EnumFacing arg1, long arg2)
	{
		return this.modelMain.getQuads(arg0, arg1, arg2);
	}

	@Override
	public boolean isAmbientOcclusion()
	{
		return this.modelMain.isAmbientOcclusion();
	}
	
	@Override
	public boolean isBuiltInRenderer()
	{
		return this.modelMain.isBuiltInRenderer();
	}

	@Override
	public boolean isGui3d()
	{
		return this.modelMain.isGui3d();
	}
	
	private static class OverridesList extends ItemOverrideList
	{
		private BakedModelGun modelGun;
		
		public OverridesList(BakedModelGun modelGun)
		{
			super(Collections.EMPTY_LIST);
			this.modelGun = modelGun;
		}
		
		@Override
		public IBakedModel handleItemState(IBakedModel originalModel, ItemStack itemStack, World world, EntityLivingBase entity)
		{
			return this.modelGun.getModelFinal().setCurrentItemStack(itemStack);
		}
	}
}
public class BakedModelGunFinalized implements IBakedModel
{
	private final IBakedModel modelMain;
	private final IBakedModel[][] attachmentModels;
	private ItemStack itemStack;
	
	public BakedModelGunFinalized(IBakedModel modelMain, IBakedModel[][] attachmentModels)
	{
		this.modelMain = modelMain;
		this.attachmentModels = attachmentModels;
		this.itemStack = null;
	}
	
	public BakedModelGunFinalized setCurrentItemStack(ItemStack itemStack)
	{
		this.itemStack = itemStack;
		return this;
	}

	@Override
	public ItemOverrideList getOverrides()
	{
		return this.modelMain.getOverrides();
	}

	@Override
	public TextureAtlasSprite getParticleTexture()
	{
		return this.modelMain.getParticleTexture();
	}

	@Override
	public List<BakedQuad> getQuads(IBlockState arg0, EnumFacing arg1, long arg2)
	{
		ArrayList<BakedQuad> list = new ArrayList<BakedQuad>();
		
		List<BakedQuad> list1 = this.modelMain.getQuads(arg0, arg1, arg2);
		
		ItemGun gun = (ItemGun) this.itemStack.getItem();
		
		Paint paint = gun.<Paint>getAttachmentCalled(this.itemStack, EnumAttachmentType.PAINT.getSlot());
		IBakedModel model;
		
		if(paint != null && paint.shouldRegister())
		{
			model = this.attachmentModels[EnumAttachmentType.PAINT.getSlot()][paint.getID()];
			
			if(model != null)
			{
				list1 = model.getQuads(arg0, arg1, arg2);
			}
		}
		
		if(list1 != null && !list1.isEmpty())
		{
			list.addAll(list1);
		}
		
		List<BakedQuad> list2;
		
		Attachment attachment;
		
		for(int i = 0; i < EnumAttachmentType.values().length; ++i)
		{
			attachment = gun.getAttachment(itemStack, i);
			
			if(attachment != null && attachment.shouldRender())
			{
				model = this.attachmentModels[i][attachment.getID()];
				
				if(model != null)
				{
					list2 = model.getQuads(arg0, arg1, arg2);
					
					if(list2 != null && !list2.isEmpty())
					{
						list.addAll(list2);
					}
				}
			}
		}
		
		return list;
	}

	@Override
	public boolean isAmbientOcclusion()
	{
		return this.modelMain.isAmbientOcclusion();
	}
	
	@Override
	public boolean isBuiltInRenderer()
	{
		return this.modelMain.isBuiltInRenderer();
	}

	@Override
	public boolean isGui3d()
	{
		return this.modelMain.isGui3d();
	}
	
	private static final Matrix4f NULL_MATRIX = new Matrix4f();
	
	@Override
	public Pair<? extends IBakedModel, Matrix4f> handlePerspective(TransformType transformType)
	{
		if(transformType == TransformType.FIRST_PERSON_RIGHT_HAND)
		{
			EntityPlayer entityPlayer = Minecraft.getMinecraft().player;
			
			if(entityPlayer != null && !entityPlayer.isSprinting() && !entityPlayer.isSneaking())
			{
				if(entityPlayer.getHeldItemMainhand().getItem() instanceof ItemGun && entityPlayer.getHeldItemOffhand().isEmpty() && Minecraft.getMinecraft().gameSettings.keyBindUseItem.isKeyDown())
				{
					ItemStack itemStack = entityPlayer.getHeldItemMainhand();
					ItemGun gun = (ItemGun) itemStack.getItem();
					
					Optic optic = gun.<Optic>getAttachmentCalled(itemStack, EnumAttachmentType.OPTIC.getSlot());
					
					if(optic != null && optic.canAim())
					{
						return Pair.of(this, NULL_MATRIX);
					}
				}
			}
		}
		
		return Pair.of(this, this.modelMain.handlePerspective(transformType).getRight());
	}
}

 

 

Edited by CAS_ual_TY
Link to comment
Share on other sites

12 hours ago, CAS_ual_TY said:

Its easier to make just all different overlays and then overlay them onto the item using IBakedModel.

 

So my item has 6 different layers overlayed onto it. For each layer I have made the different json models and textures, I have not done any combinations, those are done in code.

 

Ill just share my code with you, I think its pretty self explaining, but some comments are there making it easy to understand:

 


@Override
	public void registerGun(IForgeRegistry<Item> registry, ItemGun gun)
	{
		super.registerGun(registry, gun);
		
		registeredGuns.add(gun);
		
		ModelResourceLocation main = new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/gun", "inventory");
		ModelLoader.setCustomModelResourceLocation(gun, 0, main);
		
		ArrayList<ModelResourceLocation> list = new ArrayList<ModelResourceLocation>();
		list.add(main);
		
		int i;
		int j;
		Attachment attachment;
		
		for(i = 0; i < EnumAttachmentType.values().length; ++i) //All layers
		{
			for(j = 0; j < Attachment.getAmmountForSlot(i); ++j) //All attachments per layer
			{
				if(gun.canSetAttachment(i, j)) //Check if attachment is compatible
				{
					attachment = Attachment.getAttachment(i, j);
					
					if(attachment != null && attachment.shouldLoadModel()) //null-attachment exists, as well as some which are not visible
					{
						list.add(new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/" + attachment.getModelRL(), "inventory")); //Add MRL to the list
					}
				}
			}
		}
		
		ModelBakery.registerItemVariants(gun, list.toArray(new ModelResourceLocation[list.size()])); //Register all attachment MRLs found so that they will be loaded
	}

@SubscribeEvent
	public void modelBake(ModelBakeEvent event)
	{
		int i;
		int j;
		Attachment attachment;
		ModelResourceLocation mrl;
		IBakedModel main;
		
		IBakedModel[][] models; //These are the attachment models which will be passed onto the gun model for use
		
		for(ItemGun gun : ProxyClient.registeredGuns) //Cycle through all guns
		{
			models = new IBakedModel[EnumAttachmentType.values().length][];
			
			for(i = 0; i < models.length; ++i) //This represents the layers
			{
				models[i] = new IBakedModel[Attachment.getAmmountForSlot(i)];
				
				for(j = 0; j < Attachment.getAmmountForSlot(i); ++j) //Ammount of attachments for each layer
				{
					if(gun.canSetAttachment(i, j)) //Check if compatible
					{
						attachment = Attachment.getAttachment(i, j);
						
						if(attachment != null && attachment.shouldLoadModel()) //Make sure its not null-attachment and the model is needed
						{
							models[i][j] = event.getModelRegistry().getObject(new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/" + attachment.getModelRL(), "inventory")); //Add attachment model to the array
						}
					}
				}
			}
			
			mrl = new ModelResourceLocation(GunCus.MOD_ID + ":" + gun.getModelRL() + "/gun", "inventory"); //This is the MRL of the main item (gun)
			
			main = event.getModelRegistry().getObject(mrl); //Get the model of the gun
			
			event.getModelRegistry().putObject(mrl, new BakedModelGun(main, models)); //Replace model of the gun with custom IBakedModel and pass all the attachment models to it
		}
	}

public class BakedModelGun implements IBakedModel
{
	/*
	 * The only usage of this class is the item overrides list:
	 * Basically get the itemstack, pass it onto the modelFinal, then return modelFinal for rendering,
	 * so that during the rendering you have information about the itemstack
	 */
	private final IBakedModel modelMain;
	private final BakedModelGunFinalized modelFinal;
	private final OverridesList overridesList;
	
	public BakedModelGun(IBakedModel modelMain, IBakedModel[][] attachmentModels)
	{
		this.modelMain = modelMain;
		this.modelFinal = new BakedModelGunFinalized(this.modelMain, attachmentModels);
		this.overridesList = new OverridesList(this);
	}
	
	public BakedModelGunFinalized getModelFinal()
	{
		return modelFinal;
	}

	@Override
	public ItemOverrideList getOverrides()
	{
		return this.overridesList;
	}

	@Override
	public TextureAtlasSprite getParticleTexture()
	{
		return this.modelMain.getParticleTexture();
	}

	@Override
	public List<BakedQuad> getQuads(IBlockState arg0, EnumFacing arg1, long arg2)
	{
		return this.modelMain.getQuads(arg0, arg1, arg2);
	}

	@Override
	public boolean isAmbientOcclusion()
	{
		return this.modelMain.isAmbientOcclusion();
	}
	
	@Override
	public boolean isBuiltInRenderer()
	{
		return this.modelMain.isBuiltInRenderer();
	}

	@Override
	public boolean isGui3d()
	{
		return this.modelMain.isGui3d();
	}
	
	private static class OverridesList extends ItemOverrideList
	{
		private BakedModelGun modelGun;
		
		public OverridesList(BakedModelGun modelGun)
		{
			super(Collections.EMPTY_LIST);
			this.modelGun = modelGun;
		}
		
		@Override
		public IBakedModel handleItemState(IBakedModel originalModel, ItemStack itemStack, World world, EntityLivingBase entity)
		{
			return this.modelGun.getModelFinal().setCurrentItemStack(itemStack);
		}
	}
}

public class BakedModelGunFinalized implements IBakedModel
{
	private final IBakedModel modelMain;
	private final IBakedModel[][] attachmentModels;
	private ItemStack itemStack;
	
	public BakedModelGunFinalized(IBakedModel modelMain, IBakedModel[][] attachmentModels)
	{
		this.modelMain = modelMain;
		this.attachmentModels = attachmentModels;
		this.itemStack = null;
	}
	
	public BakedModelGunFinalized setCurrentItemStack(ItemStack itemStack)
	{
		this.itemStack = itemStack;
		return this;
	}

	@Override
	public ItemOverrideList getOverrides()
	{
		return this.modelMain.getOverrides();
	}

	@Override
	public TextureAtlasSprite getParticleTexture()
	{
		return this.modelMain.getParticleTexture();
	}

	@Override
	public List<BakedQuad> getQuads(IBlockState arg0, EnumFacing arg1, long arg2)
	{
		ArrayList<BakedQuad> list = new ArrayList<BakedQuad>();
		
		List<BakedQuad> list1 = this.modelMain.getQuads(arg0, arg1, arg2);
		
		ItemGun gun = (ItemGun) this.itemStack.getItem();
		
		Paint paint = gun.<Paint>getAttachmentCalled(this.itemStack, EnumAttachmentType.PAINT.getSlot());
		IBakedModel model;
		
		if(paint != null && paint.shouldRegister())
		{
			model = this.attachmentModels[EnumAttachmentType.PAINT.getSlot()][paint.getID()];
			
			if(model != null)
			{
				list1 = model.getQuads(arg0, arg1, arg2);
			}
		}
		
		if(list1 != null && !list1.isEmpty())
		{
			list.addAll(list1);
		}
		
		List<BakedQuad> list2;
		
		Attachment attachment;
		
		for(int i = 0; i < EnumAttachmentType.values().length; ++i)
		{
			attachment = gun.getAttachment(itemStack, i);
			
			if(attachment != null && attachment.shouldRender())
			{
				model = this.attachmentModels[i][attachment.getID()];
				
				if(model != null)
				{
					list2 = model.getQuads(arg0, arg1, arg2);
					
					if(list2 != null && !list2.isEmpty())
					{
						list.addAll(list2);
					}
				}
			}
		}
		
		return list;
	}

	@Override
	public boolean isAmbientOcclusion()
	{
		return this.modelMain.isAmbientOcclusion();
	}
	
	@Override
	public boolean isBuiltInRenderer()
	{
		return this.modelMain.isBuiltInRenderer();
	}

	@Override
	public boolean isGui3d()
	{
		return this.modelMain.isGui3d();
	}
	
	private static final Matrix4f NULL_MATRIX = new Matrix4f();
	
	@Override
	public Pair<? extends IBakedModel, Matrix4f> handlePerspective(TransformType transformType)
	{
		if(transformType == TransformType.FIRST_PERSON_RIGHT_HAND)
		{
			EntityPlayer entityPlayer = Minecraft.getMinecraft().player;
			
			if(entityPlayer != null && !entityPlayer.isSprinting() && !entityPlayer.isSneaking())
			{
				if(entityPlayer.getHeldItemMainhand().getItem() instanceof ItemGun && entityPlayer.getHeldItemOffhand().isEmpty() && Minecraft.getMinecraft().gameSettings.keyBindUseItem.isKeyDown())
				{
					ItemStack itemStack = entityPlayer.getHeldItemMainhand();
					ItemGun gun = (ItemGun) itemStack.getItem();
					
					Optic optic = gun.<Optic>getAttachmentCalled(itemStack, EnumAttachmentType.OPTIC.getSlot());
					
					if(optic != null && optic.canAim())
					{
						return Pair.of(this, NULL_MATRIX);
					}
				}
			}
		}
		
		return Pair.of(this, this.modelMain.handlePerspective(transformType).getRight());
	}
}

 

 

Do you have a GitHub? I’d like to see how you are attaching your attachments to your item gun (capability? NBT?)

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

Link to comment
Share on other sites

  • 5 weeks later...

Hey I know it has been a month but unfortunately I have been busy. So I tried to implement it the way you have on your mod @CAS_ual_TY but I can't seem to get it working. I've only done a test scenario just so I can get it to render before I start working on all the parts. Here is my code:

 

https://github.com/BeardlessBrady/Currency-Mod/commit/01f2dfb9380eae52f0fb738eb2fa0f84124d3bd7

Link to comment
Share on other sites

Where is this invoked from?

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

And where's that invoked from. Ultimately I need to know the IBakedModel modelMain object originates, as by the time it gets to BakedModelCurrencyFinalized, it's null.

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

IBakedModel main = event.getModelRegistry().getObject(mrl);

 

You need to insure that this is not failing.

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

Is it ever created? Use the debugger 

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

7 hours ago, BeardlessBrady said:

I dont think it was created but I have no idea why.

Where was it meant to be created? Place a breakpoint there and see if it hits.

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

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

    • Hello. I've been having a problem when launching minecraft forge. It just doesn't open the game, and leaves me with this "(exit code 1)" error. Both regular and optifine versions of minecraft launch just fine, tried both with 1.18.2 and 1.20.1. I can assure that my drivers are updated so that can't be it, and i've tried using Java 17, 18 and 21 to no avail. Even with no mods installed, the thing won't launch. I'll leave the log here, although it's in spanish: https://jmp.sh/s/FPqGBSi30fzKJDt2M1gc My specs are this: Ryzen 3 4100 || Radeon R9 280x || 16gb ram || Windows 10 I'd appreciate any help, thank you in advance.
    • Hey, Me and my friends decided to start up a Server with "a few" mods, the last few days everything went well we used all the items we wanted. Now our Game crashes the moment we touch a Lava Bucket inside our Inventory. It just instantly closes and gives me an "Alc Cleanup"  Crash screen (Using GDLauncher). I honestly dont have a clue how to resolve this error. If anyone could help id really appreciate it, I speak German and Englisch so you can choose whatever you speak more fluently. Thanks in Advance. Plus I dont know how to link my Crash Report help for that would be nice too whoops
    • I hosted a minecraft server and I modded it, and there is always an error on the console which closes the server. If someone knows how to repair it, it would be amazing. Thank you. I paste the crash report down here: ---- Minecraft Crash Report ---- WARNING: coremods are present:   llibrary (llibrary-core-1.0.11-1.12.2.jar)   WolfArmorCore (WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar)   AstralCore (astralsorcery-1.12.2-1.10.27.jar)   CreativePatchingLoader (CreativeCore_v1.10.71_mc1.12.2.jar)   SecurityCraftLoadingPlugin ([1.12.2] SecurityCraft v1.9.8.jar)   ForgelinPlugin (Forgelin-1.8.4.jar)   midnight (themidnight-0.3.5.jar)   FutureMC (Future-MC-0.2.19.jar)   SpartanWeaponry-MixinLoader (SpartanWeaponry-1.12.2-1.5.3.jar)   Backpacked (backpacked-1.4.3-1.12.2.jar)   LoadingPlugin (Reskillable-1.12.2-1.13.0.jar)   LoadingPlugin (Bloodmoon-MC1.12.2-1.5.3.jar) Contact their authors BEFORE contacting forge // There are four lights! Time: 3/28/24 12:17 PM Description: Exception in server tick loop net.minecraftforge.fml.common.LoaderException: java.lang.NoClassDefFoundError: net/minecraft/client/multiplayer/WorldClient     at net.minecraftforge.fml.common.AutomaticEventSubscriber.inject(AutomaticEventSubscriber.java:89)     at net.minecraftforge.fml.common.FMLModContainer.constructMod(FMLModContainer.java:612)     at sun.reflect.GeneratedMethodAccessor10.invoke(Unknown Source)     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)     at java.lang.reflect.Method.invoke(Method.java:498)     at com.google.common.eventbus.Subscriber.invokeSubscriberMethod(Subscriber.java:91)     at com.google.common.eventbus.Subscriber$SynchronizedSubscriber.invokeSubscriberMethod(Subscriber.java:150)     at com.google.common.eventbus.Subscriber$1.run(Subscriber.java:76)     at com.google.common.util.concurrent.MoreExecutors$DirectExecutor.execute(MoreExecutors.java:399)     at com.google.common.eventbus.Subscriber.dispatchEvent(Subscriber.java:71)     at com.google.common.eventbus.Dispatcher$PerThreadQueuedDispatcher.dispatch(Dispatcher.java:116)     at com.google.common.eventbus.EventBus.post(EventBus.java:217)     at net.minecraftforge.fml.common.LoadController.sendEventToModContainer(LoadController.java:219)     at net.minecraftforge.fml.common.LoadController.propogateStateMessage(LoadController.java:197)     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)     at java.lang.reflect.Method.invoke(Method.java:498)     at com.google.common.eventbus.Subscriber.invokeSubscriberMethod(Subscriber.java:91)     at com.google.common.eventbus.Subscriber$SynchronizedSubscriber.invokeSubscriberMethod(Subscriber.java:150)     at com.google.common.eventbus.Subscriber$1.run(Subscriber.java:76)     at com.google.common.util.concurrent.MoreExecutors$DirectExecutor.execute(MoreExecutors.java:399)     at com.google.common.eventbus.Subscriber.dispatchEvent(Subscriber.java:71)     at com.google.common.eventbus.Dispatcher$PerThreadQueuedDispatcher.dispatch(Dispatcher.java:116)     at com.google.common.eventbus.EventBus.post(EventBus.java:217)     at net.minecraftforge.fml.common.LoadController.distributeStateMessage(LoadController.java:136)     at net.minecraftforge.fml.common.Loader.loadMods(Loader.java:595)     at net.minecraftforge.fml.server.FMLServerHandler.beginServerLoading(FMLServerHandler.java:98)     at net.minecraftforge.fml.common.FMLCommonHandler.onServerStart(FMLCommonHandler.java:333)     at net.minecraft.server.dedicated.DedicatedServer.func_71197_b(DedicatedServer.java:125)     at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:486)     at java.lang.Thread.run(Thread.java:750) Caused by: java.lang.NoClassDefFoundError: net/minecraft/client/multiplayer/WorldClient     at java.lang.Class.getDeclaredMethods0(Native Method)     at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)     at java.lang.Class.privateGetPublicMethods(Class.java:2902)     at java.lang.Class.getMethods(Class.java:1615)     at net.minecraftforge.fml.common.eventhandler.EventBus.register(EventBus.java:82)     at net.minecraftforge.fml.common.AutomaticEventSubscriber.inject(AutomaticEventSubscriber.java:82)     ... 31 more Caused by: java.lang.ClassNotFoundException: net.minecraft.client.multiplayer.WorldClient     at net.minecraft.launchwrapper.LaunchClassLoader.findClass(LaunchClassLoader.java:191)     at java.lang.ClassLoader.loadClass(ClassLoader.java:418)     at java.lang.ClassLoader.loadClass(ClassLoader.java:351)     ... 37 more Caused by: net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerException: Exception in class transformer net.minecraftforge.fml.common.asm.transformers.SideTransformer@4e558728 from coremod FMLCorePlugin     at net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerWrapper.transform(ASMTransformerWrapper.java:260)     at net.minecraft.launchwrapper.LaunchClassLoader.runTransformers(LaunchClassLoader.java:279)     at net.minecraft.launchwrapper.LaunchClassLoader.findClass(LaunchClassLoader.java:176)     ... 39 more Caused by: java.lang.RuntimeException: Attempted to load class bsb for invalid side SERVER     at net.minecraftforge.fml.common.asm.transformers.SideTransformer.transform(SideTransformer.java:62)     at net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerWrapper.transform(ASMTransformerWrapper.java:256)     ... 41 more A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- System Details -- Details:     Minecraft Version: 1.12.2     Operating System: Linux (amd64) version 5.10.0-28-cloud-amd64     Java Version: 1.8.0_382, Temurin     Java VM Version: OpenJDK 64-Bit Server VM (mixed mode), Temurin     Memory: 948745536 bytes (904 MB) / 1564999680 bytes (1492 MB) up to 7635730432 bytes (7282 MB)     JVM Flags: 2 total; -Xmx8192M -Xms256M     IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0     FML: MCP 9.42 Powered by Forge 14.23.5.2860 63 mods loaded, 63 mods active     States: 'U' = Unloaded 'L' = Loaded 'C' = Constructed 'H' = Pre-initialized 'I' = Initialized 'J' = Post-initialized 'A' = Available 'D' = Disabled 'E' = Errored     | State | ID                 | Version                 | Source                                                | Signature                                |     |:----- |:------------------ |:----------------------- |:----------------------------------------------------- |:---------------------------------------- |     | LC    | minecraft          | 1.12.2                  | minecraft.jar                                         | None                                     |     | LC    | mcp                | 9.42                    | minecraft.jar                                         | None                                     |     | LC    | FML                | 8.0.99.99               | forge-1.12.2-14.23.5.2860.jar                         | e3c3d50c7c986df74c645c0ac54639741c90a557 |     | LC    | forge              | 14.23.5.2860            | forge-1.12.2-14.23.5.2860.jar                         | e3c3d50c7c986df74c645c0ac54639741c90a557 |     | LC    | creativecoredummy  | 1.0.0                   | minecraft.jar                                         | None                                     |     | LC    | backpacked         | 1.4.2                   | backpacked-1.4.3-1.12.2.jar                           | None                                     |     | LC    | itemblacklist      | 1.4.3                   | ItemBlacklist-1.4.3.jar                               | None                                     |     | LC    | securitycraft      | v1.9.8                  | [1.12.2] SecurityCraft v1.9.8.jar                     | None                                     |     | LC    | aiimprovements     | 0.0.1.3                 | AIImprovements-1.12-0.0.1b3.jar                       | None                                     |     | LC    | jei                | 4.16.1.301              | jei_1.12.2-4.16.1.301.jar                             | None                                     |     | LC    | appleskin          | 1.0.14                  | AppleSkin-mc1.12-1.0.14.jar                           | None                                     |     | LC    | baubles            | 1.5.2                   | Baubles-1.12-1.5.2.jar                                | None                                     |     | LC    | astralsorcery      | 1.10.27                 | astralsorcery-1.12.2-1.10.27.jar                      | a0f0b759d895c15ceb3e3bcb5f3c2db7c582edf0 |     | LC    | attributefix       | 1.0.12                  | AttributeFix-Forge-1.12.2-1.0.12.jar                  | None                                     |     | LC    | atum               | 2.0.20                  | Atum-1.12.2-2.0.20.jar                                | None                                     |     | LC    | bloodmoon          | 1.5.3                   | Bloodmoon-MC1.12.2-1.5.3.jar                          | d72e0dd57935b3e9476212aea0c0df352dd76291 |     | LC    | forgelin           | 1.8.4                   | Forgelin-1.8.4.jar                                    | None                                     |     | LC    | bountiful          | 2.2.2                   | Bountiful-2.2.2.jar                                   | None                                     |     | LC    | camera             | 1.0.10                  | camera-1.0.10.jar                                     | None                                     |     | LC    | chisel             | MC1.12.2-1.0.2.45       | Chisel-MC1.12.2-1.0.2.45.jar                          | None                                     |     | LC    | collective         | 3.0                     | collective-1.12.2-3.0.jar                             | None                                     |     | LC    | reskillable        | 1.12.2-1.13.0           | Reskillable-1.12.2-1.13.0.jar                         | None                                     |     | LC    | compatskills       | 1.12.2-1.17.0           | CompatSkills-1.12.2-1.17.0.jar                        | None                                     |     | LC    | creativecore       | 1.10.0                  | CreativeCore_v1.10.71_mc1.12.2.jar                    | None                                     |     | LC    | customnpcs         | 1.12                    | CustomNPCs_1.12.2-(05Jul20).jar                       | None                                     |     | LC    | darknesslib        | 1.1.2                   | DarknessLib-1.12.2-1.1.2.jar                          | 220f10d3a93b3ff5fbaa7434cc629d863d6751b9 |     | LC    | dungeonsmod        | @VERSION@               | DungeonsMod-1.12.2-1.0.8.jar                          | None                                     |     | LC    | enhancedvisuals    | 1.3.0                   | EnhancedVisuals_v1.4.4_mc1.12.2.jar                   | None                                     |     | LC    | extrautils2        | 1.0                     | extrautils2-1.12-1.9.9.jar                            | None                                     |     | LC    | futuremc           | 0.2.6                   | Future-MC-0.2.19.jar                                  | None                                     |     | LC    | geckolib3          | 3.0.30                  | geckolib-forge-1.12.2-3.0.31.jar                      | None                                     |     | LC    | gottschcore        | 1.15.1                  | GottschCore-mc1.12.2-f14.23.5.2859-v1.15.1.jar        | None                                     |     | LC    | hardcorerevival    | 1.2.0                   | HardcoreRevival_1.12.2-1.2.0.jar                      | None                                     |     | LC    | waila              | 1.8.26                  | Hwyla-1.8.26-B41_1.12.2.jar                           | None                                     |     | LE    | imsm               | 1.12                    | Instant Massive Structures Mod 1.12.2.jar             | None                                     |     | L     | journeymap         | 1.12.2-5.7.1p2          | journeymap-1.12.2-5.7.1p2.jar                         | None                                     |     | L     | mobsunscreen       | @version@               | mobsunscreen-1.12.2-3.1.5.jar                         | None                                     |     | L     | morpheus           | 1.12.2-3.5.106          | Morpheus-1.12.2-3.5.106.jar                           | None                                     |     | L     | llibrary           | 1.7.20                  | llibrary-1.7.20-1.12.2.jar                            | None                                     |     | L     | mowziesmobs        | 1.5.8                   | mowziesmobs-1.5.8.jar                                 | None                                     |     | L     | nocubessrparmory   | 3.0.0                   | NoCubes_SRP_Combat_Addon_3.0.0.jar                    | None                                     |     | L     | nocubessrpnests    | 3.0.0                   | NoCubes_SRP_Nests_Addon_3.0.0.jar                     | None                                     |     | L     | nocubessrpsurvival | 3.0.0                   | NoCubes_SRP_Survival_Addon_3.0.0.jar                  | None                                     |     | L     | nocubesrptweaks    | V4.1                    | nocubesrptweaks-V4.1.jar                              | None                                     |     | L     | patchouli          | 1.0-23.6                | Patchouli-1.0-23.6.jar                                | None                                     |     | L     | artifacts          | 1.1.2                   | RLArtifacts-1.1.2.jar                                 | None                                     |     | L     | rsgauges           | 1.2.8                   | rsgauges-1.12.2-1.2.8.jar                             | None                                     |     | L     | rustic             | 1.1.7                   | rustic-1.1.7.jar                                      | None                                     |     | L     | silentlib          | 3.0.13                  | SilentLib-1.12.2-3.0.14+168.jar                       | None                                     |     | L     | scalinghealth      | 1.3.37                  | ScalingHealth-1.12.2-1.3.42+147.jar                   | None                                     |     | L     | lteleporters       | 1.12.2-3.0.2            | simpleteleporters-1.12.2-3.0.2.jar                    | None                                     |     | L     | spartanshields     | 1.5.5                   | SpartanShields-1.12.2-1.5.5.jar                       | None                                     |     | L     | spartanweaponry    | 1.5.3                   | SpartanWeaponry-1.12.2-1.5.3.jar                      | None                                     |     | L     | srparasites        | 1.9.18                  | SRParasites-1.12.2v1.9.18.jar                         | None                                     |     | L     | treasure2          | 2.2.0                   | Treasure2-mc1.12.2-f14.23.5.2859-v2.2.1.jar           | None                                     |     | L     | treeharvester      | 4.0                     | treeharvester_1.12.2-4.0.jar                          | None                                     |     | L     | twilightforest     | 3.11.1021               | twilightforest-1.12.2-3.11.1021-universal.jar         | None                                     |     | L     | variedcommodities  | 1.12.2                  | VariedCommodities_1.12.2-(31Mar23).jar                | None                                     |     | L     | voicechat          | 1.12.2-2.4.32           | voicechat-forge-1.12.2-2.4.32.jar                     | None                                     |     | L     | wolfarmor          | 3.8.0                   | WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar | None                                     |     | L     | worldborder        | 2.3                     | worldborder_1.12.2-2.3.jar                            | None                                     |     | L     | midnight           | 0.3.5                   | themidnight-0.3.5.jar                                 | None                                     |     | L     | structurize        | 1.12.2-0.10.277-RELEASE | structurize-1.12.2-0.10.277-RELEASE.jar               | None                                     |     Loaded coremods (and transformers):  llibrary (llibrary-core-1.0.11-1.12.2.jar)   net.ilexiconn.llibrary.server.core.plugin.LLibraryTransformer   net.ilexiconn.llibrary.server.core.patcher.LLibraryRuntimePatcher WolfArmorCore (WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar)    AstralCore (astralsorcery-1.12.2-1.10.27.jar)    CreativePatchingLoader (CreativeCore_v1.10.71_mc1.12.2.jar)    SecurityCraftLoadingPlugin ([1.12.2] SecurityCraft v1.9.8.jar)    ForgelinPlugin (Forgelin-1.8.4.jar)    midnight (themidnight-0.3.5.jar)   com.mushroom.midnight.core.transformer.MidnightClassTransformer FutureMC (Future-MC-0.2.19.jar)   thedarkcolour.futuremc.asm.CoreTransformer SpartanWeaponry-MixinLoader (SpartanWeaponry-1.12.2-1.5.3.jar)    Backpacked (backpacked-1.4.3-1.12.2.jar)   com.mrcrayfish.backpacked.asm.BackpackedTransformer LoadingPlugin (Reskillable-1.12.2-1.13.0.jar)   codersafterdark.reskillable.base.asm.ClassTransformer LoadingPlugin (Bloodmoon-MC1.12.2-1.5.3.jar)   lumien.bloodmoon.asm.ClassTransformer     Profiler Position: N/A (disabled)     Is Modded: Definitely; Server brand changed to 'fml,forge'     Type: Dedicated Server (map_server.txt)
    • When i add mods like falling leaves, visuality and kappas shaders, even if i restart Minecraft they dont show up in the mods menu and they dont work
    • Delete the forge-client.toml file in your config folder  
  • Topics

×
×
  • Create New...

Important Information

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