Jump to content
View in the app

A better way to browse. Learn more.

Forge Forums

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

[1.7.10] onBlockAdded vs onBlockPlacedBy

Featured Replies

Posted

Hi,

 

I have searched the death out of this for a few hours now and come up empty.  Basic principle of what I'm doing is that if a player places a block, that block will place a number of other blocks relative to it's position.

 

I can get onBlockAdded to work no problem, except that's called every time the block is added in game even if it's not by the player, as you can imagine this doesn't end well with each block replicating into more and more.

 

So I found onBlockPlaced but I simply cannot get it to work no matter what I do.  does anyone have an example usage of onBlockPlaced? or even onBlockPlacedBy if that would be the more correct approach?

 

Many thanks in advance kind people :)

  • Author

Ok, I broke it down to absolute basic level to debug and these are the two I have:

 

public void onBlockAdded(World world, int x, int y, int z) 
{

System.out.println("I Added");

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

}

 

public void onBlockPlaced(World world, int x, int y, int z) 
{

System.out.println("I Placed");

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

}

 

Now, the onBlockAdded works no problem (except making a never ending pillar into the sky of course), but the onBlockPlaced doesn't even run it's debug print.  I'm clearly using it incorrectly but I can't figure out how it would be used. 

 

Moreover, I can't say for sure that I know that onBlockPlaced only runs on player placement (I'm kinda just going off the name), which lead me to believe I may need onBlockPlacedBy, for which the syntax becomes less clear.

  • Author

Ok, after a bit of headscratching I can think of a workaround...  If I have two blocks, same texture, however one is placed by the player and one is the spawned one.  Call them block1 and block2 with position x y z being the initial placement position of block1.

 

on placement of block1

place block2 at (x, y, z)

for counter = 1 to countercap

	if (x,y+counter,z) = air then

		place block2 at (x, y+counter, z)

	else

		break

 

Where countercap is the max distance for the blocks to go.

 

It's pretty messy, but until i figure out how to differentiate between the player placing a block and it just being added it'll have to do...

 

 

 

Your onBlockPlaced doesn't work, because you're not overriding it, you created your own function. The signature for it is not the same as in the Block class. Always use @Override annotations to check if you overrode it correctly. Here are the signatures for these methods in Block.java:

public void onBlockAdded(World, int, int, int)
public int onBlockPlaced(World, int, int, int, int, float, float, float, int)
public void onBlockPlacedBy(World, int, int, int, EntityLivingBase, ItemStack)

  • Author

Haha perfect timing! I'd just finished fudging it with multiple blocks, it worked but it made me feel dirty. 

 

Thankyou, however I'm still not quite there.  After popping @Override above the Public int onBlockPlaced, i receive the error:

The method onBlockPlaced(World, int, int, int) of type BlockNumenorStone must override or implement a supertype method

 

I think that this is likely just me being very noobish with the Java language, so I understand if I don't get a reply to how to resolve that.

@Override only checks if you've overriden a supertype method, so you get an error when you didn't, and because of that you know where you've made a mistake.

This annotation, however, doesn't actually make the method override anything.

For it to override a supertype method, it has to have the same signature and the modifiers as the one in the superclass.

A signature of a method is what follows:

  • its name: onBlockPlaced
  • its parameter types: World, int, int, int, int, float, float, float, int

While the method name is important, the parameter names are only for your convenience.

Now look at the error you got. It says that the method onBlockPlaced(World, int, int, int) must override or implement a supertype method.

The supertype method signature for onBlockPlaced is:

onBlockPlaced(World, int, int, int, int, float, float, float, int)

And the modifiers are:

public int

As you can see, it is not the same as your method.

You have to change the parameters of your method to be the same as in the supertype, and then it is going to override it.

  • Author

internet-high-five.jpg

 

	@Override
public int onBlockPlaced(World world, int x, int y, int z, int a, float b, float c, float d, int e)

 

fixes it perfectly :)  Thank you very much , and another Java lesson learned for me today!

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...

Important Information

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

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.