Jump to content

How does the Gui reference client side blocks, and how do client side blocks reference server side blocks?


Recommended Posts

Posted

When a player has a chest inventory screen open, I'd like to allow them to press a button to store information about that chest in chunk NBT on the server, but there doesn't seem to be a clean way to do this.

 

  1. When a button is pressed, you can get the inventory of the active GUI through minecraft.currentScreen.inventorySlots, but there appears to be a logical rift between that and the classes that actually refer to a block in the world (BlockChest, TileEntityChest). Is my only option to capture right click events, and cache the last block a player right clicked?
  2. When I want to send information about a chest to the server, it seems the only identifier I can use is its block position, but that seems to me like it has problems. What if a piston pushes the chest right after I send the message? Wouldn't my data then be associated with whatever new block (possibly another chest) now occupies that space?
Posted

You need to send packets.

You send a packet on the click that tells the server "hey, this button was clicked." The server then makes sure you're looking at a chest, where it is, etc. etc. and then stores the information (which does not go into chunk NBT, because chunk NBT only exists during the save/load process).

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.

Posted
  On 11/5/2017 at 7:14 AM, jabelar said:

I think a tile entity with an inventory should also have a Container class and that should help do the syncing. There should be a Container instance that is associated with the TileEntity instance, so any movement of the block by pistons or falling and such shouldn't cause trouble.

Expand  

While a TileEntity can create a minecraft.inventory.Container, it doesn't appear to store a reference to it. You may be thinking of the GuiContainer, which has a Container reference. That does appear to have a few members (windowId, transactionID) that map the Gui object on the client to an object on the server though, so thanks! I thought everything GUI related was client side only.

 

However, Container objects aren't saved, so I still need to map these GUI objects to blocks on the server side. Any thoughts?

Posted
  On 11/5/2017 at 2:29 PM, Draco18s said:

You need to send packets.

You send a packet on the click that tells the server "hey, this button was clicked." The server then makes sure you're looking at a chest, where it is, etc. etc. and then stores the information (which does not go into chunk NBT, because chunk NBT only exists during the save/load process).

Expand  

Thanks for the tip on Chunk NBT. That's excellent because it's exactly the behaviour I'm hoping for. I was eventually going to start listening for chunk load/unload events so I knew when/where to load or save my cache of chest info.

 

As for packets, I'm already sending plenty of packets, and I will indeed be attaching block<->gui mapping info to them once I find it, but that's not the problem. It appears that there's no logical relationship between GUI related classes (GuiContainer, ContainerChest), and Block related classes (TileEntityChest, BlockChest). That is to say, no GUI related class has a reference to a block related class, and no block related class has a reference to a GUI related class. In simple terms, if I can get a GuiContainer or ContainerChest on a server thread, and can print the associated TileEntityChest or BlockChest to the terminal, then I've gotten what I need.

Posted
  On 11/5/2017 at 4:45 PM, diesieben07 said:

EntityPlayer::openContainer will point to the currently open container.

Expand  

That's an interesting member, but it doesn't seem to solve the problem. The currently open Container appears to be in-memory-only, and won't be saved, so I need to use that to get a reference to a TileEntityChest or BlockChest, which will be saved.

Posted
  On 11/5/2017 at 5:06 PM, diesieben07 said:

Yes, of course.

Expand  

But that's the problem I originally stated. There are plenty of ways to get the relationship between TileEntityChest and BlockChest, and a few ways to get the relationship between GuiContainer and ContainerChest, but I've yet to draw a connection between one of those groups and the other, aside from perhaps BlockChest.getContainer(), which returns a brand new Container.

Posted
  On 11/5/2017 at 5:16 PM, diesieben07 said:

Well, this is your chest, right? Just store a reference to the TE in the container...

Expand  

Damn. I was trying to modify the behaviour of vanilla chests. If there's no other solution, I guess the only option is for me to listen for right click events , and store a static reference to the right clicked block. May async events have mercy on my soul.

Posted
  On 11/5/2017 at 7:34 PM, diesieben07 said:

On the server the inventory in the ContainerChest will either be a TileEntityChest (single chest) or an InventoryLargeChest.  Both of these can give you the chest.

Expand  

That's what I was looking for. Thanks!

 

 

I tried that on the client and found it to be a ContainerLocalMenu, so I assumed that TileEntityChest::creatContainer was dead code. I never thought to check it on the server. Did you just try it on both sides and find that the server side had a different object type in EntityPlayer::openContainer.lowerChestInventory?

 

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

    • Add the crash-report or latest.log (logs-folder) with sites like https://mclo.gs/ and paste the link to it here  
    • I removed yetanotherchance booster and now it says Invalid player identity
    • Cracked Launchers are not supported
    • After some time minecraft crashes with an error. Here is the log https://drive.google.com/file/d/1o-2R6KZaC8sxjtLaw5qj0A-GkG_SuoB5/view?usp=sharing
    • The specific issue is that items in my inventory wont stack properly. For instance, if I punch a tree down to collect wood, the first block I collected goes to my hand. So when I punch the second block of wood to collect it, it drops, but instead of stacking with the piece of wood already in my hand, it goes to the second slot in my hotbar instead. Another example is that I'll get some dirt, and then when I'm placing it down later I'll accidentally place a block where I don't want it. When I harvest it again, it doesn't go back to the stack that it came from on my hotbar, where it should have gone, but rather into my inventory. That means that if my inventory is full, then the dirt wont be picked up even though there should be space available in the stack I'm holding. The forge version I'm using is 40.3.0, for java 1.18.2. I'll leave the mods I'm using here, and I'd appreciate it if anybody can point me in the right direction in regards to figuring out how to fix this. I forgot to mention that I think it only happens on my server but I&#39;m not entirely sure. PLEASE HELP ME! LIST OF THE MODS. aaa_particles Adorn AdvancementPlaques AI-Improvements AkashicTome alexsdelight alexsmobs AmbientSounds amwplushies Animalistic another_furniture AppleSkin Aquaculture aquamirae architectury artifacts Atlas-Lib AutoLeveling AutoRegLib auudio balm betterfpsdist biggerstacks biomancy BiomesOPlenty blockui blueprint Bookshelf born_in_chaos Botania braincell BrassAmberBattleTowers brutalbosses camera CasinoCraft cfm (MrCrayfish’s Furniture Mod) chat_heads citadel cloth-config Clumps CMDCam CNB cobweb collective comforts convenientcurioscontainer cookingforblockheads coroutil CosmeticArmorReworked CozyHome CrabbersDelight crashexploitfixer crashutilities Create CreativeCore creeperoverhaul cristellib crittersandcompanions Croptopia CroptopiaAdditions CullLessLeaves curios curiouslanterns curiouslights Curses' Naturals CustomNPCs CyclopsCore dannys_expansion decocraft Decoration Mod DecorationDelightRefurbished Decorative Blocks Disenchanting DistantHorizons doubledoors DramaticDoors drippyloadingscreen durabilitytooltip dynamic-fps dynamiclights DynamicTrees DynamicTreesBOP DynamicTreesPlus Easy Dungeons EasyAnvils EasyMagic easy_npc eatinganimation ecologics effective_fg elevatorid embeddium emotecraft enchantlimiter EnchantmentDescriptions EnderMail engineersdecor entityculling entity_model_features entity_texture_features epicfight EvilCraft exlinefurniture expandability explosiveenhancement factory-blocks fairylights fancymenu FancyVideo FarmersDelight fast-ip-ping FastSuite ferritecore finsandtails FixMySpawnR Forge Middle Ages fossil FpsReducer2 furnish GamingDeco geckolib goblintraders goldenfood goodall H.e.b habitat harvest-with-ease hexerei hole_filler huge-structure-blocks HunterIllager iammusicplayer Iceberg illuminations immersive_paintings incubation infinitybuttons inventoryhud InventoryProfilesNext invocore ItemBorders itemzoom Jade jei (Just Enough Items) JetAndEliasArmors journeymap JRFTL justzoom kiwiboi Kobolds konkrete kotlinforforge lazydfu LegendaryTooltips libIPN lightspeed lmft lodestone LongNbtKiller LuckPerms Lucky77 MagmaMonsters malum ManyIdeasCore ManyIdeasDoors marbledsarsenal marg mcw-furniture mcw-lights mcw-paths mcw-stairs mcw-trapdoors mcw-windows meetyourfight melody memoryleakfix Mimic minecraft-comes-alive MineTraps minibosses MmmMmmMmmMmm MOAdecor (ART, BATH, COOKERY, GARDEN, HOLIDAYS, LIGHTS, SCIENCE) MobCatcher modonomicon mods_optimizer morehitboxes mowziesmobs MutantMonsters mysticalworld naturalist NaturesAura neapolitan NekosEnchantedBooks neoncraft2 nerb nifty NightConfigFixes nightlights nocube's_villagers_sell_animals NoSeeNoTick notenoughanimations obscure_api oculus oresabovediamonds otyacraftengine Paraglider Patchouli physics-mod Pillagers Gun PizzaCraft placeableitems Placebo player-animation-lib pneumaticcraft-repressurized polymorph PrettyPipes Prism projectbrazier Psychadelic-Chemistry PuzzlesLib realmrpg_imps_and_demons RecipesLibrary reeves-furniture RegionsUnexplored restrictedportals revive-me Scary_Mobs_And_Bosses selene shetiphiancore ShoulderSurfing smoothboot
  • Topics

×
×
  • Create New...

Important Information

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