Jump to content

Recommended Posts

Posted

This is something that can be used for a TON of stuff - Packet events.

 

Packet Read Event:

Where it would be called: channelRead0 in NetworkManager.java

Purpose: Packets are incredibly powerful and are used for nearly everything.  Most existing events could arguably be replaced with Packet events.  Health change?  Packet for that.  Chat message? Packet for that.

PacketReadEvent would be used to read packets sent to the client.

 

Packet Send Event:

Where it would be called: addToSendQueue in NetHandlerPlayClient.java

Purpose: Again, packets are incredibly powerful.  These would be the packets sent from the client to the server.  Things like clicking blocks, attacking entities, placing blocks, tab completing, sending chat messages, etc. 

PacketSendEvent would be cancellable, as well as be able to change the sent packet before it is sent.

 

Example Usages:

PacketReadEvent:

For reading messages sent in chat:

protected void onPacketRead(PacketReadEvent event) {
	if (event.getPacket() instanceof S02PacketChat) {
		S02PacketChat packetChat = (S02PacketChat)event.getPacket();
		System.out.println(packetChat.func_148915_c().getUnformattedText());
	}
}

For getting health changed:

protected void onPacketRead(PacketReadEvent event) {
	if (event.getPacket() instanceof S06PacketUpdateHealth) {
		S06PacketUpdateHealth packetHealth = (S06PacketUpdateHealth)event.getPacket();
		System.out.println(packetHealth.getHealth());
	}
}

 

PacketSendEvent:

Block breaking:

	protected void onPacketSend(PacketSendEvent event) {
	if (event.getPacket() instanceof C07PacketPlayerDigging) {
		C07PacketPlayerDigging digging = (C07PacketPlayerDigging)event.getPacket();
		BlockPos blockPos = digging.func_179715_a();
		Block block = mc.theWorld.getBlockState(blockPos).getBlock();
		if (digging.getStatus() == C07PacketPlayerDigging.Action.START_DESTROY_BLOCK) {
			mc.thePlayer.addChatMessage(new ChatComponentText(String.format("Started digging block %s at %s, %s, %s", 
					block.getLocalizedName(), blockPos.getX(), blockPos.getY(), blockPos.getZ())));
		} else if (digging.getStatus() == C07PacketPlayerDigging.Action.STOP_DESTROY_BLOCK) {
			mc.thePlayer.addChatMessage(new ChatComponentText(String.format("Stopped digging block %s at %s, %s, %s",
					block.getLocalizedName(), blockPos.getX(), blockPos.getY(), blockPos.getZ())));
		}
	}
}

Attacking entities:

protected void onPacketSend(PacketSendEvent event) {
	if (event.getPacket() instanceof C02PacketUseEntity)  {
		C02PacketUseEntity packetUseEntity = (C02PacketUseEntity)event.getPacket();
		if (packetUseEntity.getAction() == C02PacketUseEntity.Action.ATTACK) {
			mc.thePlayer.addChatMessage(new ChatComponentText(String.format("Started attacking entity: %s", 
					packetUseEntity.getEntityFromWorld(mc.thePlayer.getEntityWorld()).getName())));
		}
	}
}

 

These are all basic examples, though there are TONS of other examples that could benefit from this.  While there are existing events for the examples I provided, I'm sure you get the point. 

Posted

Yes I get the point, but as with the last 50 times this was suggested, it was decide that having that low level of access to the packets themselves is undesirable from a stability/high-level design point of view. Modders should not care, nore touch any of the networking code. As is pretty much everything you need/want to do with the packets directly you can do in another way.

 

So, I see no real point to add this broad of a system, that gives modders way to much opportunity to mess things up.

The costs outweigh the benefits.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

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

    • just rewatched the tutorial and my code is exactly the same as kaupenjoe's.  the item is added into the game but like i said to start it doesnt have a texture or a proper name for whatever reason.
    • yes the name is en_us.json and it is in resources -> assests -> testmod -> lang folders.  i have checked my code and am pretty confident that the code itself is correct.  i even tried loading the project in eclipse and it has the same problems, I think i will just rewatch the whole tutorial and will give an update on the situation.
    • same error, I also tried removing Valkyrian skies as well because I noticed it coming up a lot in the debug log errors
    • Hey man,    i have only been modding Minecraft for a few days but maybe I can help you. First of all make sure to follow every step of Kaupenjoe's tutorial, I found it to been very helpful and complete. The game uses the raw translation key for the item (in your case "item.testmod.alexandrite") if it can't find the correct lang file. Make sure it's name is "en_us.json" and it is saved under "ressources" -> "assets" -> "testmod".
    • whenever I try to get this item to render into the game it appears with the not texture purple and black squares and calls itself by the lang translation file path instead of the name i gave it.   { "item.testmod.alexandrite": "Alexandrite" } this is the lang json file package net.Hurst.testmod.item; import net.Hurst.testmod.TestMod; import net.minecraft.world.item.Item; import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.registries.DeferredRegister; import net.minecraftforge.registries.ForgeRegistries; import net.minecraftforge.registries.RegistryObject; public class ModItems { public static final DeferredRegister<Item> ITEMS = DeferredRegister.create(ForgeRegistries.ITEMS, TestMod.MOD_ID); public static final RegistryObject<Item> ALEXANDRITE = ITEMS.register("alexandrite", () -> new Item(new Item.Properties())); public static void register(IEventBus eventBus){ ITEMS.register(eventBus); } } this is my ModItems.java file package net.Hurst.testmod; import com.mojang.logging.LogUtils; import net.Hurst.testmod.item.ModItems; import net.minecraft.world.item.CreativeModeTabs; import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.event.BuildCreativeModeTabContentsEvent; import net.minecraftforge.event.server.ServerStartingEvent; import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.fml.ModLoadingContext; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.config.ModConfig; import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; import org.slf4j.Logger; // The value here should match an entry in the META-INF/mods.toml file @Mod(TestMod.MOD_ID) public class TestMod { public static final String MOD_ID = "testmod"; private static final Logger LOGGER = LogUtils.getLogger(); public TestMod() { IEventBus modEventBus = FMLJavaModLoadingContext.get().getModEventBus(); modEventBus.addListener(this::commonSetup); ModItems.register(modEventBus); MinecraftForge.EVENT_BUS.register(this); modEventBus.addListener(this::addCreative); ModLoadingContext.get().registerConfig(ModConfig.Type.COMMON, Config.SPEC); } private void commonSetup(final FMLCommonSetupEvent event) { } // Add the example block item to the building blocks tab private void addCreative(BuildCreativeModeTabContentsEvent event) { if(event.getTabKey() == CreativeModeTabs.INGREDIENTS){ event.accept(ModItems.ALEXANDRITE); } } // You can use SubscribeEvent and let the Event Bus discover methods to call @SubscribeEvent public void onServerStarting(ServerStartingEvent event) { } // You can use EventBusSubscriber to automatically register all static methods in the class annotated with @SubscribeEvent @Mod.EventBusSubscriber(modid = MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD, value = Dist.CLIENT) public static class ClientModEvents { @SubscribeEvent public static void onClientSetup(FMLClientSetupEvent event) { } } } this is my TestMod.java file { "parent": "minecraft:item/generated", "textures": { "layer0": "testmod:item/generated" } } this is my model file for the item. I am using intellij 2025.1.2 with fdk 1.21 and java 21 I would appreciate the help.
  • Topics

×
×
  • Create New...

Important Information

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