Jump to content
Search In
  • More options...
Find results that contain...
Find results in...

[1.11] [SOLVED] Help disabling xp orbs on dead from a minion.


chipoodle
 Share

Recommended Posts

Hi everybody,

 

I have a problem coding my mod. I'm doing a summonable bear by extending EntityPolarBear class and implementing IEntityOwnable interface. Everything  works alright but when i kill my minion, it drop xp orbs which is a undesairable behavior. Could some help me disabling this feature? This is my code:

 

public class EntitySoulBear extends EntityPolarBear implements IEntityOwnable {
protected static int puntosAsignados;
private static double saludMaxima;
private static final int SALUD_INICIAL = 30;

protected static final DataParameter<Byte> TAMED = EntityDataManager.<Byte>createKey(EntityTameable.class,
		DataSerializers.BYTE);
protected static final DataParameter<Optional<UUID>> OWNER_UNIQUE_ID = EntityDataManager
		.<Optional<UUID>>createKey(EntityTameable.class, DataSerializers.OPTIONAL_UNIQUE_ID);

public EntitySoulBear(World worldIn) {
	super(worldIn);
	// this.setOwnerId(null);
	this.setTamed(false);

}

public EntitySoulBear(World worldIn, EntityPlayer playerIn) {
	this(worldIn);
	this.setOwnerId(playerIn.getUniqueID());
	this.setTamed(true);
}

@Override
protected void initEntityAI() {
	//super.initEntityAI();
	this.tasks.addTask(0, new EntityAISwimming(this));
	this.tasks.addTask(1, new EntityAIWatchClosest(this, EntityMob.class, 8.0F));
	// this.tasks.addTask(1, new EntityPolarBear.AIMeleeAttack());
	//this.tasks.addTask(2, new EntityAILeapAtTarget(this, 0.4F));
	this.tasks.addTask(3, new SoulBearAIMeleeAttack(this, 1.25D, true));
	// this.tasks.addTask(2, new EntityAIAttackMelee(this, 1.0D, true));
	// this.tasks.addTask(1, new EntityPolarBear.AIPanic());
	// this.tasks.addTask(3, new EntityAIPanic(this, 2.0D));

	//this.tasks.addTask(3, new EntityAIFollowParent(this, 1.25D));
	this.tasks.addTask(4, new SoulBearAIFollowOwner(this, 1.0D, 10.0F, 2.0F));
	this.tasks.addTask(5, new EntityAIWander(this, 1.0D));
	this.tasks.addTask(6, new EntityAIWatchClosest(this, EntityPlayer.class, 8.0F));
	this.tasks.addTask(7, new EntityAILookIdle(this));

	this.targetTasks.addTask(1, new SoulBearAIOwnerHurtByTarget(this));
	this.targetTasks.addTask(2, new SoulBearAIOwnerHurtTarget(this));
	this.targetTasks.addTask(3, new EntityAIHurtByTarget(this, true, new Class[0]));
	this.targetTasks.addTask(4, new EntityAINearestAttackableTarget(this, EntityMob.class, true));
	this.targetTasks.addTask(4, new EntityAINearestAttackableTarget(this, EntitySlime.class, true));
}

@Override
protected void applyEntityAttributes() {
	// super.applyEntityAttributes();

	EntityPlayer ep = Minecraft.getMinecraft().player;
	if (ep != null) {
		PlayerSkillCapability playerCapability = (PlayerSkillCapability) PlayerSkillCapabilityProvider.Get(ep);
		if (playerCapability != null) {
			this.puntosAsignados = playerCapability.getPaSoulBear();
			/*
			 * System.out.println( "===========>soulWolf PA:" +
			 * this.puntosAsignados + " SERVER?: " +
			 * !this.worldObj.isRemote);
			 */
			saludMaxima = this.puntosAsignados + SALUD_INICIAL;
		}
	}

	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.MAX_HEALTH);
	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.KNOCKBACK_RESISTANCE);
	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.MOVEMENT_SPEED);
	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.ARMOR);
	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.ARMOR_TOUGHNESS);

	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.FOLLOW_RANGE).setBaseValue(16.0D);

	this.getEntityAttribute(SharedMonsterAttributes.MAX_HEALTH).setBaseValue(30.0D);
	this.getEntityAttribute(SharedMonsterAttributes.FOLLOW_RANGE).setBaseValue(20.0D);
	this.getEntityAttribute(SharedMonsterAttributes.MOVEMENT_SPEED).setBaseValue(0.25D);
	this.getEntityAttribute(SharedMonsterAttributes.ARMOR).setBaseValue(1.5D);
	this.getAttributeMap().registerAttribute(SharedMonsterAttributes.ATTACK_DAMAGE);
	// this.getEntityAttribute(SharedMonsterAttributes.ATTACK_DAMAGE).setBaseValue(6.0D);
	this.getEntityAttribute(SharedMonsterAttributes.ATTACK_DAMAGE)
			.setBaseValue((1.0D * 0.35 * puntosAsignados) + 4); // 4-10 dmg
																// thru 20
																// lvls
	this.getEntityAttribute(SharedMonsterAttributes.MAX_HEALTH).setBaseValue(saludMaxima);
}

@Override
protected void entityInit() {
	super.entityInit();
	this.dataManager.register(TAMED, Byte.valueOf((byte) 0));
	this.dataManager.register(OWNER_UNIQUE_ID, Optional.<UUID>absent());
}

@Override
public void onLivingUpdate() {
	super.onLivingUpdate();
	if (this.getOwner() == null || this.getOwner().isDead)
		this.setDead();
}

@Override
public UUID getOwnerId() {
	return (UUID) ((Optional) this.dataManager.get(OWNER_UNIQUE_ID)).orNull();
}

public void setOwnerId(@Nullable UUID p_184754_1_) {
	this.dataManager.set(OWNER_UNIQUE_ID, Optional.fromNullable(p_184754_1_));
}

@Override
@Nullable
public EntityLivingBase getOwner(){
        try {
            UUID uuid = this.getOwnerId();
            return uuid == null ? null : this.world.getPlayerEntityByUUID(uuid);
        }
        catch (IllegalArgumentException var2){
            return null;
        }
    }

public void setTamed(boolean tamed) {
	// super.setTamed(tamed);
	byte tamedByte = ((Byte) this.dataManager.get(TAMED)).byteValue();
	if (tamed) {
		this.dataManager.set(TAMED, Byte.valueOf((byte) (tamedByte | 4)));
	} else {
		this.dataManager.set(TAMED, Byte.valueOf((byte) (tamedByte & -5)));
	}
}

public boolean isOwner(EntityLivingBase entityIn) {
	return entityIn == this.getOwner();
}

@Override
public Team getTeam() {
	if (this.isTamed()) {
		EntityLivingBase entitylivingbase = (EntityLivingBase) this.getOwner();

		if (entitylivingbase != null) {
			return entitylivingbase.getTeam();
		}
	}
	return super.getTeam();
}

@Override
public boolean isOnSameTeam(Entity entityIn) {
	// super.isOnSameTeam(entityIn);
	if (this.isTamed()) {
		EntityLivingBase entitylivingbase = (EntityLivingBase) this.getOwner();

		if (entityIn == entitylivingbase) {
			return true;
		}

		if (entitylivingbase != null) {
			boolean isOnTeam = entitylivingbase.isOnSameTeam(entityIn);
			boolean isSameOwner = false;
			if (entityIn instanceof IEntityOwnable && ((IEntityOwnable) entityIn).getOwner() != null)
				isSameOwner = entitylivingbase.getUniqueID()
						.equals(((IEntityOwnable) entityIn).getOwner().getUniqueID());
			return isOnTeam || isSameOwner;
		}
	}

	return super.isOnSameTeam(entityIn);
}

public boolean isTamed() {
	return (((Byte) this.dataManager.get(TAMED)).byteValue() & 4) != 0;
}

public boolean isSitting() {
	return (((Byte) this.dataManager.get(TAMED)).byteValue() & 1) != 0;
}

@Override
public void onDeath(DamageSource cause) {
	if (!this.world.isRemote && this.world.getGameRules().getBoolean("showDeathMessages")
			&& this.getOwner() instanceof EntityPlayerMP) {
		// this.getOwner().addChatMessage(this.getCombatTracker().getDeathMessage());
		this.setTamed(false);
	}
	super.onDeath(cause);
}

public static void setPuntosAsignados(int puntos) {
	puntosAsignados = puntos;
}

public void playWarningSound() {
	super.playWarningSound();
}

public boolean shouldAttackEntity(EntityLivingBase p_142018_1_, EntityLivingBase p_142018_2_) {
	if (/* !(p_142018_1_ instanceof EntityCreeper) && */ !(p_142018_1_ instanceof EntityGhast)) {

		if (p_142018_1_ instanceof EntitySoulBear) {
			EntitySoulBear soulBear = (EntitySoulBear) p_142018_1_;

			if (soulBear.isTamed() && soulBear.getOwner() == p_142018_2_) {
				return false;
			}
		}
		if (p_142018_1_ instanceof EntityWolf) {
			EntityWolf entitywolf = (EntityWolf) p_142018_1_;

			if (entitywolf.isTamed() && entitywolf.getOwner() == p_142018_2_) {
				return false;
			}
		}

		return p_142018_1_ instanceof EntityPlayer && p_142018_2_ instanceof EntityPlayer
				&& !((EntityPlayer) p_142018_2_).canAttackPlayer((EntityPlayer) p_142018_1_) ? false
						: !(p_142018_1_ instanceof AbstractHorse) || !((AbstractHorse) p_142018_1_).isTame();
	} else {
		return false;
	}
}

@Override
public boolean attackEntityAsMob(Entity entityIn) {
	super.attackEntityAsMob(entityIn);
	boolean flag = entityIn.attackEntityFrom(DamageSource.causeMobDamage(this),
			(float) ((int) this.getEntityAttribute(SharedMonsterAttributes.ATTACK_DAMAGE).getAttributeValue()));
	if (flag) {
		this.applyEnchantments(this, entityIn);
		// Cura 1.5 cada que ataca
		// this.heal(1.5F);
	}
	return flag;
}
}

 

Thanks in advance

Link to comment
Share on other sites

EXP only drops if mobs are killed by the player.

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.

Link to comment
Share on other sites

You'll have to examine the EntityWolf class to see how it does it.

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.

Link to comment
Share on other sites

I already did. Even EntityTamable (Which is the extra class that EntityWolf inherits from unlike EntityPolarBear) and they don't seem to have any code for setting experience orbs from mobs they kill. any idea folks?

Make yours extend EntityTameable and if it is not supposed to function that way you will need to subscribe to LivingDeathEvent and spawn the exp points yourself.

VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING

I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect.

Forge and vanilla BlockState generator.

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

 Share



  • Recently Browsing

    No registered users viewing this page.

  • Posts

    • As title says. Already had to get some work arounds to get java working, and I don't have the ability to upgrade to windows 10.
    • I am having an issue running a server with my mod. I know that I am reaching across sides somewhere in my Mod, but could not find where this error is occurring in my mod. The crash report that I have attached below mentioned that it involved the LocalPlayer. However, when I searched my mod for LocalPlayer, I only found one case in the event that I have attached below. Can you find where I errored?   Crash Report: ---- Minecraft Crash Report ---- // I bet Cylons wouldn't have this problem. Time: 1/17/22, 8:10 PM Description: Mod loading error has occurred java.lang.Exception: Mod Loading has failed at net.minecraftforge.logging.CrashReportExtender.dumpModLoadingCrashReport(CrashReportExtender.java:69) ~[forge-1.18-38.0.17_mapped_official_1.18-recomp.jar%2376%2382!:?] {re:classloading} at net.minecraftforge.server.loading.ServerModLoader.load(ServerModLoader.java:53) ~[forge-1.18-38.0.17_mapped_official_1.18-recomp.jar%2376%2382!:?] {re:classloading} at net.minecraft.server.Main.main(Main.java:104) ~[forge-1.18-38.0.17_mapped_official_1.18-recomp.jar%2377!:?] {re:classloading} at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?] {} at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[?:?] {} at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] {} at java.lang.reflect.Method.invoke(Method.java:568) ~[?:?] {} at net.minecraftforge.fml.loading.targets.ForgeServerUserdevLaunchHandler.lambda$launchService$0(ForgeServerUserdevLaunchHandler.java:16) ~[fmlloader-1.18-38.0.17.jar%230!:?] {} at cpw.mods.modlauncher.LaunchServiceHandlerDecorator.launch(LaunchServiceHandlerDecorator.java:37) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:53) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:71) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.Launcher.run(Launcher.java:106) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.Launcher.main(Launcher.java:77) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:26) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.modlauncher.BootstrapLaunchConsumer.accept(BootstrapLaunchConsumer.java:23) [modlauncher-9.0.24.jar%2310!:?] {} at cpw.mods.bootstraplauncher.BootstrapLauncher.main(BootstrapLauncher.java:90) [bootstraplauncher-0.1.17.jar:?] {} A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- Head -- Thread: main Stacktrace: at net.minecraftforge.fml.loading.RuntimeDistCleaner.processClassWithFlags(RuntimeDistCleaner.java:71) ~[fmlloader-1.18-38.0.17.jar%230!:1.0] {} -- MOD examplemod -- Details: Mod File: main Failure message: Example Mod (examplemod) has failed to load correctly java.lang.RuntimeException: Attempted to load class net/minecraft/client/player/LocalPlayer for invalid dist DEDICATED_SERVER Mod Version: 3.0 Mod Issue URL: NOT PROVIDED Exception message: java.lang.RuntimeException: Attempted to load class net/minecraft/client/player/LocalPlayer for invalid dist DEDICATED_SERVER Stacktrace: at net.minecraftforge.fml.loading.RuntimeDistCleaner.processClassWithFlags(RuntimeDistCleaner.java:71) ~[fmlloader-1.18-38.0.17.jar:1.0] {} at cpw.mods.modlauncher.LaunchPluginHandler.offerClassNodeToPlugins(LaunchPluginHandler.java:88) ~[modlauncher-9.0.7.jar:?] {} at cpw.mods.modlauncher.ClassTransformer.transform(ClassTransformer.java:120) ~[modlauncher-9.0.7.jar:?] {} at cpw.mods.modlauncher.TransformingClassLoader.maybeTransformClassBytes(TransformingClassLoader.java:50) ~[modlauncher-9.0.7.jar:?] {} at cpw.mods.cl.ModuleClassLoader.readerToClass(ModuleClassLoader.java:110) ~[securejarhandler-0.9.54.jar:?] {} at cpw.mods.cl.ModuleClassLoader.lambda$findClass$16(ModuleClassLoader.java:213) ~[securejarhandler-0.9.54.jar:?] {} at cpw.mods.cl.ModuleClassLoader.loadFromModule(ModuleClassLoader.java:223) ~[securejarhandler-0.9.54.jar:?] {} at cpw.mods.cl.ModuleClassLoader.findClass(ModuleClassLoader.java:213) ~[securejarhandler-0.9.54.jar:?] {} at cpw.mods.cl.ModuleClassLoader.loadClass(ModuleClassLoader.java:130) ~[securejarhandler-0.9.54.jar:?] {} at java.lang.ClassLoader.loadClass(ClassLoader.java:520) ~[?:?] {} at java.lang.Class.forName0(Native Method) ~[?:?] {} at java.lang.Class.forName(Class.java:467) ~[?:?] {} at net.minecraftforge.fml.javafmlmod.AutomaticEventSubscriber.lambda$inject$6(AutomaticEventSubscriber.java:75) ~[javafmllanguage-1.18-38.0.17.jar%2378!:?] {} at java.util.ArrayList.forEach(ArrayList.java:1511) ~[?:?] {} at net.minecraftforge.fml.javafmlmod.AutomaticEventSubscriber.inject(AutomaticEventSubscriber.java:62) ~[javafmllanguage-1.18-38.0.17.jar%2378!:?] {} at net.minecraftforge.fml.javafmlmod.FMLModContainer.constructMod(FMLModContainer.java:91) ~[javafmllanguage-1.18-38.0.17.jar%2378!:?] {} at net.minecraftforge.fml.ModContainer.lambda$buildTransitionHandler$4(ModContainer.java:120) ~[fmlcore-1.18-38.0.17.jar%2380!:?] {} at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) ~[?:?] {} at java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1796) ~[?:?] {} at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373) ~[?:?] {} at java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182) ~[?:?] {} at java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655) ~[?:?] {} at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622) ~[?:?] {} at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165) ~[?:?] {} -- System Details -- Details: Minecraft Version: 1.18 Minecraft Version ID: 1.18 Operating System: Windows 10 (amd64) version 10.0 Java Version: 17.0.1, Eclipse Adoptium Java VM Version: OpenJDK 64-Bit Server VM (mixed mode, sharing), Eclipse Adoptium Memory: 320780752 bytes (305 MiB) / 1127219200 bytes (1075 MiB) up to 2122317824 bytes (2024 MiB) CPUs: 4 Processor Vendor: GenuineIntel Processor Name: Intel(R) Core(TM) i3-7020U CPU @ 2.30GHz Identifier: Intel64 Family 6 Model 142 Stepping 9 Microarchitecture: Amber Lake Frequency (GHz): 2.30 Number of physical packages: 1 Number of physical CPUs: 2 Number of logical CPUs: 4 Graphics card #0 name: Intel(R) HD Graphics 620 Graphics card #0 vendor: Intel Corporation (0x8086) Graphics card #0 VRAM (MB): 1024.00 Graphics card #0 deviceId: 0x5921 Graphics card #0 versionInfo: DriverVersion=27.20.100.9664 Memory slot #0 capacity (MB): 8192.00 Memory slot #0 clockSpeed (GHz): 2.67 Memory slot #0 type: DDR4 Virtual memory max (MB): 16427.04 Virtual memory used (MB): 10800.33 Swap memory total (MB): 8334.11 Swap memory used (MB): 434.15 JVM Flags: 1 total; -XX:+ShowCodeDetailsInExceptionMessages ModLauncher: 9.0.24+9.0.24+main.7be9f01d ModLauncher launch target: forgeserveruserdev ModLauncher naming: mcp ModLauncher services: mixin PLUGINSERVICE eventbus PLUGINSERVICE object_holder_definalize PLUGINSERVICE runtime_enum_extender PLUGINSERVICE capability_token_subclass PLUGINSERVICE accesstransformer PLUGINSERVICE runtimedistcleaner PLUGINSERVICE mixin TRANSFORMATIONSERVICE fml TRANSFORMATIONSERVICE FML Language Providers: minecraft@1.0 javafml@null Mod List: forge-1.18-38.0.17_mapped_official_1.18-recomp.jar|Minecraft |minecraft |1.18 |COMMON_SET|Manifest: a1:d4:5e:04:4f:d3:d6:e0:7b:37:97:cf:77:b0:de:ad:4a:47:ce:8c:96:49:5f:0a:cf:8c:ae:b2:6d:4b:8a:3f main |Example Mod |examplemod |3.0 |ERROR |Manifest: NOSIGNATURE |Forge |forge |38.0.17 |COMMON_SET|Manifest: NOSIGNATURE Crash Report UUID: a2d945ef-ef76-4bb1-ac09-f2b263e52519 FML: 38.0 Forge: net.minecraftforge:38.0.17 Mod Event with LocalPlayer: @SubscribeEvent public static void renderGameOverlay(RenderGameOverlayEvent.Post event) { if(!(Thread.currentThread().getThreadGroup() == SidedThreadGroups.SERVER)) { Minecraft mc = Minecraft.getInstance(); LocalPlayer player = mc.player; if (mc.gameMode.canHurtPlayer() && event.getType() == RenderGameOverlayEvent.ElementType.ALL) { ModRender renderer = new ModRender(Minecraft.getInstance()); renderer.renderToolbars(Minecraft.getInstance(), player); } } }  
    • That's because redstone doesn't use tile entities. It's all handled by blockstates. There's no way to achieve what you want as far as I know.
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

By using this site, you agree to our Privacy Policy.