Jump to content

Recommended Posts

Posted

I'm looking for a script that when you mine a block it wont be (destoryed or it will get destroyed and recreate itself) and still drop materials. Anyone who got a clue? :)

Posted

I don't usually give code but anyway when I do I add comments.. It's your loss if you copy and paste without trying to understand so please don't if you're serious about modding.

	@Override
public void breakBlock(World world, int x, int y, int z, Block block, int meta)
{
	//Using random ints in the drops may cause a crash. Set amounts don't.
	//Loops through all drops.
	for(int i =  0; i < block.getDrops(world, x, y, z, meta, 0).size(); i++){
		//Breaks the loop if i == size.
		if(i == block.getDrops(world, x, y, z, meta, 0).size()){
			break;
		}
		//Spawns the drops into the world.
		world.spawnEntityInWorld(new EntityItem(world, x, y, z, block.getDrops(world, x, y, z, meta, 0).get(i)));
	}
	//Sets the block to the current block.
	world.setBlock(x, y, z, this);
}

If I helped please press the Thank You button.

Posted

I don't usually give code but anyway when I do I add comments.. It's your loss if you copy and paste without trying to understand so please don't if you're serious about modding.

	@Override
public void breakBlock(World world, int x, int y, int z, Block block, int meta)
{
	//Using random ints in the drops may cause a crash. Set amounts don't.
	//Loops through all drops.
	for(int i =  0; i < block.getDrops(world, x, y, z, meta, 0).size(); i++){
		//Breaks the loop if i == size.
		if(i == block.getDrops(world, x, y, z, meta, 0).size()){
			break;
		}
		//Spawns the drops into the world.
		world.spawnEntityInWorld(new EntityItem(world, x, y, z, block.getDrops(world, x, y, z, meta, 0).get(i)));
	}
	//Sets the block to the current block.
	world.setBlock(x, y, z, this);
}

So inefficient. You can 1) store the List<ItemStack> in the method. That way you don't need those repetetive calls to block.getDrops(*), and 2) you can iterate over a list way easier. You don't even need the

if (1 == size)

statement.

Don't PM me with questions. They will be ignored! Make a thread on the appropriate board for support.

 

1.12 -> 1.13 primer by williewillus.

 

1.7.10 and older versions of Minecraft are no longer supported due to it's age! Update to the latest version for support.

 

http://www.howoldisminecraft1710.today/

Posted

So inefficient. You can 1) store the List<ItemStack> in the method. That way you don't need those repetetive calls to block.getDrops(*), and 2) you can iterate over a list way easier. You don't even need the

if (1 == size)

statement.

 

You're totally right :) I really shouldn't code while distracted. My new code probably isn't the best but it's better anyway, Here's the new code:

	@Override
public void breakBlock(World world, int x, int y, int z, Block block, int meta)
{
	super.breakBlock(world, x, y, z, block, meta);

	//List of drops
	List<ItemStack> drops = block.getDrops(world, x, y, z, meta, 0);

	//Loops through all drops.
	for(ItemStack itemstack : drops){
		//Spawns the drops into the world.
		world.spawnEntityInWorld(new EntityItem(world, x, y, z, itemstack));
	}
	//Sets the block to the current block.
	world.setBlock(x, y, z, this);
}

If I helped please press the Thank You button.

Posted

Sadly I am pretty new and still learning so don't have much experience yet, and mostly I like to run through the referenced libraries for help to make some scripts ^^

Posted

I am trying to add a creative mode into the script so you can destroy it without respawning in creative mode but cannot get it to work. :(

 

public void breakBlock(World world, int x, int y, int z, Block block, EntityPlayer player, int meta )

{

 

//Using random ints in the drops may cause a crash. Set amounts don't.

//Loops through all drops.

for(int i =  0; i < block.getDrops(world, x, y, z, meta, 0).size(); i++){

//Breaks the loop if i == size.

if(i == block.getDrops(world, x, y, z, meta, 0).size()){

break;

}

//Spawns the drops into the world.

world.spawnEntityInWorld(new EntityItem(world, x, y, z, block.getDrops(world, x, y, z, meta, 0).get(i)));

 

}

        if (!player.capabilities.isCreativeMode && (meta & 8) != 0 && world.getBlock(x, y - 1, z) == this)

        {

        world.setBlock(x, y, z, this);

        }

 

this is what i have ...

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



×
×
  • Create New...

Important Information

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