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.

Featured Replies

Posted

Hello,

 

I was just wondering if there is some onLoaded event for Tile Entities that are called AFTER the chunk they are on is loaded?

I have a Tile Entity that needs to be aware of any neighbor TileEntities, and while onNeighborChange works great for detecting TileEntities being placed placed and removed, it does not help with the initial scan on Chunk load.

 

So far I have looked at:

class constructor - No point, world is not yet loaded.

readFromNBT - World/chunk not yet loaded in most cases.

validate - Called while chunk is loading, so calling getTileEntity causes infinite loop and crash.

onChunkLoad event - Not even close, would be too much work to listen to every Chunk load event and go through every tile entity.

 

 

So I'm just doing a final check here. Is there any method or event called on a TileEntity after it and it's chunk has been loaded?(I.e, I can call getTileEntity on it's location)

I see that normal entities has onChunkLoad called on every entity in the chunk, but not TileEntities?

 

I know I can just use updateEntity() with a flag or something, but I will potentially have thousands of these TileEntities loaded at once, and currently don't have a updateEntity() on them. Would rather try to avoid it.

 

 

Thank you for your time =)

There must be something better, but possibly you could use the regular populate chunk event and just scan all the blocks to see if any have tile entities.  Since the chunk is fairly small it should not be too big of a hit on perf.

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

  • Author

An empty updateEntity doesn't stop it from being called, sure, but returning false in canUpdate() does.

Anyway, I know I'm nitpicking when it comes to performance, and I should just go with the flag option unless I actually am able to measure it as a performance problem, but now I just can't put this down xD

 

So here's the solution I came up with:

Use a TickHandler with a list of TileEntities that have loaded, but not yet ticket, and call onLoaded or something on them:

private static List<ITileLoadEventListener> tileList = new ArrayList<ITileLoadEventListener>();

@SubscribeEvent
public void onServerTick(ServerTickEvent event) {
	if(event.phase == Phase.START)
	{
		for(ITileLoadEventListener listener : tileList)
			listener.onLoadComplete();
		tileList.clear();
	}
}

public static void registerListener(ITileLoadEventListener tile)
{
	tileList.add(tile);
}

Then a Tile Entity can just register itself as interested in an onLoadComplete event by calling registerListener(this) in either it's constructors, readFromNBT or validate().

 

This way, I only have one method calling every tick, instead of thousands :D

  • Author

You don't agree with the solution? Or you don't agree with the fact that I do so much to avoid the flag? xD

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.