Jump to content

Recommended Posts

Posted

Hello!

I already made a thread about this issue, but then I thought that I managed to fix the issue, so I posted about that in forementioned thread. Sadly, it still errors, and now I have no clue why that happens, so I have to make another thread. The issue I have is that I created a custom EntityFX, and it crashes randomly when it's rendering. Here's the code for the entity:

public class EntityRainbowFX extends EntityFX {
private static final ResourceLocation textureFile = new ResourceLocation(Reference.MODID, "textures/particle/rainbow.png");

public EntityRainbowFX(World world, double x, double y, double z) {
	super(world, x, y, z);
	this.particleMaxAge = 50;
	this.particleScale = 1.5F;
	Random rand = new Random();
	this.motionX = rand.nextDouble() * 0.1D - 0.05D;
	this.motionY = rand.nextDouble() * 0.1D;
	this.motionZ = rand.nextDouble() * 0.1D - 0.05D;
}

@Override
public void renderParticle(Tessellator tess, float tick, float par3, float par4, float par5, float par6, float par7) {
	Minecraft.getMinecraft().renderEngine.bindTexture(textureFile);
	glDepthMask(false);
	glEnable(GL_BLEND);
	glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
	glAlphaFunc(GL_GREATER, 0.003921569F);
	tess.startDrawingQuads();
	tess.setBrightness(getBrightnessForRender(tick));
	float scale = 0.1F * particleScale;
	float x = (float)(this.prevPosX + (this.posX - this.prevPosX) * (double)tick - interpPosX);
	float y = (float)(this.prevPosY + (this.posY - this.prevPosY) * (double)tick - interpPosY);
	float z = (float)(this.prevPosZ + (this.posZ - this.prevPosZ) * (double)tick - interpPosZ);
	tess.addVertexWithUV((double)(x - par3 * scale - par6 * scale), (double)(y - par4 * scale), (double)(z - par5 * scale - par7 * scale), 1, 1);
	tess.addVertexWithUV((double)(x - par3 * scale + par6 * scale), (double)(y + par4 * scale), (double)(z - par5 * scale + par7 * scale), 1, 0);
	tess.addVertexWithUV((double)(x + par3 * scale + par6 * scale), (double)(y + par4 * scale), (double)(z + par5 * scale + par7 * scale), 0, 0);
	tess.addVertexWithUV((double)(x + par3 * scale - par6 * scale), (double)(y - par4 * scale), (double)(z + par5 * scale - par7 * scale), 0, 1);
	tess.draw();
	glDisable(GL_BLEND);
	glDepthMask(true);
	glAlphaFunc(GL_GREATER, 0.1F);
}

@Override
public int getFXLayer() {
	return 3;
}

@Override
public void onUpdate() {
	this.prevPosX = this.posX;
	this.prevPosY = this.posY;
	this.prevPosZ = this.posZ;

	if (this.particleAge++ >= this.particleMaxAge)
		this.setDead();

	this.moveEntity(this.motionX, this.motionY, this.motionZ);
	System.out.println(this.motionX + " " + this.motionY + " " + this.motionZ);
}
}

 

I spawn it when an item is used, like this:

public boolean onItemUse(ItemStack itemStack, EntityPlayer player, World world, int x, int y, int z, int side, float offsetX, float offsetY, float offsetZ){
Minecraft.getMinecraft().effectRenderer.addEffect(new EntityRainbowFX(world, (double)(x + offsetX), (double)(y + offsetY), (double)(z + offsetZ)));
return false;
}

 

Now what happens, is that I hold RMB with this item on the ground for some time, and the particles keep spawning and flying away. But, sometimes if I hold it for about 3 to 7 seconds, it errors and Minecraft exits. I have no idea what is causing this, I tried moving the random number generation (motionX, motionY, motionZ) to different methods, and then to the constructor (like it is in the posted code), but it still doesn't work. Here's the Forge log:

https://gist.github.com/anonymous/bdcb82c8f9692556ccdc

 

The crash happens at line 1682, all those digits before it are caused by me calling println on the motion variables.

Posted

Hi

 

The crash is happening on the server, but EntityFX are client-side only.  Probably something to do with onItemUse accessing the client side minecraft from the server.  onItemUse is called on both client and server

 

You need to use

if (world.isRemote) {

  spawn here

}

 

-TGG

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

    • Well, as usual, it was user error. Naming mismatch in sounds.json.  Please delete this post if you find it necessary. 
    • Hello Forge community.  I'm running into an issue with a mod I'm working on.  To preface, I can call /playsound modId:name music @a and I can hear the sound I registered being played in game. Great!  However, I cannot get it to trigger via my mod code.    Registration: public static final RegistryObject<SoundEvent> A_WORLD_OF_MADNESS = SOUND_EVENTS.register("a_world_of_madness", () -> new SoundEvent(new ResourceLocation("tetheredsouls", "a_world_of_madness")));   Playback: Minecraft mc = Minecraft.getInstance(); if (!(mc.player instanceof LocalPlayer) || mc.level == null) return; LocalPlayer player = (LocalPlayer) mc.player; BlockPos pos = player.blockPosition(); SoundEvent track = ModSounds.A_WORLD_OF_MADNESS.get(); System.out.println(track); System.out.println(pos); System.out.println(player); // play exactly like the tutorial: client-only, at the player's position try { mc.level.playLocalSound( player.getX(), player.getY(), player.getZ(), track, SoundSource.MUSIC, // Or MASTER if needed 1f, 1f, false ); System.out.println("[DEBUG] playSound success: " + track.getLocation()); } catch (Exception e) { System.err.println("[ERROR] Failed to play sound: " + track.getLocation()); e.printStackTrace(); } Sounds.json:   { "theme_of_laura": { "category": "music", "sounds": [ { "name": "tetheredsouls:a_world_of_madness", "stream": true } ] } } Things I have tried: - multiple .ogg files. Short .ogg files (5 seconds, <100KB).  - default minecraft sounds imported from import net.minecraft.sounds.SoundEvents; These work given my code. No idea why these are different.  - playSound() method, as well as several others in past iterations that did not work   I would be forever grateful if somebody could point me in the right direction. I've looked at several mod github repositories and found extremely similar code to what I'm doing. I've also found several threads in this forum that did not solve my issue. I just cannot figure out what I'm doing differently, and why I'm able to queue sounds manually with playsound but the code won't play it (despite confirming the code is being run with the debug statements.)
    • Delete the tensura-reincarnated/common.toml file (config folder)
    • Jesus Christ is God's Son, Jesus died for our sins and rose from the dead to Give us eternal life. Ask Him to also heal your body.
  • Topics

  • Create New...

Important Information

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