Jump to content

Recommended Posts

Posted (edited)

In 1.8.9, i am attempting to create a custom squid, but unfortunately something in my code doesn't allow my custom entity to apply its texture. i have tried a few things and nothing has worked if you need any additional information let me know

 

EntityFile:

public class EntityKraken extends EntitySquid
{
    private float randomMotionVecZ;
    private float randomMotionVecX;
    private float randomMotionVecY;
    public EntityKraken(World worldIn) {
        super(worldIn);
        this.setSize(0.95F, 0.95F);
        this.tasks.addTask(0, new EntityKraken.AIMoveRandom(this));
    }
    
    public void func_175568_b(float randomMotionVecXIn, float randomMotionVecYIn, float randomMotionVecZIn)
    {
        this.randomMotionVecX = randomMotionVecXIn;
        this.randomMotionVecY = randomMotionVecYIn;
        this.randomMotionVecZ = randomMotionVecZIn;
    }
    
    public boolean func_175567_n()
    {
        return this.randomMotionVecX != 0.0F || this.randomMotionVecY != 0.0F || this.randomMotionVecZ != 0.0F;
    }
    
    static class AIMoveRandom extends EntityAIBase
    {
        private EntityKraken squid;
        public AIMoveRandom(EntityKraken entityKraken)
        {
            this.squid = entityKraken;
        }
        /**
         * Returns whether the EntityAIBase should begin execution.
         */
        public boolean shouldExecute()
        {
            return true;
        }
        /**
         * Updates the task
         */
        
        public void updateTask()
        {
            int i = this.squid.getAge();
            if (i > 100)
            {
                this.squid.func_175568_b(0.0F, 0.0F, 0.0F);
            }
            else if (this.squid.getRNG().nextInt(50) == 0 || !this.squid.inWater || !this.squid.func_175567_n())
            {
                float f = this.squid.getRNG().nextFloat() * (float)Math.PI * 2.0F;
                float f1 = MathHelper.cos(f) * 0.2F;
                float f2 = -0.1F + this.squid.getRNG().nextFloat() * 2.0F;
                float f3 = MathHelper.sin(f) * 0.2F;
                this.squid.func_175568_b(f1, f2, f3);
            }
        }
    }
}

RenderFile:

public class RenderKraken extends RenderLiving<EntityKraken>{
    protected ResourceLocation SquidTextures = new ResourceLocation(Main.MODID,"textures/entity/EntityKraken.png");
    public RenderKraken(RenderManager renderManager,ModelBase modelBaseIn, float shadowSizeIn)
    {
        super(renderManager,modelBaseIn,shadowSizeIn);
    }
    @Override
    protected ResourceLocation getEntityTexture(EntityKraken entity)
    { 
        return SquidTextures;
    }
}

 

 

IRenderFactoryFile:

public class RenderFactory implements IRenderFactory<EntityKraken>{
    
    public static final RenderFactory INSTANCE = new RenderFactory();
    
    public RenderKraken createRenderFor(RenderManager manager) {
        return new RenderKraken(manager, new ModelSquid(), 1.0f);
    }
}

EntityRegistryFile:

public class EntityRegister {
    public static void mainRegistry(){
        register();
    }
    private static void register() {
        createEntity(EntityKraken.class, "Kraken", 0x2de5ec, 0x8e54c8, 1053);
        
    }
    private static void createEntity(Class EntityClass, String EntityName, int pcolor, int scolor, int id) {
        EntityRegistry.registerModEntity(EntityClass, EntityName, id, Main.modInstance, 64, 1, true);
        createEgg(EntityClass,pcolor,scolor);
        // TODO Auto-generated method stub
        
    }
    private static void createEgg(Class id, int pcolor, int scolor) {
        EntityRegistry.registerEgg(id, pcolor, scolor);
        
    }
}

 

ClientProxy:

public class ClientProxy extends Commonproxy{
    @Override
    public void preInit(FMLPreInitializationEvent e){
        super.preInit(e);
    }
    
    @Override
    public void init(FMLInitializationEvent e){
        super.init(e);
        ItemRender.registerItem();
        BlockRender.registerItem();
        EntityRegister.mainRegistry();

    }
    
    @Override
    public void postInit(FMLPostInitializationEvent e){
        super.postInit(e);
    }
    @Override
    public void registerEntityRenderers(){
        RenderingRegistry.registerEntityRenderingHandler(EntityKraken.class, RenderFactory.INSTANCE);
    }
}


 

 

Edited by crazyjackel11
make easier to read

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

    • You can check mod compatibility remove new mods and test them one by one.
    • @Tsuk1 Also, new note, you can use blockbench to make the custom item model for when it is not on the head.   EDIT: Funny story, I am making a mod similar to yours! Mine is called NorseMC.
    • @Nood_dev Could you send a screenshot of your weapon code? Here is the one I made (for a dagger): The specific UUID does not matter, just that it is the same every time, which is why UUID#randomUUID does not work public class DaggerItem extends TieredItem implements Vanishable { protected static final double REACH_MODIFIER = -1.5D; protected final Multimap<Attribute, AttributeModifier> defaultModifiers; protected final UUID BASE_ATTACK_REACH_UUID = UUID.fromString("6fe75b5c-9d1b-4e83-9eea-a1d5a94e8dd5") public DaggerItem(Tier pTier, int pAttackDamageModifier, float pAttackSpeedModifier, Properties pProperties) { super(pTier, pAttackDamageModifier, pAttackSpeedModifier, pProperties); this.attackDamage = (float) pAttackDamageModifier + pTier.getAttackDamageBonus(); ImmutableMultimap.Builder<Attribute, AttributeModifier> builder = ImmutableMultimap.builder(); builder.put(Attributes.ATTACK_DAMAGE, new AttributeModifier(BASE_ATTACK_DAMAGE_UUID, "Weapon modifier", this.attackDamage, AttributeModifier.Operation.ADDITION)); builder.put(Attributes.ATTACK_SPEED, new AttributeModifier(BASE_ATTACK_SPEED_UUID, "Weapon modifier", pAttackSpeedModifier, AttributeModifier.Operation.ADDITION)); // THE ONE YOU WANT: builder.put(ForgeMod.ENTITY_REACH.get(), new AttributeModifier(BASE_ATTACK_REACH_UUID, "Weapon modifier", REACH_MODIFIER, AttributeModifier.Operation.ADDITION)); this.defaultModifiers = builder.build(); } @Override public Multimap<Attribute, AttributeModifier> getDefaultAttributeModifiers(EquipmentSlot pEquipmentSlot) { return pEquipmentSlot == EquipmentSlot.MAINHAND ? this.defaultModifiers : super.getDefaultAttributeModifiers(pEquipmentSlot); } }
    • https://images.app.goo.gl/1PxFKdxByTgkxvSu6
    • That's what we'll try out. I could never figure out how to recreate the crash, so I'll just have to wait and see.
  • Topics

×
×
  • Create New...

Important Information

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