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'm trying to get the players game mode is single player. But the only way i can figure it out is using this:

EntityPlayerMP playerMP = (EntityPlayerMP)event.player;
	if(playerMP.theItemInWorldManager.getGameType() != GameType.CREATIVE || playerMP.theItemInWorldManager.getGameType() != GameType.SPECTATOR) {

 

Is there any other way to do it?

Former developer for DivineRPG, Pixelmon and now the maker of Essence of the Gods

  • Author

I also want to state that im using the tick event for this code, aswell as @SideOnly(Side.CLIENT) annotation because on servers it crashes without it...

I know it's not supposed to be used that but i don't think that client and EntityPlayerMP is compatible (Well duhhh)

Former developer for DivineRPG, Pixelmon and now the maker of Essence of the Gods

  • Author

private EssenceItems item = new EssenceItems();
private Item boots = null, body = null, legs = null, helmet = null;

@SubscribeEvent
public void playerTick(PlayerTickEvent event) {
	ItemStack stackBoots = event.player.inventory.armorItemInSlot(0);
	ItemStack stackLegs = event.player.inventory.armorItemInSlot(1);
	ItemStack stackBody = event.player.inventory.armorItemInSlot(2);
	ItemStack stackHelmet = event.player.inventory.armorItemInSlot(3);
	if(stackBoots != null) boots = stackBoots.getItem();
	else boots = null;
	if(stackBody != null) body = stackBody.getItem();
	else body = null;
	if(stackLegs != null) legs = stackLegs.getItem();
	else legs = null;
	if(stackHelmet != null) helmet = stackHelmet.getItem();
	else helmet = null;

	EntityPlayerMP playerMP = (EntityPlayerMP)event.player;
	if(playerMP.theItemInWorldManager.getGameType() != GameType.CREATIVE || playerMP.theItemInWorldManager.getGameType() != GameType.SPECTATOR) {
		if(helmet == item.flairiumHelmet && body == item.flairiumChest && legs == item.flairiumLegs && boots == item.flairiumBoots){
			event.player.capabilities.allowFlying = true;
		} else {
			event.player.capabilities.allowFlying = false;
			event.player.capabilities.isFlying = false;
		}
	}
}

 

That gives me a crash that leads to this when trying to enter a server with my mod and also when i use the EntityPlayerMP code in sp:

 

 

[12:26:31] [Client thread/ERROR] [FML]: 0: NORMAL
[12:26:31] [Client thread/ERROR] [FML]: 1: ASM: net.essence.event.ArmorAbilityEvent@262d72a playerTick(Lnet/minecraftforge/fml/common/gameevent/TickEvent$PlayerTickEvent;)V
[12:26:31] [Client thread/ERROR] [FML]: 2: ASM: net.essence.event.PlayerEvent@621104df onTick(Lnet/minecraftforge/fml/common/gameevent/TickEvent$PlayerTickEvent;)V
[12:26:31] [Client thread/ERROR] [FML]: 3: ASM: net.essence.event.PlayerEvent@7a615950 onTick(Lnet/minecraftforge/fml/common/gameevent/TickEvent$PlayerTickEvent;)V
[12:26:31] [Client thread/ERROR] [FML]: 4: ASM: net.essence.client.BarTickHandler@1a68c0c onTick(Lnet/minecraftforge/fml/common/gameevent/TickEvent$PlayerTickEvent;)V

 

 

Former developer for DivineRPG, Pixelmon and now the maker of Essence of the Gods

Okay, so how would i go for being in single player and checking the game mode?

Exactly the same. Single player has the integrated server which uses EntityPlayerMP just like the dedicated server. Nowadays the vast majority of code does not need to change whether in single or multi player.

  • Author

Well using

if (event.player instanceof EntityPlayerMP) {
		EntityPlayerMP playerMP = (EntityPlayerMP)event.player;
		if(playerMP.theItemInWorldManager.getGameType() != GameType.CREATIVE || playerMP.theItemInWorldManager.getGameType() != GameType.SPECTATOR) {
			if(helmet == item.flairiumHelmet && body == item.flairiumChest && legs == item.flairiumLegs && boots == item.flairiumBoots) {
				event.player.capabilities.allowFlying = true;
			} else {
				event.player.capabilities.allowFlying = false;
				event.player.capabilities.isFlying = false;
			}
		}
	}

Doesn't let me fly when using the flairium armour set anymore. Doesn't matter what game mode I'm in

Former developer for DivineRPG, Pixelmon and now the maker of Essence of the Gods

I've never really even used packets, it sounds noobish but i haven't ever had a need for it :P

Well, lucky for you then that you don't even need to make your own:

((EntityPlayerMP) player).playerNetServerHandler.sendPacket(new S39PacketPlayerAbilities(player.capabilities));

Step 1) Find a way to store data about the player somewhere, probably on the player (left as an exercise to the reader)

Step 2) If the player is not wearing the equipment, disable the capability of flying and save "I have turned flying off" to the data in step 1

Step 3) Next tick, if "I have turned flying off" is true, set it to false, if capability of flying is still false, turn off isFlying

Step 4) Technically optional, save a "I attempted to disable flying" value in step 1 to true, and don't change it to false until your mod enables flying again (ignore checking if flying is not allowed while this value is flagged; it saves some CPU cycles)

 

That way if another mod is allowing flight, your mod only disables the capability for 1 tick and doesn't make the player fall (which gives another mod the opportunity to turn the capability back on) and you don't constantly re-check.

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.

What the hell are you doing Anon10W1z?

The code he used was perfectly fine. Do not use Minecraft.getMinecraft().

He said this is singleplayer.

Maker of the Craft++ mod.

What the hell are you doing Anon10W1z?

The code he used was perfectly fine. Do not use Minecraft.getMinecraft().

He said this is singleplayer.

That would still only give you the client player, and would crash the mod if played on a server. There is absolutely no reason at all to use Minecraft.getMinecraft() in this case, single player or not.

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.