Jump to content

Recommended Posts

Posted

It is possible, make sure the block metadata is the same as the item metadata and use damageDropped and idDropped.

--EDIT--

Hi,

I am making a mod where my metadata ore (gem ore) drops metadata items. I've got everything but the dropping set up. Is it even possible?

 

BlockMetaOre

package addedcompat.common;

import java.util.List;
import java.util.Random;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.client.renderer.texture.IconRegister;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.ItemStack;
import net.minecraft.util.Icon;

public class BlockMetaOre extends Block {

public BlockMetaOre(int id, Material material) {
	super(id, material.rock);
	setCreativeTab(AddedCompat.tabAddedCompat);

}

@SideOnly(Side.CLIENT)
private Icon[] icons;

@SideOnly(Side.CLIENT)
public void registerIcons(IconRegister par1IconRegister) {
	//this.blockIcon = par1IconRegister.registerIcon(AddedCompat.modid + ":" + (this.getUnlocalizedName().substring(5)));
	icons = new Icon[2];

	for(int i = 0; i < icons.length; i++) {
		icons[i] = par1IconRegister.registerIcon(AddedCompat.modid + ":" + (this.getUnlocalizedName().substring(5)) + i);
	}
}

@SideOnly(Side.CLIENT)
public Icon getIcon(int par1, int par2) {
	return icons[par2];
}

@SideOnly(Side.CLIENT)
public void getSubBlocks(int par1, CreativeTabs par2CreativeTabs, List par3List) {
	for(int i = 0; i < 2; i++) {
		par3List.add(new ItemStack(par1, 1, i));
	}


}

/*public int damageDropped(int i)
{
switch (i)
{
case 0: return 0;
case 1: return 1;
/*case 2: return 2;
case 3: return 3;
case 4: return 4;
case 5: return 5;
case 6: return 6;
case 7: return 10;
case 8: return 11;
case 9: return 9;
case 10: return 14;
}
return this.blockID;
}
public int idDropped(int par1, Random par2Random, int par3)
{
switch(par1)
{
case 0:
return AddedCompat.metaItemCompat.itemID;
case 1:
return new ItemStack(AddedCompat.metaItemCompat,1,1);
case 10:
return Base.eelEmpty.itemID;
default:
return this.blockID;
}/*


/*public int damageDropped(int i) {
         switch (par1ItemStack.getItemDamage()) 
           {
                  case 0(BLOCK METADATA): return 0(ITEM METADATA);
                  case 1(BLOCK METADATA): return 1(ITEM METADATA);
           }
    }*/

public int damageDropped(int par1) {
	return par1;
	/*if(par1 == 0) {
		return par1;
	}
	switch(par1) {
		case 0: par1 = new ItemStack(AddedCompat.metaItemCompat,1,0);
			break;
		case 1: par1 = new ItemStack(AddedCompat.metaBlockCompat,1,1);
			break;
	}*/

}

}

 

ItemBlockOre

package addedcompat.common;

import net.minecraft.item.ItemBlock;
import net.minecraft.item.ItemStack;

public class ItemBlockMetaOre extends ItemBlock {

public ItemBlockMetaOre(int id) {
	super(id);
	setHasSubtypes(true);
}

public String getUnlocalizedName(ItemStack itemStack) {
	String name = "";
	switch(itemStack.getItemDamage()) {
		case 0: {
			name = "sapphireOre";
			break;
		}
		case 1: {
			name = "rubyOre";
			break;
		}
		default: 
			name = "broken";
		}
		return getUnlocalizedName() + "." + name;
	}

public int getMetadata(int par1) {
	return par1;
}

}

Thanks!

Posted

Hi

 

You mean - like harvesting wood gives the corresponding type of wood?

 

Block.damageDropped(int metadata)

 

overridden for BlockWood:

    public int damageDropped(int metaData)

    {

        return metaData;

    }

 

-TGG

 

Posted

Hi

 

If your ItemID is always the same, and only the metadata changes, you can use damageDropped and idDropped as we described.

 

If you want to vary the ItemID as well as the damage value, you could consider overriding Block.getBlockDropped

 

    /**
     * This returns a complete list of items dropped from this block.
     *
     * @param world The current world
     * @param x X Position
     * @param y Y Position
     * @param z Z Position
     * @param metadata Current metadata
     * @param fortune Breakers fortune level
     * @return A ArrayList containing all items this block drops
     */
    public ArrayList<ItemStack> getBlockDropped(World world, int x, int y, int z, int metadata, int fortune)
    {
        ArrayList<ItemStack> ret = new ArrayList<ItemStack>();

        int count = quantityDropped(metadata, fortune, world.rand);
        for(int i = 0; i < count; i++)
        {
            int id = idDropped(metadata, world.rand, fortune);
            if (id > 0)
            {
                ret.add(new ItemStack(id, 1, damageDropped(metadata)));
            }
        }
        return ret;
    }

 

-TGG

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

    • Please read the FAQ and post logs as described there.
    • Upon starting the server I get; [main/ERROR] [minecraft/Main]: Failed to start the minecraft server net.minecraftforge.fml.LoadingFailedException: Loading errors encountered: [     Framework (framework) has failed to load correctly §7java.lang.NoClassDefFoundError: net/minecraft/client/gui/components/toasts/Toast ] I suspect there is a (possibly a few) client-only mods installed on my server. Any help would be appreciated! (Yes I know there are a lot of mods...) Here is the crash log:   https://paste.ee/p/pRz5mhMl#s=0
    • That's basically what the failure does, my apologies for failing to specify.  It just tries again on the next tick until it detects the entities for that chunk are loaded, and then tries to load the entity.  From there it gets into different failure states depending on what goes wrong, but in short, if the entity fails to load once the entity list becomes available, the request is cleared and must be resubmitted by the end user.  There should be few cases where that actually happens. Yes, that is my understanding of forceloading.  That's why on a successful summon, it removes the forceload.  Otherwise it does just leave the chunks loaded long term. Thank you for your help, any knowledge is useful!  I don't often mess with forceloading and my prior experience is 1.16 so I'm also a bit out of my depth haha.
    • I will have to do more research about 1.18 chunk loading. You were unclear about how your code manages with the entity load failure. If you simply used a loop, I suggest submitting a tick task to the next tick which does the same thing, checking if the entities are loaded and if so teleporting the right one else submitting another tick task etc. Also I think forceloading permanently force loads the chunk, and it only starts to unload when you make a subsequent call to mark the chunk as not forceloaded. I may be completely wrong, I dont know much about 1.18, most of my experience is 1.20. Good luck I hope you figure it out after all this time 😅
    • i managed to fix it by reinstalling the modpack and re-add all the extra mods I've had previously.
  • Topics

  • Who's Online (See full list)

    • There are no registered users currently online
×
×
  • Create New...

Important Information

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