Jump to content

[KINDA SOLVED] [1.9] Using IBakedModel instead of ISmartItemModel


mortinious

Recommended Posts

Hi.

 

I'm a returning oldschool modder (modded alot around 2011-2012) and are trying to make a return but a lot of stuff has changed.

 

What I'm trying to do is to have an items texture based on 2 images depending on what NBT tags are set e.g "material"=1 and "socket"=2 generate a specific combination of 2 textures baked together.

 

The thing is I've been searching for a guide or tutorial on how the baked models work but i only find guides/tutorials on ISmartItemModel which is removed from 1.9.

 

Can someone give me a brief explanation or link to a guide the explains how to use the baked item models in 1.9?

If this already exists on the forum you have to excuse me as I've been searching and googling for hours without finding anything that gave me any enlightenment on the issue.

 

 

 

Link to comment
Share on other sites

Should i extend the model to ItemOverrideList or do i even need a custom Model file anymore?

 

This is the main problem i have, since i havent worked with ISmartItemModel i dont really know how to translate the guides and there is currently no good documentation on how to translate it either.

Link to comment
Share on other sites

Ok, i said i wouldnt ask any more questions so answer if you like, if not i guess i have to wait for some decent documentation gets released on the issue.

 

So now my custom model file implements IBakedModel and the getOverrides fuction automatically got added. From what i've read ItemOverrides are new to 1.9, how do i create/use them? The getOverrides() returns null and have no arguments, so what is the reason of having it if you have to create the ItemOverrides locally anyway?

Link to comment
Share on other sites

By not returning 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

Thanks for the answer, ofc i know i have to change the return but to what?

 

The getOverrides() returns a ItemOverrideList which in turns needs a List<ItemOverrides> in its constructor. I looked at the constructor of ItemOverride and i dont understand what the variables are since they are not yet deobfuscated. What are the parameters in ItemOverride so i can create my own?

 

Do i need to create a CustomOverrideHandler aswell as CustomOverrideList to handle the states?

 

After a bit more research i found out that getOverride() is never ran by minecraft? It only runs from RenderItem and the specific function is never ran.

 

Now i've traced the problem further, I get to the function getItemModelWithOverrides() in RenderITem with the CustomModel intact, there the fuction translates it into a standard SimpleBakedModel instead so all my custom settings in my CustomModels getOverrides() is removed. What am i doing wrong here?

 

I think i've gotten it to work somewhat decently but now camera transforms from the JSON file doesnt work at all and the item is held like a normal item despite having the same JSON file as before.

If i disable the custom model it goes back to normal. Also getItemCameraTransforms() in IBakedModel is marked as @Deprecated so how do i get the json-transforms now?

Link to comment
Share on other sites

Oh, sorry i was a bit vague. I get my CustomModel to work with all the stuff you said. The thing is that now all the display settings from the json file is discarded and the sword (which is what the custom model is rendering) is rendered very wierd: image

 

The json file is basicly a copy of the vanilla sword one and is i disable the custom model and everything surrounding it and render the item normally it works perfectly.

 

I am able to modify how the item is rendered by implementing IPerspectiveAwareModel instead of IBakedModel but i have some troubles to make it look right.

 

Therefor i ask if you have to manuallt render custom models or if im just doing something wrong.

Link to comment
Share on other sites

UPDATED!

 

I post what i think is needed, if you need more code just tell me, didnt wanna overdo it.

 

Some code is not used and are there to future proof.

 

 

SocketSwordItemModel aka my custom model

public class SocketSwordItemModel implements IBakedModel{

public static final ModelResourceLocation modelResourceLocation = new ModelResourceLocation("mortiniousmods:socket_iron_sword", "inventory");
public static final ArrayList<ModelResourceLocation> socketModelResourceLocations = new ArrayList<ModelResourceLocation>(){{
	add(new ModelResourceLocation("mortiniousmods:socket_vile", "inventory"));
	add(new ModelResourceLocation("mortiniousmods:socket_spectral", "inventory"));
}};

public int socket;
public ArrayList<IBakedModel> socketModels;

public IBakedModel model;

public SocketSwordItemModel(IBakedModel existingModel, ArrayList<IBakedModel> socketModels){
	model = existingModel;
	this.socketModels = socketModels;
}

public SocketSwordItemModel getBakedModel(SocketSwordItemModel base, IBakedModel socket){
	return base;

}

@Override
public List<BakedQuad> getQuads(IBlockState state, EnumFacing side, long rand) {
		ArrayList<BakedQuad> swordQuads = new ArrayList(model.getQuads(state, null, rand));
	if(socket != -1){
 		ArrayList<BakedQuad> socketQuads = new ArrayList(socketModels.get(socket).getQuads(state, null, rand));
 		ArrayList<BakedQuad> newQuads = new ArrayList<BakedQuad>();
 		newQuads.addAll(swordQuads);
 		newQuads.addAll(socketQuads);


		//swordQuads.addAll(socketQuads);


		return newQuads.subList(0, newQuads.size());
	}
	return swordQuads.subList(0, swordQuads.size());
}

@Override
public boolean isAmbientOcclusion() {
	// TODO Auto-generated method stub
	return model.isAmbientOcclusion();
}

@Override
public boolean isGui3d() {
	// TODO Auto-generated method stub
	return model.isGui3d();
}

@Override
public boolean isBuiltInRenderer() {
	// TODO Auto-generated method stub
	return false;
}

@Override
public TextureAtlasSprite getParticleTexture() {
	// TODO Auto-generated method stub
	return model.getParticleTexture();
}

@Override
public ItemCameraTransforms getItemCameraTransforms() {
	// TODO Auto-generated method stub
	return ItemCameraTransforms.DEFAULT;
}

@Override
public ItemOverrideList getOverrides() {
	// TODO Auto-generated method stub
	return CustomOverrideList.INSTANCE;
}

 

ModelBakeEventHandler

public class ModelBakeEventHandler {
  public static final ModelBakeEventHandler instance = new ModelBakeEventHandler();

  private ModelBakeEventHandler(){};

  // Called after all the other baked models have been added to the modelRegistry
  // Allows us to manipulate the modelRegistry before BlockModelShapes caches them.
  @SubscribeEvent
  public void onModelBakeEvent(ModelBakeEvent event)
  {
    // Find the existing mapping for ChessboardSmartItemModel - we added it in StartupClientOnly.initClientOnly(), which
    //   caused it to be loaded from resources (model/items/mbe15_item_chessboard.json) just like an ordinary item
    // Replace the mapping with our ISmartBlockModel, using the existing mapped model as the base for the smart model.
    Object object =  event.getModelRegistry().getObject(SocketSwordItemModel.modelResourceLocation);
    ArrayList<IBakedModel> socketModels = new ArrayList<IBakedModel>();
    for(int i = 0; i < SocketSwordItemModel.socketModelResourceLocations.size(); i++){
        socketModels.add((IBakedModel)event.getModelRegistry().getObject(SocketSwordItemModel.socketModelResourceLocations.get(i)));
    }

    if (object instanceof IBakedModel) {
    	IBakedModel existingModel = (IBakedModel)object;
    	SocketSwordItemModel customModel = new SocketSwordItemModel(existingModel,socketModels);
    	event.getModelRegistry().putObject(SocketSwordItemModel.modelResourceLocation, customModel);
    	Object object2 =  event.getModelRegistry().getObject(SocketSwordItemModel.modelResourceLocation);
    	object2.hashCode();
    }
  }
}

 

CustomOverrideList

public final class CustomOverrideList extends ItemOverrideList
{
    public static final CustomOverrideList INSTANCE = new CustomOverrideList();
    private CustomOverrideList()
    {
        super(ImmutableList.<ItemOverride>of());
    }

    @Override
    public IBakedModel handleItemState(IBakedModel originalModel, ItemStack stack, World world, EntityLivingBase entity)
    {
    	if(stack.hasTagCompound()){
    		((SocketSwordItemModel)originalModel).socket = stack.getTagCompound().getInteger("socket");
    	}
        return originalModel;
    }
}

 

ClientProxy

public class ClientProxy extends CommonProxy {

    @Override
    public void preInit(FMLPreInitializationEvent e) {
        super.preInit(e);


    }

    @Override
    public void init(FMLInitializationEvent e) {
        super.init(e);
        
        ItemRenderRegister.registerItemRenderer();
        BlockRenderRegister.registerBlockRenderer();
        ItemRenderRegister.init();
        
        MinecraftForge.EVENT_BUS.register(ModelBakeEventHandler.instance);
    }

    @Override
    public void postInit(FMLPostInitializationEvent e) {
        super.postInit(e);
    }
}

 

ItemRenderRegister

public final class ItemRenderRegister {


public static String modid = ModMain.MODID;

public static void init(){
        ModelLoader.setCustomModelResourceLocation(ModItems.socket_crystal, 0, new ModelResourceLocation("mortiniousmods:vile_crystal","inventory"));
        ModelLoader.setCustomModelResourceLocation(ModItems.socket_crystal, 1, new ModelResourceLocation("mortiniousmods:spectral_crystal","inventory"));

        ModelLoader.setCustomModelResourceLocation(ModItems.socket_iron_sword, 0, new ModelResourceLocation("mortiniousmods:socket_iron_sword", "inventory"));
        ModelLoader.setCustomModelResourceLocation(ModItems.socket_iron_sword, 1, new ModelResourceLocation("mortiniousmods:socket_vile", "inventory"));
        ModelLoader.setCustomModelResourceLocation(ModItems.socket_iron_sword, 2, new ModelResourceLocation("mortiniousmods:socket_spectral", "inventory"));
        
}

    public static void registerItemRenderer() {
   	
    	reg(ModItems.socket_crystal, 0, "vile_crystal");
    	reg(ModItems.socket_crystal, 1, "spectral_crystal");
    	reg(ModItems.socket_iron_sword, 0, "socket_iron_sword");
    	reg(ModItems.socket_iron_sword, 1, "socket_vile");
    	reg(ModItems.socket_iron_sword, 2, "socket_spectral");
    	//reg(ModItems.socket_iron_sword);
    	
    }
    
    public static void reg(Item item) {
        Minecraft.getMinecraft().getRenderItem().getItemModelMesher()
        .register(item, 0, new ModelResourceLocation(modid + ":" + item.getUnlocalizedName().substring(5), "inventory"));
    }
    
    public static void reg(Item item, int meta, String file) {
        Minecraft.getMinecraft().getRenderItem().getItemModelMesher()
        .register(item, meta, new ModelResourceLocation(modid + ":" + file, "inventory"));
        
    }
    
    
    
    
}

 

Link to comment
Share on other sites

UPDATE: The model merging now works as it should, still the issue of it being rendered wierdly persists.

I saw a post recently with someone having the same problem but i already had my item set to parent=item/handheld and without the custom model the item renders correctly (like a vanilla sword).

I also updated the previous post with current code

Link to comment
Share on other sites

My needs is as follows:

 

I have a base model of a sword.

I also have an array of smaller models that are going on top of the sword model depending on a few NBT tags. All models work as intended except their transformations

I get the merging to work but i cant get the transformation to be transferred from the json file to the final model. (the super classes only returns ItemCameraTransformation.DEFAULT)

If i disable the custom model so i just get the base sword model it is transformed as it should based on the json file.

 

I might be totally off couse since i based it on a tutorial for 1.8.9 but there is no documentation for 1.9 yet so i didnt have a choice

Link to comment
Share on other sites

Thanks for the answer, now my problem is that i cant find where to get the transforms from the original models. The earliest i get them they are already baked by Forge (into ItemLayerModel$BakedItemModel) and their transforms are private.

getItemCameraTransforms() are as i said decrepated and returns DEFUALT.

Link to comment
Share on other sites

So now my model works as intended. I hard coded the transformations since i found no way of getting the to be read correctly from the base model. If any one knows a way, please tell.

For others with the same problem, here's the code i used for the transformation of a handheld item (sword/axe/shovel).

 

	@Override
public Pair<? extends IBakedModel, Matrix4f> handlePerspective(TransformType type) {
	Matrix4f m = new Matrix4f();
	m.setIdentity();
	TRSRTransformation trsrt = new TRSRTransformation(m);


	switch(type){
	case FIRST_PERSON_RIGHT_HAND:
		trsrt = new TRSRTransformation(new Vector3f( 0.1f, 0.2f, 0.05f ), new Quat4f(-0.15304594f, -0.6903456f, 0.15304594f, 0.6903456f), new Vector3f(0.68f, 0.68f, 0.68f),  new Quat4f(0.0f, 0.0f, 0.0f, 1.0f));
		break;
	case FIRST_PERSON_LEFT_HAND:
		trsrt = new TRSRTransformation(new Vector3f( 0.1f, 0.2f, 0.05f ), new Quat4f(0.15304594f, -0.6903456f, 0.15304594f, -0.6903456f), new Vector3f(0.68f, 0.68f, 0.68f),  new Quat4f(0.0f, 0.0f, 0.0f, 1.0f));
		break;
	case THIRD_PERSON_RIGHT_HAND:
		trsrt = new TRSRTransformation(new Vector3f( 0.0f, 0.25f, 0.03f ), new Quat4f(-0.3265056f, -0.6272113f, 0.32650554f, 0.62721133f), new Vector3f(0.85f, 0.85f, 0.85f),  new Quat4f(0.0f, 0.0f, 0.0f, 1.0f));
		break;
	case THIRD_PERSON_LEFT_HAND:
		trsrt = new TRSRTransformation(new Vector3f( 0.0f, 0.25f, 0.03f ), new Quat4f(-0.3265056f, 0.6272113f, -0.32650554f, 0.62721133f), new Vector3f(0.85f, 0.85f, 0.85f),  new Quat4f(0.0f, 0.0f, 0.0f, 1.0f));
		break;
	case GROUND:
		trsrt = new TRSRTransformation(new Vector3f( 0.0f, 0.0f, 0.0f ), new Quat4f(0.0f, 0.0f, 0.0f, 1.0f), new Vector3f(0.5f, 0.5f, 0.5f),  new Quat4f(0.0f, 0.0f, 0.0f, 1.0f));
		break;

	default:
		break;
	}

	return Pair.of(this,trsrt.getMatrix());
}

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

    • As a seasoned investor, I’ve learned that the financial world can be exciting and treacherous. My experiences with investments have taught me the importance of diligence and thorough research, particularly when dealing with newer and high-risk assets like Bitcoin. Unfortunately, my journey with Bitcoin was marred by a painful lesson in the form of a scam, which I hope to share to help others avoid similar pitfalls. My introduction to Bitcoin investing seemed promising. The allure of high returns and the buzz surrounding cryptocurrency were captivating. I was drawn to several Bitcoin investment platforms that promised substantial profits. These platforms presented themselves with professional websites, attractive promotions, and genuine testimonials. I was led to believe that these sites were reliable and that I was making a sound investment. However, this trust proved to be misplaced. The platform I initially invested in showcased fake success stories and substantial profits to entice investors. They used these fabricated examples to build credibility and persuade new investors like me to commit more funds. Their tactics were sophisticated; they knew exactly how to create an illusion of success and security. I, too, was lured by their promises and gradually invested a considerable amount of money, totaling 68,000 USD.The initial investments went smoothly. My account appeared to grow with impressive returns, and I felt a sense of validation in my investment strategy. But things took a drastic turn when I decided to make a more significant investment, believing that the returns would only get better. Once I deposited a substantial sum, the platform’s behavior changed abruptly. My account was frozen without warning, and I was faced with a barrage of demands for additional payments before I could access my funds or the supposed profits. The situation was both distressing and bewildering. I was met with excuses and obstructions at every turn. It became clear that I was dealing with a fraudulent company that had no intention of honoring its commitments. The realization that I had been deceived was crushing. The emotional and financial toll of the situation was overwhelming. Determined to recover my funds, I reached out to Trust Geeks Hack Expert, a service recommended by a trusted friend who had faced a similar ordeal. My initial skepticism was tempered by desperation and hope. Trust Geeks Hack Expert took immediate action. Their team worked tirelessly to investigate the fraudulent platform and recover my lost funds. Their dedication and expertise were evident throughout the process. In just a few weeks, Trust Geeks Hack Expert managed to successfully retrieve the full amount of 68,000 USD. Their assistance was thorough and professional, and they kept me informed every step of the way. Their efforts not only resulted in the recovery of my funds but also provided me with invaluable insights into how these scams operate. This. This experience has been a harsh lesson in the importance of conducting thorough research before investing in any platform, particularly in the cryptocurrency space. The allure of high returns can be overwhelming, but it’s crucial to approach such investments with caution. Verify the legitimacy of the platform, seek out reviews from reliable sources, and ensure that any investment opportunity has a track record of transparency and reliability. To anyone who finds themselves in a similar predicament, I cannot recommend Trust Geeks Hack Expert  enough. Their professionalism and commitment to recovering my funds were exemplary:: E>mail: trustgeekshackexpert {@} fastservice{.}com -----> Tele>gram : Trustgeekshackexpert, And also  What's>App   + 1-7-1-9-4-9-2-2-6-9-3
    • As a seasoned investor, I’ve learned that the financial world can be exciting and treacherous. My experiences with investments have taught me the importance of diligence and thorough research, particularly when dealing with newer and high-risk assets like Bitcoin. Unfortunately, my journey with Bitcoin was marred by a painful lesson in the form of a scam, which I hope to share to help others avoid similar pitfalls. My introduction to Bitcoin investing seemed promising. The allure of high returns and the buzz surrounding cryptocurrency were captivating. I was drawn to several Bitcoin investment platforms that promised substantial profits. These platforms presented themselves with professional websites, attractive promotions, and genuine testimonials. I was led to believe that these sites were reliable and that I was making a sound investment. However, this trust proved to be misplaced. The platform I initially invested in showcased fake success stories and substantial profits to entice investors. They used these fabricated examples to build credibility and persuade new investors like me to commit more funds. Their tactics were sophisticated; they knew exactly how to create an illusion of success and security. I, too, was lured by their promises and gradually invested a considerable amount of money, totaling 68,000 USD.The initial investments went smoothly. My account appeared to grow with impressive returns, and I felt a sense of validation in my investment strategy. But things took a drastic turn when I decided to make a more significant investment, believing that the returns would only get better. Once I deposited a substantial sum, the platform’s behavior changed abruptly. My account was frozen without warning, and I was faced with a barrage of demands for additional payments before I could access my funds or the supposed profits. The situation was both distressing and bewildering. I was met with excuses and obstructions at every turn. It became clear that I was dealing with a fraudulent company that had no intention of honoring its commitments. The realization that I had been deceived was crushing. The emotional and financial toll of the situation was overwhelming. Determined to recover my funds, I reached out to Trust Geeks Hack Expert, a service recommended by a trusted friend who had faced a similar ordeal. My initial skepticism was tempered by desperation and hope. Trust Geeks Hack Expert took immediate action. Their team worked tirelessly to investigate the fraudulent platform and recover my lost funds. Their dedication and expertise were evident throughout the process. In just a few weeks, Trust Geeks Hack Expert managed to successfully retrieve the full amount of 68,000 USD. Their assistance was thorough and professional, and they kept me informed every step of the way. Their efforts not only resulted in the recovery of my funds but also provided me with invaluable insights into how these scams operate. This. This experience has been a harsh lesson in the importance of conducting thorough research before investing in any platform, particularly in the cryptocurrency space. The allure of high returns can be overwhelming, but it’s crucial to approach such investments with caution. Verify the legitimacy of the platform, seek out reviews from reliable sources, and ensure that any investment opportunity has a track record of transparency and reliability. To anyone who finds themselves in a similar predicament, I cannot recommend Trust Geeks Hack Expert  enough. Their professionalism and commitment to recovering my funds were exemplary:: E>mail: trustgeekshackexpert{@}fastservice{.}com -----> Tele>gram : Trustgeekshackexpert, And also  What's>App   + 1-7-1-9-4-9-2-2-6-9-3
    • I've been playing it for only 1 day and it doesn't want to go into the game anymore. I've tried reinstalling the game and repairing the game files (on curseforge) but it still doesn't work. Whenever i try to click on the Singleplayer icon, it just flickers into the world creation page and flickers back 
    • https://gist.github.com/RealMangoBot/03ce10d60ce10f126dcf2c033c3a4f46  
  • Topics

×
×
  • Create New...

Important Information

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