Posted March 2, 20178 yr for(int i = Xlow; i <= Xhigh;i++) { for(int j = Zlow; j <= Zhigh;j++) { int k; for (k = 120; ! (Block.getIdFromBlock(world.getBlock(i, k, j)) == 110) && k > 62; k--) { ; } } } My mod often uses getIdFromBlock(x,y,z) method and with the new BlockPos system I can't find a way to replace that function with a similar function that does the same thing in one line. I know how to use BlockPos but multiple lines are used and then I will need to change the for loop logic or make it possibly slower. (Block.getIdFromBlock(world.getBlockState((i,j,k)).getBlock() Only the (i,j,k) parameter doesn't work, how can I make this work since after all BlockPos is just a 3d vector right? Edited March 2, 20178 yr by Lethalbeast06 spelling
March 2, 20178 yr Author 1 minute ago, Awesome_Spider said: 1.7.10 is not supported here. changed title i am updating from 1.7.10 to 1.11
March 2, 20178 yr Oh, sorry. Replace world.getBlock(i, k, j) with world.getBlock(new BlockPos(i, k, j)).
March 2, 20178 yr Author 2 minutes ago, Awesome_Spider said: new BlockPos(i, k, j) ah thanks i was thinking the same, although this still gives error with a slight modification this works Block.getIdFromBlock(world.getBlockState(new BlockPos(i, k, j)).getBlock())
March 2, 20178 yr Author eclipse gives an error that types don't match, when adding .getblock() the blockstate is converted into a block object which is what getIdFromBlock needs and it works
March 2, 20178 yr world.getBlockState() returns an IBlockState. If you want the Block from this, you need to do .getBlock() 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.
March 2, 20178 yr Don't rely on numeric IDs of singletons like Block and Item, they're automatically assigned and can be different in every save. Compare the objects directly instead (e.g. state.getBlock() == Blocks.OBSIDIAN). Edited March 2, 20178 yr by Choonster Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.
March 2, 20178 yr Or, if you can be somewhat flexible, compare using instanceof. This will match modded block classes that extend your block of interest. The debugger is a powerful and necessary tool in any IDE, so learn how to use it. You'll be able to tell us more and get better help here if you investigate your runtime problems in the debugger before posting.
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.