Posted August 23, 201411 yr 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 =)
August 23, 201411 yr 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/
August 23, 201411 yr 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 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
August 23, 201411 yr 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?
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.