Jump to content

[1.9] Assistance required in handling chest opening interactions


baegmon

Recommended Posts

Currently working on a custom party system but I can't seem to figure out chests.

 

I have a HashMap which tracks all the players and the blocks they have placed (have made sure this also allows Chests):

 

private HashMap<String, ArrayList<Block>> ownedBlocks = new HashMap<String, ArrayList<Block>>();

 

Now, I'm trying to handle an event where a user who did not place the block cannot access the contents of the chests.

 

@SubscribeEvent
public void playerOpenChest(PlayerOpenContainerEvent event){

	EntityPlayer player = event.getEntityPlayer();

	if(player.openContainer instanceof ContainerChest){

		ContainerChest chest = (ContainerChest) player.openContainer;	
		String playerName = player.getName();

		// if HashMap contains player name
		if(ownedBlocks.containsKey(playerName)){
			ArrayList<Block> playerPlacedBlocks = ownedBlocks.get(playerName);

			if(playerPlacedBlocks.contains(chest)){
				System.out.println("I made this chest! I can open this chest!");

			} else {
				System.out.println("This chest is not mine! I shouldn't open other peoples chests!");
			}

		}


	}

}

 

Whenever I try to open my chests, it fires "This chest is not mine! I shouldn't open other peoples chests!"

This is what I have so far, I'm completely lost on how to handle the "if~else" interactions with chests and would love any direction you guys could give me. Thanks!

Link to comment
Share on other sites

Ok, first of all, your data structure (that Map-List thing) is not appropriate at all.

First of, you will want to store this per Chunk and dynamically load and unload based on when chunks load and unload. Use

ChunkEvent.Load

,

ChunkEvent.Unload

,

ChunkDataEvent.Load

and

ChunkDataEvent.Save

.

 

Moreover you cannot just track

Block

instances. The

Block

instance represents all blocks of a certain type (e.g. Blocks.stone represents all stone blocks). Doing this is not the easiest task in the world, since you have to detect any modification to the world. Basically you want to store (possibly) a player for every block position in the world. You will want to use the player's UUID for this.

 

Alright will have to research abit more for how to properly implement chunks and stuff but on to the actual question, how do you tell another player that they can't use a chest through the PlayerOpenContainer event?

Link to comment
Share on other sites

I suggest using the tile entity NBT data. If you're using your own custom chests (which is really the best option), override various methods in the block class instead of using evebts., store the player UUID in the tile entity and override readFromNBT and writeToNBT.

If you're working with vanilla chests, you will have to use events. You may have to store the custom player UUID per-chunk like how diesieben07 said as well.

catch(Exception e)

{

 

}

Yay, Pokémon exception handling, gotta catch 'em all (and then do nothing with 'em).

Link to comment
Share on other sites

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

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Hello, I was trying to play a MOD in my preferred language, but I see that only some items are translated, and I go to debug and I get this information (the only thing that is translated is the bestiary):   [14sep.2024 17:14:36.415] [Render thread/WARN] [net.minecraft.client.resources.language.ClientLanguage/]: Skipped language file: mowziesmobs:lang/es_es.json (com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Expected name at line 394 column 2 path $.config.mowziesmobs.ice_crystal_attack_multiplier) [14sep.2024 17:14:36.421] [Render thread/WARN] [net.minecraft.client.resources.language.ClientLanguage/]: Skipped language file: iceandfire:lang/es_es.json (com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Unterminated object at line 1349 column 4 path $.iceandfire.sound.subtitle.dragonflute)   Is that the reason why everything is not translated? , and is there any way to fix it? Thanks
    • I got my model to render from the models renderToBuffer method. But still not quite what I want. I want to render the model from my renderer's render method. I feel that having access to the renderer and its methods will open some doors for me later down the line. //EntityRendererProvider.Context pContext = ; I want this //ToaPlayerRenderer render = new ToaPlayerRenderer(pContext, false); // if I can get the above line to work, having the methods from the renderer class would be incredibly helpful down the line RenderType rendertype = model.renderType(p.getSkinTextureLocation()); // this should be something like render.getTextureLocation() VertexConsumer vertexconsumer = buffer.getBuffer(rendertype); model.renderToBuffer(stack, vertexconsumer, paLights, 1, 1, 1, 1, 1); // I don't want the render to happen here since it doesn't use the renderer //model.render(p, 1f, pTicks, stack, buffer, paLights); I want to render the model using this It is certainly getting closer though. Probably. I am still worried that even if pContext is initialized this new instance of the renderer class will still hit me with the classic and all too familiar "can't use static method in non-static context"
    • Hello, I am learning how to create Multipart Entities and I tried creating a PartEntity based on the EnderDragonPart code. However, when I tested summoning the entity in the game, the PartEntity appeared at position x 0, y 0, z 0 within the game. I tried to make it follow the main entity, and after testing again, the part entity followed the main entity but seemed to teleport back to x 0, y 0, z 0 every tick (I'm just guessing). I don't know how to fix this can someone help me? My github https://github.com/SteveKK666/Forge-NewWorld-1.20.1/tree/master/src/main/java/net/kk/newworldmod/entity/custom Illustration  https://drive.google.com/file/d/157SPvyQCE8GcsRXyQQkD4Dyhalz6LjBn/view?usp=drive_link Sorry for my English; I’m not very good at it. 
    • its still crashing with the same message
  • Topics

×
×
  • Create New...

Important Information

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