Jump to content
  • Home
  • Files
  • Docs
Topics
  • All Content

  • This Topic
  • This Forum

  • Advanced Search
  • Existing user? Sign In  

    Sign In



    • Not recommended on shared computers


    • Forgot your password?

  • Sign Up
  • All Activity
  • Home
  • Mod Developer Central
  • Modder Support
  • [1.16.3]No longer a target for MonsterEntity while equipped with an iron chest plate
Currently Supported: 1.16.X (Latest) and 1.15.X (LTS)
Sign in to follow this  
Followers 0
KGJP

[1.16.3]No longer a target for MonsterEntity while equipped with an iron chest plate

By KGJP, October 26, 2020 in Modder Support

  • Reply to this topic
  • Start new topic

Recommended Posts

KGJP    0

KGJP

KGJP    0

  • Tree Puncher
  • KGJP
  • Members
  • 0
  • 9 posts
Posted October 26, 2020 (edited)

Assumptions and what we want to achieve

No longer a target for MonsterEntity while equipped with an iron chest plate.

You also want to make the same motion if you have an iron chest plate in your right or left hand

 

What I've tried

 

As an example, F "Ignored by Zombies"

 

Override the following goal of ZombieEntity

 

this.targetSelector.addGoal(2, new NearestAttackableTargetGoal<>(this, PlayerEntity.class, true));
      

Extract the goals of zombieEntity.targetSelector.

Find the above goal that targets PlayerEntity and extract the targetEntitySelector.

  private static final Field privateFieldGoals = ObfuscationReflectionHelper
      .findField(GoalSelector.class, "goals");

  private static final Field privateFieldExcludedFieldTargetEntitySelector = ObfuscationReflectionHelper
      .findField(NearestAttackableTargetGoal.class, "targetEntitySelector");

Set your custom IronChecker in setCustomPredicate

        EntityPredicate entityPredicate = (EntityPredicate) privateFieldExcludedFieldTargetEntitySelector
            .get(goal);
        entityPredicate.setCustomPredicate(new IronChecker());

 

  private static class IronChecker implements Predicate<LivingEntity> {

    @Override
    public boolean test(LivingEntity livingEntity) {
      if (!(livingEntity instanceof PlayerEntity)) {
        return false;
      }
      PlayerEntity playerEntity = (PlayerEntity) livingEntity;

      if (playerEntity.getHeldItemMainhand()
          .isItemEqual(Items.DIAMOND_CHESTPLATE.getDefaultInstance())) {
        System.out.println("HeldItemMainhand");
        return false;
      }
      System.out.println(playerEntity.inventory.armorInventory);
      if (playerEntity.inventory.armorInventory
          .contains(Items.DIAMOND_CHESTPLATE.getDefaultInstance())) {

        return false;
      }
      System.out.println(playerEntity.inventory.offHandInventory);
      if (playerEntity.inventory.offHandInventory
          .contains(Items.DIAMOND_CHESTPLATE.getDefaultInstance())) {

        return false;
      }
      return true;
    }
  }

 

If you spawn a zombie while holding the iron chest plate, it will ignore you.
However, if you don't have the chest plate, you become a target for the zombie.
And if you switch to the iron chest plate again, You will continue to be a target for the zombies. (Ideally you want to be untargeted.)

 

supplementary information

minecraft version 1.16.3
minecraft forge version 1.16.3

 

 

I have looked into various things and tried, but I can't seem to solve the problem and I am having trouble.
Please help me out.

 

 

A similar move is the pig.
If you hold a carrot, or a fishing rod with a carrot, the pig will follow the player.

But what I would like to implement is an even faster switch.
In this case, the moment you hold the chest plate in your hand, it is released from the target. Once the chest plate is removed from the hand, the player becomes the target, just like the existing movement. The moment you hold the chest plate in your hand again, you are released from the target.

 

 

Edited October 26, 2020 by KGJP
  • Quote

Share this post


Link to post
Share on other sites

ChampionAsh5357    162

ChampionAsh5357

ChampionAsh5357    162

  • World Shaper
  • ChampionAsh5357
  • Members
  • 162
  • 1021 posts
Posted October 26, 2020

Usually something like should use the new brain system to store the current target of an entity. However, very few entities are implemented with that right now. A simple solution is to check during LivingSetAttackTargetEvent for if your entity is an instance of this and the one being targeted has whatever it does and to set the current attack target to null. However, this is a huge cost in performance. The much more efficient way would be to create your own task that takes in a predicate to check if it should execute or continue executing.

  • Quote

Share this post


Link to post
Share on other sites

KGJP    0

KGJP

KGJP    0

  • Tree Puncher
  • KGJP
  • Members
  • 0
  • 9 posts
Posted October 27, 2020
16 hours ago, ChampionAsh5357 said:

Usually something like should use the new brain system to store the current target of an entity. However, very few entities are implemented with that right now. A simple solution is to check during LivingSetAttackTargetEvent for if your entity is an instance of this and the one being targeted has whatever it does and to set the current attack target to null. However, this is a huge cost in performance. The much more efficient way would be to create your own task that takes in a predicate to check if it should execute or continue executing.

I was able to do this by overriding TemptGoal and manipulating AttackTarget and delayTemptCounter.
I'm glad there's a great existing class,...
Thanks for the pork and carrots.

  • Quote

Share this post


Link to post
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.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  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.

    • Insert image from URL
×
  • Desktop
  • Tablet
  • Phone
Sign in to follow this  
Followers 0
Go To Topic Listing



  • Recently Browsing

    No registered users viewing this page.

  • Posts

    • domi0908
      fix hitboxes red baby mobs please

      By domi0908 · Posted 1 minute ago

      forge, do and turn on hit boxes in little mobs
    • domi0908
      fix hitboxes red baby mobs please

      By domi0908 · Posted 2 minutes ago

      pls fix hitboxes red baby mobs
    • domi0908
      fix hitboxes red baby mobs please

      By domi0908 · Posted 4 minutes ago

      fix hitboxes red baby mobs please 
    • MasterQuentus
      Minecraft says 200 mods installed 198 loaded

      By MasterQuentus · Posted 10 minutes ago

      OK will do when I get off work 
    • JoehnMama
      minecraft crashes as soon as I use shaders

      By JoehnMama · Posted 15 minutes ago

      And it's funny because I was able to run shaders before and now I can't
  • Topics

    • domi0908
      2
      fix hitboxes red baby mobs please

      By domi0908
      Started 4 minutes ago

    • MasterQuentus
      2
      Minecraft says 200 mods installed 198 loaded

      By MasterQuentus
      Started 25 minutes ago

    • JoehnMama
      12
      minecraft crashes as soon as I use shaders

      By JoehnMama
      Started 9 hours ago

    • BBoi69
      6
      My modpack takes years to load

      By BBoi69
      Started 6 hours ago

    • lulw
      1
      Optifine and forge not working

      By lulw
      Started 27 minutes ago

  • Who's Online (See full list)

    • Bailym
    • Klarks
    • Draco18s
    • domi0908
    • MasterQuentus
    • vemerion
    • JoehnMama
    • BBoi69
    • diesieben07
  • All Activity
  • Home
  • Mod Developer Central
  • Modder Support
  • [1.16.3]No longer a target for MonsterEntity while equipped with an iron chest plate
  • Theme

Copyright © 2019 ForgeDevelopment LLC · Ads by Longitude Ads LLC Powered by Invision Community