Jump to content

Recommended Posts

Posted

Hello. I know that this problem is quite usual in this forum, but I still can't understand what am I doing wrong. I have encountered the problem that entity is not rendering. I have registered an entity, it's renderer and both are working (I have added logger.info to their constructor).

 

My entity class is blank: constructor, and, actually, that's all.

 

I have figured out that constructor of the entity is called on the server side only. Am I right? How to sync the entity to the client then?

 

Sorry for my English.

Posted

You need to provide some of your code so we can help you. Ideally you would provide a github of your mod but at the very least the renderer class, the method where the renderer is registered and the method where the entity is spawned would suffice with us likely asking for more relevant information later. 

Judging by the fact that the entity is invisible likely the problem lies in your renderer, or, alternatively the entity isn't spawned and thus simply doesn't exist in the world but without any code I can't say much more.

Posted
Spoiler

public class EntityRegister {
    public static void server() {
        EntityEntry warden = new EntityEntry(EntityLibraryWarden.class, "LibraryWarden");
        warden.setRegistryName("EntityLibraryWarden");
        ForgeRegistries.ENTITIES.register(warden);
    }
    public static void client() {
        RenderingRegistry.registerEntityRenderingHandler(EntityLibraryWarden.class, new LibraryWardenFactory());
    }
}

 


public class EntityLibraryWarden extends EntityLiving {
    public EntityLibraryWarden(World worldIn) {
        super(worldIn);
        Main.logger.info("SUMMONING! " + worldIn.isRemote); // worldIn.isRemote == false
    }
}

public class LibraryWardenRender extends Render<EntityLibraryWarden> {

    private LibraryWardenModel model = new LibraryWardenModel();

    public LibraryWardenRender(RenderManager renderManager) {
        super(renderManager);
        Main.logger.info("New render"); // called
    }

    @Override
    public void doRender(EntityLibraryWarden entity, double x, double y, double z, float entityYaw, float partialTicks) {
        model.render(entity, 0F, 0F, 0F, 0F, 0F, 1F);
        Main.logger.info("Render"); // NOT called
    }


    @Nullable
    @Override
    protected ResourceLocation getEntityTexture(EntityLibraryWarden entity) {
        Main.logger.info("GetTexture!");
        return null;
    }
}

public class LibraryWardenModel extends ModelBase {
	private final ModelRenderer body;
	private final ModelRenderer head;

	public LibraryWardenModel() {
		textureWidth = 16;
		textureHeight = 16;

		body = new ModelRenderer(this);
		body.setRotationPoint(0.0F, 24.0F, 0.0F);
		body.cubeList.add(new ModelBox(body, 0, 0, -8.0F, -10.0F, -8.0F, 16, 10, 16, 0.0F, false));

		head = new ModelRenderer(this);
		head.setRotationPoint(0.0F, 24.0F, 0.0F);
		head.cubeList.add(new ModelBox(head, 0, 0, -7.0F, -17.0F, -7.0F, 14, 7, 14, 0.0F, false));
	}

	@Override
	public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5) {
		body.render(f5);
		head.render(f5);
	}
	public void setRotationAngle(ModelRenderer modelRenderer, float x, float y, float z) {
		modelRenderer.rotateAngleX = x;
		modelRenderer.rotateAngleY = y;
		modelRenderer.rotateAngleZ = z;
	}
}

I am spawning entity through "/summon".

Posted
7 minutes ago, TestingSubject002 said:

EntityEntry warden = new EntityEntry(EntityLibraryWarden.class, "LibraryWarden"); warden.setRegistryName("EntityLibraryWarden"); ForgeRegistries.ENTITIES.register(warden);

First of all NEVER EVER register things like this. If you have to access the registry directly then you are doing something VERY wrong. Use the appropriate RegistryEvent.Register<T> event and use the registry provided to you in that event.

Second of all this is not enough information for the EntityEntry. You at the very least also need to provide the tracker data and the registry name/ID.

Thirdly don't construct EntityEntries directly. Use EntityEntryBuilder.

 

Your entity doesn't exist on the client because you didn't register it correctly.

  • Thanks 1
Posted (edited)

Well, I am stuck again. How to register entities using event?

@SubscribeEvent
public static void registerEntities(RegistryEvent<EntityEntry> event) {
    // ???
}

Sorry for the waste of your time.

 

Oh sorry. I have understood.

Edited by TestingSubject002

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

    • The game crashed whilst unexpected error Error: net.minecraftforge.fml.ModLoadingException: Advanced Mining Dimension (mining_dimension) encountered an error during the done event phase
    • Here is the end of the log. it was way too big to put in pastebin, but I started from when I was online and everything was fine. Error should be in here: https://pastebin.com/Sdhdq593
    • Update: I stand corrected as I was able to dig up a relevant log from my earlier testing which highlights the overall issue but does not explain how to solve it. See, Diagnostic Logs for pack.mcmeta not found: https://pastebin.com/LXS8Rtna
    • Which mod was this? What are all the mods that were in use? It will help if enough information to replicate the problem is available.
    • I have been attempting to create a supplementary resource pack with Patchouli in order to add back the guidebook for Better End but unfortunately in every prototype I have made pack.mcmeta and my resource pack are not recognized. I have tested both zipped and unzipped and either way curseforge does not recognize my resource pack as existing. For testing I stripped my pack down to just the pack.mcmeta file and two empty folders labelled data and assets and I know the data folder is not the problem as firstly my first attempts just had an assets folder following Patchouli instructions and data came later in my flailing attempts to make anything in my pack work. The mcmeta file is not recognized whether or not I use this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } "language": { "en_US": { "name": "English", "region": "United States" } } } ,or this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } } I have made sure to only use lowercase and the pack folder is named better-end-guide. Is this some magic nonsense from me doing this manually instead of using an IDE or similar tool? Could it be because my files are by default in UTF-8 even though ANSI gives the same results? Is there a specific community secret tool I am supposed to use for zipping or specific settings? I am pulling my hair in distress. Unfortunately as there are no errors involved I lack logs to offer, if that disqualifies this thread please do not be harsh and instead if you can then please direct me to a forum with different rules and sufficiently respectful but knowledgeable as to be of assistance. Most of my experience with the programming community has been poor and so naturally I find myself wary.
  • Topics

  • Who's Online (See full list)

    • There are no registered users currently online
×
×
  • Create New...

Important Information

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