Posted July 28, 201510 yr I'm trying to make use BlockEvent.BreakEvent to allow the player to chop down trees that are multiple blocks wide all at once, but all kinds of things are going wrong. It counts all blocks as wood, even if they're not, and it always thinks that positions have already been used. (so, basically, all the breaks are being tripped every time.) I honestly don't know why this is happening, can anyone enlighten me? Notes: * I've tried using Block#isWood, it doesn't help. * I've also tried comparing the individual co-ordinates in the BlockPoses instead of .equals'ing them, it doesn't help. Code: @SubscribeEvent public void treecapitate(BlockEvent.BreakEvent event) { if(event.state.getBlock().isWood(event.world, event.pos)) { chopTree(event.world, event.pos, new ArrayList<BlockPos>(128)); } } public void chopTree(World world, BlockPos pos, List<BlockPos> done) { done.add(pos); for(int i = 2; i <= 5; i++) { BlockPos target = pos.offset(EnumFacing.getFront(i)); System.out.println(target.toString()); if(world.getBlockState(target).getBlock().equals(Blocks.log)); { System.out.println("Found wood!"); boolean stop = false; for(BlockPos donepos : done) { System.out.println(donepos.toString()); if(donepos.equals(target)) { stop = true; break; } } if(stop = false) { chopTree(world, target, done); } else System.out.println("Been there, done that!"); } } while(world.getBlockState(pos.up()).getBlock().isWood(world, pos.up())) { world.destroyBlock(pos.up(), true); pos = pos.up(); } } Console output when the player harvests the northwest corner of a 2x2 tree: Note: The actual donepos should have been 2180/65/-1499. BlockPos{x=2180, y=65, z=-1501} Found wood! BlockPos{x=2180, y=65, z=-1500} Been there, done that! BlockPos{x=2180, y=65, z=-1499} Found wood! BlockPos{x=2180, y=65, z=-1500} Been there, done that! BlockPos{x=2179, y=65, z=-1500} Found wood! BlockPos{x=2180, y=65, z=-1500} Been there, done that! BlockPos{x=2181, y=65, z=-1500} Found wood! BlockPos{x=2180, y=65, z=-1500} Been there, done that!
July 28, 201510 yr You are making the code way more convoluted than you need to: why use a List at all, when you are already iterating over positions? Make your iteration logic do the work. Another thing - if you are going to use the position above the current one, use pos.up() once as an assignment, like so: // or however you want to check if it's a log, perhaps there's a Forge method while (world.getBlockState(pos).getBlock() instanceof BlockLog) { // destroy the block world.destroyBlock(pos, true); // this is also where you should check the surrounding blocks // but those can also be long branches, so you should probably come up with a better system than this // which only goes up and possibly one block to each side (I'm not writing that, though) // finally move up one position pos = pos.up(); } Also, check your code for errors - you surely meant to use == here: if(stop = false) And be careful using .equals - that's usually not what you want. http://i.imgur.com/NdrFdld.png[/img]
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.