Передвижение моба

Версия Minecraft
1.7.10

Endless

Любитель OpenGL
270
11
82
Хотел сделать так чтоб моб мог двигаться только когда на него не смотрят, пошел в гитхаб искать сурцы похожих енитити с таким параметром (нашел мод в котором моб передвигался в правильный для меня момент) начал искать, то что мне надо (естсена я лох и ничего не нашел,либо слепой, либо дебил) щас у меня два пути, искать методом проб и ошибок либо чтоб (дебилу) указали часть кода
Код:
package com.temportalist.weepingangels.common.entity

import java.util

import com.temportalist.origin.api.common.lib.V3O
import com.temportalist.origin.api.common.utility.{Teleport, Stacks, WorldHelper}
import com.temportalist.origin.internal.common.extended.ExtendedEntityHandler
import com.temportalist.weepingangels.common.entity.ai.EntityAIAngelAttackTarget
import com.temportalist.weepingangels.common.extended.AngelPlayer
import com.temportalist.weepingangels.common.init.WAItems
import com.temportalist.weepingangels.common.lib.AngelUtility
import com.temportalist.weepingangels.common.{WAOptions, WeepingAngels}
import cpw.mods.fml.common.eventhandler.SubscribeEvent
import cpw.mods.fml.relauncher.{Side, SideOnly}
import net.minecraft.block.Block
import net.minecraft.entity._
import net.minecraft.entity.ai._
import net.minecraft.entity.passive.{EntityPig, EntityVillager}
import net.minecraft.entity.player.{EntityPlayer, EntityPlayerMP}
import net.minecraft.init.Items
import net.minecraft.item.ItemStack
import net.minecraft.nbt.{NBTTagCompound, NBTTagList}
import net.minecraft.util.{AxisAlignedBB, DamageSource, EntityDamageSource}
import net.minecraft.world.{EnumDifficulty, World}
import net.minecraftforge.event.world.BlockEvent

import scala.collection.mutable

/**
 *
 *
 * @author TheTemportalist 1/27/15
 */
class EntityAngel(world: World) extends EntityAgeable(world) {

    //val lightSourceKillDelay_Max: Int = 20 * 10
    var stolenInventory: Array[ItemStack] = null
    var hasProcreated: Boolean = false

    this.getNavigator.setBreakDoors(true)
    this.tasks.addTask(0, new EntityAIAttackOnCollide(this, classOf[EntityPlayer], 1.0D, true))
    this.tasks.addTask(1, new EntityAIWatchClosest(this, classOf[EntityPlayer], 16.0F))
    this.tasks.addTask(2, new EntityAIWatchClosest(this, classOf[EntityVillager], 8.0F))
    this.tasks.addTask(3, new EntityAILookIdle(this))
    this.targetTasks.addTask(1, new EntityAIHurtByTarget(this, true))
    this.targetTasks.addTask(2, new EntityAIAngelAttackTarget(this))

    this.experienceValue = 50
    this.isImmuneToFire = true
    this.setSize(0.6F, 2.0F)
    this.stepHeight = 2.0F
    this.setGrowingAge((WAOptions.decrepitationAge_max * 1.25).toInt)

    override def isAIEnabled: Boolean = true

    override def createChild(ageable: EntityAgeable): EntityAgeable = {
        new EntityAngel(this.worldObj)
    }

    override def entityInit(): Unit = {
        super.entityInit()

        // angry state
        this.dataWatcher.addObject(16, 0.asInstanceOf[Byte])
        // arm state
        this.dataWatcher.addObject(17, 0.asInstanceOf[Byte])
        // decrepetation texture id
        this.dataWatcher.addObject(18, -1) // calm
        this.dataWatcher.addObject(19, -1) // angry
        // voice throw delay
        this.dataWatcher.addObject(20, WAOptions.throwVoiceDelay_Max.asInstanceOf[Byte])

    }

    override def writeEntityToNBT(tagCom: NBTTagCompound): Unit = {
        super.writeEntityToNBT(tagCom)

        tagCom.setBoolean("hasInventory", this.hasStolenInventory)
        if (this.hasStolenInventory) {
            val tagList: NBTTagList = new NBTTagList()

            for (slotID <- 0 until this.stolenInventory.length) {
                if (this.stolenInventory(slotID) != null) {
                    val stackTagCom: NBTTagCompound = new NBTTagCompound()
                    stackTagCom.setInteger("slot", slotID.asInstanceOf[Byte])
                    this.stolenInventory(slotID).writeToNBT(stackTagCom)
                    tagList.appendTag(stackTagCom)
                }
            }

            tagCom.setTag("inventory", tagList)
            tagCom.setInteger("inventorySize", this.stolenInventory.length)
        }

        tagCom.setBoolean("hasProcreated", this.hasProcreated)

    }

    override def readEntityFromNBT(tagCom: NBTTagCompound): Unit = {
        super.readEntityFromNBT(tagCom)

        if (tagCom.getBoolean("hasInventory")) {
            this.stolenInventory = new Array[ItemStack](tagCom.getInteger("inventorySize"))

            val tagList: NBTTagList = tagCom.getTagList("inventory", 10)
            for (tagIndex <- 0 until tagList.tagCount()) {
                val stackTagCom: NBTTagCompound = tagList.getCompoundTagAt(tagIndex)
                val slotID: Int = stackTagCom.getInteger("slot") & 255
                if (slotID >= 0 && slotID < this.stolenInventory.length) {
                    this.stolenInventory(slotID) = ItemStack.loadItemStackFromNBT(stackTagCom)
                }
            }

        }
        else {
            this.stolenInventory = null
        }

        this.hasProcreated = tagCom.getBoolean("hasProcreated")

    }

    def setAngryState(state: Byte): Unit = {
        this.dataWatcher.updateObject(16, state)
    }

    def getAngryState: Byte = {
        this.dataWatcher.getWatchableObjectByte(16)
    }

    def setArmState(state: Byte): Unit = {
        this.dataWatcher.updateObject(17, state)
    }

    def getArmState: Byte = {
        this.dataWatcher.getWatchableObjectByte(17)
    }

    def setLightSourceKillDelay(delay: Int): Unit = {
        this.dataWatcher.updateObject(18, delay)
    }

    def getLightSourceKillDelay: Int = {
        this.dataWatcher.getWatchableObjectInt(18)
    }

    def getTextureID(isAngry: Boolean): Int = {
        this.dataWatcher.getWatchableObjectInt(if (isAngry) 19 else 18)
    }

    def setTextureID(isAngry: Boolean, id: Int): Unit = {
        this.dataWatcher.updateObject(if (isAngry) 19 else 18, id)
    }

    def getVoiceThrowDelay(): Int = {
        this.dataWatcher.getWatchableObjectByte(20).asInstanceOf[Int]
    }

    def setVoiceThrowDelay(delay: Int): Unit = {
        this.dataWatcher.updateObject(20, delay.asInstanceOf[Byte])
    }

    def decrementVoiceThrowDelay(): Unit = {
        this.setVoiceThrowDelay(this.getVoiceThrowDelay() - 1)
    }

    def getNewThrowVoiceDelay(): Int = {
        this.rand.nextInt(WAOptions.throwVoiceDelay_Max - WAOptions.throwVoiceDelay_Min) +
                WAOptions.throwVoiceDelay_Min
    }

    def tryThrowVoice(target: EntityPlayer): Unit = {
        if (this.worldObj.isRemote) {
            val soundX: Double = (2 * target.posX) - this.posX
            val soundY: Double = this.posY //(2 * target.posY) - this.posY
            val soundZ: Double = (2 * target.posZ) - this.posZ
            this.worldObj.playSoundEffect(
                soundX, soundY, soundZ,
                this.getRandomMobSound(), this.getSoundVolume, this.getSoundPitch
            )
        }
    }

    def getRandomMobSound(): String = {
        WAOptions.mobSounds(this.rand.nextInt(WAOptions.mobSounds.length))
    }

    override def applyEntityAttributes(): Unit = {
        super.applyEntityAttributes()

        this.getEntityAttribute(SharedMonsterAttributes.followRange).setBaseValue(64.0D)
        this.setSpeed(WAOptions.angelMaxSpeed)
        this.getAttributeMap.registerAttribute(SharedMonsterAttributes.attackDamage)
        this.getEntityAttribute(SharedMonsterAttributes.attackDamage).setBaseValue(10.0D)

    }

    def getSpeed(): Double = {
        this.getEntityAttribute(SharedMonsterAttributes.movementSpeed).getBaseValue
    }

    def setSpeed(speed: Double): Unit = {
        this.getEntityAttribute(SharedMonsterAttributes.movementSpeed).setBaseValue(speed)
    }

    override def getLivingSound: String = {
        WeepingAngels.MODID + ":stone"
    }

    override def getHurtSound: String = {
        WeepingAngels.MODID + ":light"
    }

    override def getDeathSound: String = {
        WeepingAngels.MODID + ":crumble"
    }

    def hasStolenInventory: Boolean = {
        this.stolenInventory != null
    }

    def setStolenInventory(inventory: Array[ItemStack]): Unit = {
        this.stolenInventory = inventory
    }

    def dropStolenInventory(): Unit = {
        if (this.hasStolenInventory) {
            for (i <- 0 until this.stolenInventory.length) {
                Stacks.spawnItemStack(
                    this.worldObj, new V3O(this), this.stolenInventory(i), this.rand, 10
                )
            }

            this.stolenInventory = null

        }

    }

    def changeAngelMovement(): Unit = {
        if (this.getAttackTarget != null) {
            val difX: Double = Math.abs(this.posX - this.getAttackTarget.posX)
            val difY: Double = Math.abs(this.posY - this.getAttackTarget.posY)
            val difZ: Double = Math.abs(this.posZ - this.getAttackTarget.posZ)

            if (difX <= 5.0D && difY <= 5.0D && difZ <= 5.0D) {
                this.setAngryState(1)
                this.setArmState(2)
            }
            else {
                this.setAngryState(0)
                if (difX <= 15.0D && difY <= 15.0D && difZ <= 15.0D) {
                    this.setArmState(1)
                }
                else {
                    this.setArmState(0)
                }
            }
        }

    }

    override def getBoundingBox: AxisAlignedBB = this.boundingBox

    def canBeSeen(): Boolean = {
        AngelUtility.canBeSeen_Multiplayer(this.worldObj, this, this.getBoundingBox, 64D)
    }

    override def onUpdate(): Unit = {
        // Kill if neccessary
        if (!this.worldObj.isRemote && this.worldObj.difficultySetting == EnumDifficulty.PEACEFUL) {
            this.setDead()
        }

        // Check movement variable which shouldnt change
        //if (this.moveStrafing != 0.0F)
        //    this.moveStrafing = 0.0F
        //if (this.moveForward != 0.0F)
        //    this.moveForward = 0.0F
        if (this.isJumping)
            this.isJumping = false

        val canBeSeen: Boolean = this.canBeSeen()

        if (canBeSeen) {
            // Angel is quantum locked

            this.setSpeed(0.0D)
            this.rotationYawHead = this.prevRotationYawHead

            if (WAOptions.angelThrowsVoice) {
                if (this.getVoiceThrowDelay() <= 0) {
                    val lookingPlayer: EntityPlayer = AngelUtility
                            .getEntityLooking(this.worldObj, this, this.getBoundingBox, 64D,
                                classOf[EntityPlayer]).asInstanceOf[EntityPlayer]
                    if (lookingPlayer != null) {
                        this.tryThrowVoice(lookingPlayer)
                    }
                    this.setVoiceThrowDelay(this.getNewThrowVoiceDelay())
                }
                else {
                    this.decrementVoiceThrowDelay()
                }
            }

        }
        else {
            // Angel can move
            var speed: Double = WAOptions.angelMaxSpeed
            if (this.isChild) speed *= 2
            if (this.getSpeed() != speed) {
                this.setSpeed(speed)
            }

        }

        /*
        val canRemoveLight: Boolean = WAOptions.angelsLookForTorches && canBeSeen &&
                (if (this.isInSkylight) !this.worldObj.isDaytime else true)
        if (canRemoveLight) {
            val coordsOfSource: Vec3 = this.findNearestTorch()
            if (coordsOfSource != null) {
                val ticksUntilSourceBreak: Int = this.getLightSourceKillDelay
                if (ticksUntilSourceBreak <= 0) {
                    this.breakLightSource(coordsOfSource)
                    //this.setLightSourceKillDelay(this.lightSourceKillDelay_Max)
                }
                else {
                    this.setLightSourceKillDelay(ticksUntilSourceBreak - 1)
                }
            }
        }
        */

        /*
        if (!canBeSeen) {
            this.changeAngelMovement()
            if (!this.hasProcreated && this.getAITarget == null) {
                if (this.getGrowingAge >= 24000 * 4 && this.rand.nextInt(50) == 0) {
                    this.procreate(null)
                    this.hasProcreated = true
                }
            }
        }
        */

        super.onUpdate()

    }

    override def findPlayerToAttack(): Entity = {
        this.worldObj.getClosestVulnerablePlayerToEntity(this,
            this.getEntityAttribute(SharedMonsterAttributes.followRange).getAttributeValue)
    }

    def procreate(otherAngel: EntityAngel): Unit = {
        val ageable: EntityAgeable = this.createChild(otherAngel)
        if (ageable != null) {
            //this.setGrowingAge(6000)
            this.setAttackTarget(null)
            if (otherAngel != null) {
                //otherAngel.setGrowingAge(6000)
                otherAngel.setAttackTarget(null)
            }
            ageable.setGrowingAge(-24000 * 4)
            //ageable.setSize(0.3F, 1.0F)

            ageable.setLocationAndAngles(
                this.posX, this.posY, this.posZ, this.rotationYaw, this.rotationPitch
            )

            this.worldObj.spawnEntityInWorld(ageable)
        }

    }

    override def onLivingUpdate(): Unit = {
        this.updateArmSwingProgress()

        val brightness: Float = this.getBrightness(1.0F)
        if (brightness > 0.5F) {
            this.entityAge += 2
        }

        super.onLivingUpdate()

        if (this.worldObj.isRemote) {
            if (this.getTextureID(isAngry = false) < 0) this.onAgeChanged(isAngry = false)
            if (this.getTextureID(isAngry = true) < 0) this.onAgeChanged(isAngry = true)
        }
    }

    @SideOnly(Side.CLIENT)
    def onAgeChanged(isAngry: Boolean) {
        val id: Int = AngelUtility.getTextureIDFromCorruption(isAngry, this.getCorruption(), this.hashCode())
        if (id >= 0) this.setTextureID(isAngry, id)
    }

    def getCorruption(): Int = AngelUtility.getDecrepitation(this.getGrowingAge)

    override def attackEntityAsMob(entity: Entity): Boolean = {

        if (entity != null && !this.canBeSeen()) {
            var didAlternateAction: Boolean = false
            var entityIsConvertting: Boolean = false
            entity match {
                case player: EntityPlayerMP =>
                    if (WAOptions.angelsCanConvertPlayers &&
                            this.rand.nextInt(100) < WAOptions.conversionChance) {
                        val angelPlayer: AngelPlayer = ExtendedEntityHandler.getExtended(
                            player, classOf[AngelPlayer])

                        if (!angelPlayer.converting()) {
                            angelPlayer.startConversion()
                            angelPlayer.setAngelHealth(0.0F)
                            angelPlayer.clearRegenTicks()
                            this.rejuvinate(1, 0.25D)
                        }

                        didAlternateAction = true
                        entityIsConvertting = true

                    }
                    if (!didAlternateAction && WAOptions.angelsCanTeleportPlayers &&
                            this.rand.nextInt(100) < WAOptions.teleportationChance) {
                        Teleport.toPointRandom(player,
                            WAOptions.teleportationMinRange, WAOptions.teleportationMaxRange)
                        this.rejuvinate(1, 1.0D)
                        this.worldObj.playSoundAtEntity(player,
                            WeepingAngels.MODID + ":teleport_activate", 1.0F, 1.0F)
                        didAlternateAction = true

                    }
                case pig: EntityPig =>
                    super.attackEntityAsMob(pig)
                    pig.attackEntityFrom(new EntityDamageSource("angel", this), 1F)
                case _ =>
            }

            if (!didAlternateAction && !entityIsConvertting) {
                val damage: Float = this.getEntityAttribute(SharedMonsterAttributes.attackDamage)
                        .getAttributeValue.asInstanceOf[Float]
                if (WAOptions.angelOverridesPlayerArmor) {
                    entity match {
                        case living: EntityLivingBase =>
                            living.setHealth(living.getHealth - damage)
                            return true
                        case _ =>
                    }
                }
                return entity.attackEntityFrom(DamageSource.causeMobDamage(this), damage)
            }

            return true
        }

        false
    }

    def rejuvinate(times: Int, factor: Double): Unit = {
        val crement: Int = (2000 * factor).asInstanceOf[Int]
        for (i <- 0 until times) {
            var nextAge: Int = 0
            if (this.isChild) {
                nextAge = this.getGrowingAge + crement
                if (nextAge > 0) {
                    nextAge = 0
                }
            }
            else {
                nextAge = this.getGrowingAge - crement
                if (nextAge < 0) {
                    nextAge = 0
                }
            }
            this.setGrowingAge(nextAge)
        }
    }

    override def onDeath(source: DamageSource): Unit = {
        super.onDeath(source)
        if (this.hasStolenInventory) {
            this.dropStolenInventory()
        }
    }

    override def attackEntityFrom(source: DamageSource, damage: Float): Boolean = {
        if (AngelUtility.canAttackEntityFrom(this.worldObj, source, damage)) {
            super.attackEntityFrom(source, damage)
            true
        }
        else {
            false
        }
    }

    override def knockBack(attackingEntity: Entity, amount: Float, x: Double, z: Double): Unit = {
    }

    override def dropFewItems(hitRecentlyByPlayer: Boolean, looting: Int): Unit = {
        if (this.rand.nextInt(100) < 20) {
            val angelTearStack: ItemStack = new ItemStack(WAItems.angelTear, 1, 0)
            val tagCom: NBTTagCompound = new NBTTagCompound
            val tearType: String = if (this.rand.nextBoolean()) "Teleportation"
            else "Time Manipulation"
            if (tearType.equals("Teleportation")) {
                tagCom.setInteger("uses", 5)
            }
            else if (tearType.equals("Time Manipulation")) {
                tagCom.setInteger("uses", 1)
            }
            tagCom.setString("type", tearType)
            angelTearStack.setTagCompound(tagCom)
            this.entityDropItem(angelTearStack, 0.0F)
        }
    }

    override def getCanSpawnHere: Boolean = {
        if (this.worldObj.difficultySetting != EnumDifficulty.PEACEFUL) {
            val dimensionID = this.worldObj.provider.dimensionId
            if (WAOptions.spawnHeightRanges.contains(dimensionID)) {
                val range = WAOptions.spawnHeightRanges(dimensionID)
                if (range._1 <= this.posY && this.posY <= range._2) {
                    return this.isValidLightLevel && super.getCanSpawnHere
                }
            }
        }
        false
    }

    def isValidLightLevel: Boolean = {
        WorldHelper.isValidLightLevelForMobSpawn(this, WAOptions.maxLightLevelForSpawn)
    }

    override def interact(player: EntityPlayer): Boolean = {
        val itemstack: ItemStack = player.inventory.getCurrentItem
        ///*
        if (itemstack == null) {
            this.setGrowingAge(this.getGrowingAge / 2)
            this.onAgeChanged(false)
            this.onAgeChanged(true)
        }
        //*/
        if (itemstack != null && itemstack.getItem == Items.spawn_egg) {
            if (!this.worldObj.isRemote) {
                val oclass: Class[_] = EntityList.getClassFromID(itemstack.getItemDamage)
                if (oclass != null && oclass.isAssignableFrom(this.getClass)) {
                    val entityageable: EntityAgeable = this.createChild(this)
                    if (entityageable != null) {
                        entityageable.setGrowingAge(-24000 * 4)
                        entityageable
                                .setLocationAndAngles(this.posX, this.posY, this.posZ, 0.0F, 0.0F)
                        this.worldObj.spawnEntityInWorld(entityageable)
                        if (itemstack.hasDisplayName) {
                            entityageable.setCustomNameTag(itemstack.getDisplayName)
                        }
                        if (!player.capabilities.isCreativeMode) {
                            itemstack.stackSize -= 1
                            if (itemstack.stackSize <= 0) {
                                player.inventory
                                        .setInventorySlotContents(player.inventory.currentItem,
                                            null.asInstanceOf[ItemStack])
                            }
                        }
                    }
                }
            }
            true
        }
        else {
            false
        }
    }

    def setYoungestAdult(): Unit = {
        this.setGrowingAge(0)
    }

    override def setGrowingAge(tickAge: Int): Unit = {
        val wasChild: Boolean = this.isChild || tickAge <= -96000

        super.setGrowingAge(tickAge)

        if (this.isChild) {
            this.setSize(0.3F, 1.0F)
        }

        if (!wasChild && this.getGrowingAge <= 0) {
            this.setDead()
        }

        if (wasChild && this.getGrowingAge >= 0) {
            this.setYoungestAdult()
        }

        if (WorldHelper.isClient) {
            this.onAgeChanged(isAngry = false)
            this.onAgeChanged(isAngry = true)
        }

    }

}

object EntityAngel {

    val lights: mutable.Map[V3O, util.List[V3O]] = mutable.Map[V3O, util.List[V3O]]()

    // todo talk to MCForge people in irc & find out why there is not event in Chunk.setBlockState
    // todo, if just not implemented, then implement and move this
    @SubscribeEvent
    def blockPlaced(event: BlockEvent.PlaceEvent): Unit = {
        val block: Block = event.placedBlock
        val vec: V3O = new V3O(event.blockSnapshot)

        if (block.getLightValue > 0f) {
            val chunkPos: V3O = new V3O(vec.getChunk(event.world))
            if (!this.lights.contains(chunkPos))
                this.lights(chunkPos) = new util.ArrayList[V3O]()
            this.lights(chunkPos).add(vec)
        }
    }

}
если, что вот сами сурсы TheTemportalist/WeepingAngels
 
1,007
36
206
Код:
 def canBeSeen(): Boolean = {
        AngelUtility.canBeSeen_Multiplayer(this.worldObj, this, this.getBoundingBox, 64D)
    }

        val canBeSeen: Boolean = this.canBeSeen()

        if (canBeSeen) {
            // Angel is quantum locked

            this.setSpeed(0.0D)
            this.rotationYawHead = this.prevRotationYawHead

            if (WAOptions.angelThrowsVoice) {
                if (this.getVoiceThrowDelay() <= 0) {
                    val lookingPlayer: EntityPlayer = AngelUtility
                            .getEntityLooking(this.worldObj, this, this.getBoundingBox, 64D,
                                classOf[EntityPlayer]).asInstanceOf[EntityPlayer]
                    if (lookingPlayer != null) {
                        this.tryThrowVoice(lookingPlayer)
                    }
                    this.setVoiceThrowDelay(this.getNewThrowVoiceDelay())
                }
                else {
                    this.decrementVoiceThrowDelay()
                }
            }

        }
        else {
            // Angel can move
            var speed: Double = WAOptions.angelMaxSpeed
            if (this.isChild) speed *= 2
            if (this.getSpeed() != speed) {
                this.setSpeed(speed)
            }

        }
 
1,038
57
229
MovingObjectPosition mop = Minecraft.getMinecraft().objectMouseOver()
 
Сверху