Jump to content

[SOLVED][1.12] Entity not being rendered


OttselKid

Recommended Posts

I've seen so many threads like this, but I still can't figure out what the problem is. Have a look at my code:

 

Entity file:

Spoiler

public class EntityRFProjectile extends EntityArrow {


    public EntityRFProjectile(World worldIn) {
        super(worldIn);
    }

    public EntityRFProjectile(World worldIn, double x, double y, double z) {
        super(worldIn, x, y, z);
    }

    public EntityRFProjectile(World worldIn, EntityLivingBase shooter) {
        super(worldIn, shooter);
    }

    @Override
    protected void onHit(RayTraceResult result) {
        if (!world.isRemote)
        {
            if (result.entityHit !=null){
                if(result.entityHit instanceof EntityLivingBase){
                    result.entityHit.attackEntityFrom(DamageSourceRFP.dealDamage(this,this),5f);
                }
            }
            if(result.typeOfHit != RayTraceResult.Type.MISS) {
                setDead();
            }
        }
    }

    @Override
    protected ItemStack getArrowStack() {
        return null;
    }

    protected static class DamageSourceRFP extends EntityDamageSource{

        public DamageSourceRFP(){
            this(null);
        }
        public DamageSourceRFP(Entity sourceIn){
            super("rf-projectile", sourceIn);
        }
        public static DamageSource dealDamage(EntityRFProjectile projectile,Entity source){
            return (new EntityDamageSourceIndirect("rf-projectile",projectile,projectile)).setProjectile();
        }
    }
}

 

Rendering Handler:

Spoiler

@SideOnly(Side.CLIENT)
public class RenderEntityRFProjectile extends Render<EntityRFProjectile> {
    private final ModelRFProjectile model = new ModelRFProjectile();


    private static ResourceLocation TEXTURE = new ResourceLocation(BaseDefence.modId,"textures/entity/rf-projectile.png");

    static {
    }

    public RenderEntityRFProjectile(RenderManager renderManager) {
        super(renderManager);
    }

    @Override
    public void doRender(EntityRFProjectile entity, double x, double y, double z, float entityYaw, float partialTicks) {
        model.render(entity,0f,0f,-1f,0f,0f,1f);
        super.doRender(entity, x, y, z, entityYaw, partialTicks);

    }

    @Nullable
    @Override
    protected ResourceLocation getEntityTexture(EntityRFProjectile entity) {
        return TEXTURE;
    }
}

 

Model File:

Spoiler

@SideOnly(Side.CLIENT)
public class ModelRFProjectile extends ModelBase {
    public ModelRenderer renderer;

    public ModelRFProjectile() {
        this.textureWidth = 64;
        this.textureHeight = 32;

        this.renderer = new ModelRenderer(this, 0, 0);
        this.renderer.setRotationPoint(0.0F, 0.0F, 0.0F);
        this.renderer.addBox(0.0F, 0.0F, 0.0F, 2, 2, 8);
    }

    @Override
    public void render(Entity entity, float limbSwing, float limbSwingAmount, float ageInTicks, float rotationYaw, float rotationPitch, float scale) {
        GlStateManager.enableBlend();
        GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
        GlStateManager.color(1.0F, 1.0F, 1.0F, 0.0F);
        this.renderer.render(scale);
        GlStateManager.disableBlend();
    }
}

 

And finally, server-side

EntityRegistry.registerModEntity(new ResourceLocation(BaseDefence.modId, "rf-projectile"), EntityRFProjectile.class, BaseDefence.modId + ".rf-projectile", id, BaseDefence.instance, 64, 3, true);

and client-side

RenderingRegistry.registerEntityRenderingHandler(EntityRFProjectile.class, RenderEntityRFProjectile::new);

registrations, all in preInit.

 

What am I missing?

 

---SOLUTION---

Thanks to V0idWa1k3r

 

Added translation code to the doRender method and bound the texture to the model in the Render Helper class

Spoiler

@Override
    public void doRender(EntityRFProjectile entity, double x, double y, double z, float entityYaw, float partialTicks) {
        GlStateManager.pushMatrix();
        GlStateManager.translate(x,y,z);
        this.bindEntityTexture(entity);
        model.render(entity,partialTicks,0f,-1f,0f,0f,0.05f);
        GlStateManager.popMatrix();
        super.doRender(entity,x, y, z, entityYaw, partialTicks);
    }

 

Removed unnecessary rendering code from the render method in the model class

Spoiler

@Override
    public void render(Entity entity, float limbSwing, float limbSwingAmount, float ageInTicks, float rotationYaw, float rotationPitch, float scale) {
        this.renderer.render(scale);
    }

 

 

 

Edited by OttselKid
Added solution
Link to comment
Share on other sites

4 minutes ago, OttselKid said:

model.render(entity,0f,0f,-1f,0f,0f,1f);

You are rendering your model at 0,0,0 view-space wise. You need to translate the matrix accordingly by the x/y/z passed in the doRender method.

You also probably want to bind your texture before rendering the model.

Edited by V0idWa1k3r
  • Like 1
Link to comment
Share on other sites

6 hours ago, V0idWa1k3r said:

You are rendering your model at 0,0,0 view-space wise. You need to translate the matrix accordingly by the x/y/z passed in the doRender method.

You also probably want to bind your texture before rendering the model.

Thank you for pointing this out. Did both things and works great! When I have time, I'll add the solution to the main post so others can see it.

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

    • okay.. ';D i did my good old technique of troubleshooting modpack (disabling ALL the mods and gradually in parts enabbling them and lauching game, enabling more mods, launching e.t.c) and managed to narrow it down to one mod.... it was "better smithing table" causing all the errors and making several mods to spit errors.. Same way by FIRSTLY turning on "better smithing tables" and seeing which mods it clashed with was: "Doggy Tallents Next" "bartering station" "Curios API" And further i wasn't able to check what mods conflicted b'cuz it was like: it was working with X mods, enabled 10 more mods, crashed. procedurally disabled all of them and still was crashing, disabled some more mods, worked. enabled back mods with which it was crashing and now it wasn't  i can't understand why and what mods are bad but i'm happy i somehow got the main error causer which again was "better smithing table". Without that mod everything works just fine. SOLVED (?)
    • So I'm creating yet another minecraft modpack and stumbled upon error I've never encoutered.. I tried to troubleshoot it myself and it always worked but this time I didn't manage.. Here is minecraft crash report: https://pastebin.com/EVqzdDKg I can't find how or from where to post debug.log  I'm sorry, can someone help me? (as a disclaimer - i've tried already reinstalling minecraft and java)
    • It works without mods, I've ran it through the launcher by itself and runs perfectly fine, when I open it through Forge I can get through to the launcher but when I go to open the world it loads then gives me the error code 1. Is there anymore info that could help diagnose it?
    • Also had the issue. GLAD TO TELL YOU I HAVE THE FIX! Create: Applied Kinetic literally says "Replace all inscriber recipes with Create's sequenced assembly recipe". When I turned off this mod it worked fine. I also didn't use that mod of the pack i played so it didn't matter for me.
    • Right now im trying to make an own mod for minecraft for the version 1.16.5 with forge but whatever i do it still doesnt fix the error this is my build.gradle : buildscript { repositories { maven { url = "https://maven.minecraftforge.net" } mavenCentral() } dependencies { classpath 'net.minecraftforge.gradle:ForgeGradle:5.1.+' } } apply plugin: 'net.minecraftforge.gradle' apply plugin: 'java' group = 'com.example' // Modify to your package name version = '1.0' archivesBaseName = 'flippermod' java { toolchain { languageVersion = JavaLanguageVersion.of(8) } } minecraft { version = "1.16.5-36.2.42" // Ensure this matches your Forge version mappings channel: 'official', version: '1.16.5' runs { client { workingDirectory project.file('run') property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP' property 'forge.logging.console.level', 'debug' mods { flipper_mod { sourceSets.main.output } } } } } repositories { maven { url = "https://maven.minecraftforge.net/" } mavenCentral() } dependencies { minecraft "net.minecraftforge:forge:1.16.5-36.2.42" } and this one is my settings.gradle:  pluginManagement { repositories { gradlePluginPortal() maven { name = 'MinecraftForge' url = 'https://maven.minecraftforge.net/' } } } plugins { id 'org.gradle.toolchains.foojay-resolver-convention' version '0.7.0' } rootProject.name = 'flippermod' this one is the mods.tml    modLoader="javafml" loaderVersion="[36,)" modId="flippermod" version="1.0.0" displayName="Flippermod" and the last one is the gradle-wrapper.properties distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-bin.zip dc :"code_slivki"
  • Topics

×
×
  • Create New...

Important Information

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