Jump to content

Recommended Posts

Posted

Hi there,

I've been working on a wind turbine and recently changed the way I was rendering it to a Techne model. I want to make the blades constantly spin on the wind turbine so that it looks significantly better. How would I animate it to constantly rotate? I assume it's a method somewhere. If anybody would be kind enough to help that would be very nice as any tutorials I found were two years old.

 

If this helps, here is my wind turbine in game:

1iJQd28.png

I have no idea what I'm doing.

Posted

My way is next — put moving parts into separate model(s), and then use glRotate() and/or glRotate() when rendering the whole thing. As an example, here's my clock renderer:

@SideOnly(Side.CLIENT)
public class TileEntityRendererClockPole extends TileEntitySpecialRenderer{
protected ModelBase base = new ClockPoleBase();
protected ModelBase rim = new ClockPoleRim();
protected ModelBase hour = new ClockPoleHour();
protected ModelBase minute = new ClockPoleMinute();

@Override
public void renderTileEntityAt(TileEntity tileentity, double d, double d1, double d2, float f){
	GL11.glPushMatrix();
	GL11.glTranslatef((float)d, (float)d1, (float)d2);
	TileEntityClockPole tile = (TileEntityClockPole)tileentity;
	if(tile != null){
		renderBlock(tile, tile.getWorldObj(), tile.xCoord, tile.yCoord, tile.zCoord, RoWBlocks.clockPole);
	}
	GL11.glPopMatrix();
}

public void renderBlock(TileEntityClockPole tile, World world, int i, int j, int k, Block block){
	Tessellator tessellator = Tessellator.instance;
	float f = block.getMixedBrightnessForBlock(world, i, j, k);
	int l = world.getLightBrightnessForSkyBlocks(i, j, k, 0);
	int l1 = l % 65536;
	int l2 = l / 65536;
	tessellator.setColorOpaque_F(f, f, f);
	OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, (float)l1, (float)l2);

	if(tile != null){
		Minecraft minecraft = Minecraft.getMinecraft();
		float time = 0;
		if(minecraft.theWorld != null){
			time = (float)minecraft.theWorld.getWorldTime();
		}
		GL11.glPushMatrix();
		GL11.glTranslatef(0.5F, 1.5F, 0.5F);
		if(world.getBlock(i, j - 1, k) instanceof BlockSlab)
			GL11.glTranslatef(0F, -0.5F, 0F);
		GL11.glScalef(-1.0F, -1.0F, 1.0F);
		GL11.glPushMatrix();
		bindTexture(new ResourceLocation("row:textures/clock/pole/base.png"));
		base.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
		bindTexture(new ResourceLocation("row:textures/clock/pole/rim.png"));
		GL11.glTranslatef(0.0F, -2.4375F, 0.0F);
		for(byte u = 0; u <= 3; u++){
			GL11.glRotatef(u * 90F, 0.0F, 1.0F, 0.0F);
			rim.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPushMatrix();
			GL11.glRotatef((time - 6000) / 11999F * 360F, 0.0F, 0.0F, 1.0F);
			hour.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPopMatrix();
			GL11.glPushMatrix();
			GL11.glRotatef((time - 6000) / 11999F * 12F * 360F, 0.0F, 0.0F, 1.0F);
			minute.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPopMatrix();
		}
		GL11.glPopMatrix();
		GL11.glPopMatrix();
	}
}
}

If i helped you, don't forget pressing "Thank You" button. Thanks for your time.

Posted

My way is next — put moving parts into separate model(s), and then use glRotate() and/or glRotate() when rendering the whole thing. As an example, here's my clock renderer:

@SideOnly(Side.CLIENT)
public class TileEntityRendererClockPole extends TileEntitySpecialRenderer{
protected ModelBase base = new ClockPoleBase();
protected ModelBase rim = new ClockPoleRim();
protected ModelBase hour = new ClockPoleHour();
protected ModelBase minute = new ClockPoleMinute();

@Override
public void renderTileEntityAt(TileEntity tileentity, double d, double d1, double d2, float f){
	GL11.glPushMatrix();
	GL11.glTranslatef((float)d, (float)d1, (float)d2);
	TileEntityClockPole tile = (TileEntityClockPole)tileentity;
	if(tile != null){
		renderBlock(tile, tile.getWorldObj(), tile.xCoord, tile.yCoord, tile.zCoord, RoWBlocks.clockPole);
	}
	GL11.glPopMatrix();
}

public void renderBlock(TileEntityClockPole tile, World world, int i, int j, int k, Block block){
	Tessellator tessellator = Tessellator.instance;
	float f = block.getMixedBrightnessForBlock(world, i, j, k);
	int l = world.getLightBrightnessForSkyBlocks(i, j, k, 0);
	int l1 = l % 65536;
	int l2 = l / 65536;
	tessellator.setColorOpaque_F(f, f, f);
	OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, (float)l1, (float)l2);

	if(tile != null){
		Minecraft minecraft = Minecraft.getMinecraft();
		float time = 0;
		if(minecraft.theWorld != null){
			time = (float)minecraft.theWorld.getWorldTime();
		}
		GL11.glPushMatrix();
		GL11.glTranslatef(0.5F, 1.5F, 0.5F);
		if(world.getBlock(i, j - 1, k) instanceof BlockSlab)
			GL11.glTranslatef(0F, -0.5F, 0F);
		GL11.glScalef(-1.0F, -1.0F, 1.0F);
		GL11.glPushMatrix();
		bindTexture(new ResourceLocation("row:textures/clock/pole/base.png"));
		base.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
		bindTexture(new ResourceLocation("row:textures/clock/pole/rim.png"));
		GL11.glTranslatef(0.0F, -2.4375F, 0.0F);
		for(byte u = 0; u <= 3; u++){
			GL11.glRotatef(u * 90F, 0.0F, 1.0F, 0.0F);
			rim.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPushMatrix();
			GL11.glRotatef((time - 6000) / 11999F * 360F, 0.0F, 0.0F, 1.0F);
			hour.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPopMatrix();
			GL11.glPushMatrix();
			GL11.glRotatef((time - 6000) / 11999F * 12F * 360F, 0.0F, 0.0F, 1.0F);
			minute.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
			GL11.glPopMatrix();
		}
		GL11.glPopMatrix();
		GL11.glPopMatrix();
	}
}
}

 

I've got the blade rendering in a seperate model alright, but I'm kinda stuck on the actual rotation part. I've tried to copy what you've done with no success. Here is my rendering class:

 

package foodTech.tileEntities.render;

import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
import net.minecraft.entity.Entity;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ResourceLocation;

import org.lwjgl.opengl.GL11;

import foodTech.Main;
import foodTech.blocks.CreateBlocks;
import foodTech.tileEntities.models.windTurbine.ModelWindTurbineShaft;
import foodTech.tileEntities.models.windTurbine.ModelWindTurbineTop;
import foodTech.tileEntities.models.windTurbine.ModelWindTurbineTopBlade;

public class RenderWindTurbine extends TileEntitySpecialRenderer //Tells OpenGL how the windTurbine tileEntity should be drawn
{
private final ResourceLocation textureWindTurbineShaft = new ResourceLocation("roboguy99", "textures/models/windTurbineShaft.png");
private final ResourceLocation textureWindTurbineTop = new ResourceLocation("roboguy99", "textures/models/windTurbineTop.png");

private final ModelWindTurbineShaft modelShaft;
private final ModelWindTurbineTop modelTop;
private final ModelWindTurbineTopBlade modelTopBlade;

public RenderWindTurbine()
{
	this.modelShaft = new ModelWindTurbineShaft();
	this.modelTop = new ModelWindTurbineTop();
	this.modelTopBlade = new ModelWindTurbineTopBlade();
}

public void renderTileEntityAt(TileEntity tileEntity, double x, double y, double z, float f) 
{	
	int x1 = tileEntity.xCoord;
	int y1 = tileEntity.yCoord;
	int z1 = tileEntity.zCoord;

	while(tileEntity.getWorldObj().getBlockMetadata(x1, y1, z1) < 7 && tileEntity.getWorldObj().getBlock(x1, y1, z1).equals(CreateBlocks.blockWindTurbine))
	{
		y1++;
	}

	int metadata = tileEntity.getWorldObj().getBlockMetadata(tileEntity.xCoord, tileEntity.yCoord, tileEntity.zCoord);

	if(metadata > 0 && metadata < 7)
	{
		GL11.glPushMatrix();
	        
	       GL11.glTranslatef((float) x + 0.5F, (float) y + 1.5F, (float) z + 0.5F);

	       Minecraft.getMinecraft().renderEngine.bindTexture(textureWindTurbineShaft);

	       GL11.glRotatef(180F, 0.0F, 0.0F, 1.0F);

	       this.modelShaft.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);

	       GL11.glPopMatrix();
	}
	if (metadata > 7)
	{
		GL11.glPushMatrix();
	        
	       GL11.glTranslatef((float) x + 0.5F, (float) y + 1.5F, (float) z + 0.5F);

	       Minecraft.getMinecraft().renderEngine.bindTexture(textureWindTurbineTop);

	       //GL11.glRotatef(180F, 0.0F, 0.0F, 1.0F); //Commenting this out causes the rendering to float up 1 block

	       this.modelTop.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
	       this.modelTopBlade.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
	        
	       for(int i = 0; i < 360; i++)
	       {
	        	GL11.glRotatef(i, 0.0F, 0.0F, 1.0F);
	       }
	        
	       GL11.glPopMatrix();
	}
}
}

 

I have no idea what I'm doing.

Posted

Rotating should be done before rendering. Also,

for(int i = 0; i < 360; i++)
{
GL11.glRotatef(i, 0.0F, 0.0F, 1.0F);
}

makes no sence. And, I think, it's good idea to use minecraft time to define the rotation angle.

Try this:

if (metadata > 7){
GL11.glPushMatrix();
GL11.glTranslatef((float) x + 0.5F, (float) y + 1.5F, (float) z + 0.5F);
this.modelTop.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
Minecraft.getMinecraft().renderEngine.bindTexture(textureWindTurbineTop);
float time = 0;
if(minecraft.theWorld != null){
	time = (float)Minecraft.getMinecraft().theWorld.getWorldTime();
}
float mult = 1F/12000F; //adjust this value to get the desired rotation speed
GL11.glRotatef(time * mult, 0.0F, 0.0F, 1.0F);
this.modelTopBlade.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
GL11.glPopMatrix();
}

If i helped you, don't forget pressing "Thank You" button. Thanks for your time.

Posted

Rotating should be done before rendering. Also,

for(int i = 0; i < 360; i++)
{
GL11.glRotatef(i, 0.0F, 0.0F, 1.0F);
}

makes no sence. And, I think, it's good idea to use minecraft time to define the rotation angle.

Try this:

if (metadata > 7){
GL11.glPushMatrix();
GL11.glTranslatef((float) x + 0.5F, (float) y + 1.5F, (float) z + 0.5F);
this.modelTop.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
Minecraft.getMinecraft().renderEngine.bindTexture(textureWindTurbineTop);
float time = 0;
if(minecraft.theWorld != null){
	time = (float)Minecraft.getMinecraft().theWorld.getWorldTime();
}
float mult = 1F/12000F; //adjust this value to get the desired rotation speed
GL11.glRotatef(time * mult, 0.0F, 0.0F, 1.0F);
this.modelTopBlade.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
GL11.glPopMatrix();
}

 

I've been playing around with this code for a little bit, because as you can see in picture below it's not rendering at all correctly. I tried printing out

time * mult

and the number is indeed changing. The rotation does not however change more than once however. I tried changing the multiplier in debug mode which caused the turbine to move once and then stop again. Please help!

 

It's probably worth noting that the top block of the turbine is rendered entirely wrong (textures are all over the place)

 

kZ9WZps.png

I have no idea what I'm doing.

Posted

I've been playing around with this code for a little bit, because as you can see in picture below it's not rendering at all correctly. I tried printing out

time * mult

and the number is indeed changing. The rotation does not however change more than once however. I tried changing the multiplier in debug mode which caused the turbine to move once and then stop again. Please help!

 

It's probably worth noting that the top block of the turbine is rendered entirely wrong (textures are all over the place)

Well, providing the rest of your sources that are concerned with the block so that i can actually run the mod and debug it will be a good idea.

If i helped you, don't forget pressing "Thank You" button. Thanks for your time.

Posted

I've been playing around with this code for a little bit, because as you can see in picture below it's not rendering at all correctly. I tried printing out

time * mult

and the number is indeed changing. The rotation does not however change more than once however. I tried changing the multiplier in debug mode which caused the turbine to move once and then stop again. Please help!

 

It's probably worth noting that the top block of the turbine is rendered entirely wrong (textures are all over the place)

Well, providing the rest of your sources that are concerned with the block so that i can actually run the mod and debug it will be a good idea.

 

Ok sorry. I'm going to give you the link to the entire mod on dropbox because I'm in the middle of sorting out a lot of things and a huge amount of classes are currently needed for the VERY broken base upon which the windmill must sit. https://www.dropbox.com/sh/nzd6s6usysjri56/hhx8kivoWd

 

To place the turbine you need to assemble a 3*3 area of turbine base blocks and you'll see it turn into a very brokenly rendered multiblock (I'm having troubles with this too). Hopefully you'll find everything you need. A quick pointer: I think the most important class here is tileEntities/render/RenderWindTurbine.

 

Sorry again about the mess and thanks for the help.

I have no idea what I'm doing.

Posted

To rotate things properly you should model them so that their axles will go trough (0, 0, 0) point. Your blades are modeled wrong. And the whole code was written very poorly. Also, why are you binding texture after you render the top?

However, i've made it work in some way.

if (metadata > 7)
	{

		Minecraft.getMinecraft().renderEngine.bindTexture(textureWindTurbineTop);
		GL11.glPushMatrix();
		GL11.glTranslatef((float) x + 0.5F, (float) y - 0.5F, (float) z + 0.5F);
		this.modelTop.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
		GL11.glPopMatrix();


		float time = 0;
		if(minecraft.theWorld != null)
		{
			time = (float)Minecraft.getMinecraft().theWorld.getWorldTime();
		}

		float mult = 2F; //adjust this value to get the desired rotation speed
		GL11.glPushMatrix();
		GL11.glTranslatef((float) x + 0.5F, (float) y + 7.0F/16F, (float) z + 0.5F);
		GL11.glRotatef(time * mult, 0.0F, 0.0F, 1.0F);
		GL11.glTranslatef(0, -15.0F/16F, 0);
		this.modelTopBlade.render((Entity)null, 0.0F, 0.0F, -0.1F, 0.0F, 0.0F, 0.0625F);
		GL11.glPopMatrix();
	}
}

Still some weird black objects can be seen passing away sometimes.

If i helped you, don't forget pressing "Thank You" button. Thanks for your time.

Posted

It works, thanks! Perhaps you'd like to explain how my code was written very poorly so that I can improve in the future and correct my mistakes however?

I have no idea what I'm doing.

Posted

Well, as i've said, this part makes no sense

for(int i = 0; i < 360; i++){
GL11.glRotatef(i, 0.0F, 0.0F, 1.0F);
} 

In your RenderGrindstone the numbers of glPushMatrix(); and glPopMatrix(); are not mathcing, that may cause GL troubles. That's what I've seen. Sorry, but I have no time to check all your code.

If i helped you, don't forget pressing "Thank You" button. Thanks for your time.

Posted

It works, thanks! Perhaps you'd like to explain how my code was written very poorly so that I can improve in the future and correct my mistakes however?

I have no idea what I'm doing.

Posted

It works, thanks! Perhaps you'd like to explain how my code was written very poorly so that I can improve in the future and correct my mistakes however?

 

Well that explains the stack overflow warnings it was producing. Thanks.

I have no idea what I'm doing.

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

    • im having trouble with this error, can you guys help heres the log [12:19:18] [main/INFO]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker [12:19:18] [main/INFO]: Using primary tweak class name net.minecraftforge.fml.common.launcher.FMLTweaker [12:19:18] [main/INFO]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLTweaker [12:19:18] [main/INFO]: Forge Mod Loader version 14.23.5.2860 for Minecraft 1.12.2 loading [12:19:18] [main/INFO]: Java is Java HotSpot(TM) 64-Bit Server VM, version 1.8.0_51, running on Windows 10:amd64:10.0, installed at C:\Users\lexal\curseforge\minecraft\Install\runtime\jre-legacy\windows-x64\jre-legacy [12:19:19] [main/INFO]: Searching C:\Users\lexal\curseforge\minecraft\Instances\FoolCraft 3\mods for mods [12:19:19] [main/WARN]: The coremod org.minimallycorrect.libloader.LibLoader does not have a MCVersion annotation, it may cause issues with this version of Minecraft [12:19:19] [main/WARN]: The coremod LibLoader (org.minimallycorrect.libloader.LibLoader) is not signed! [12:19:32] [ForkJoinPool.commonPool-worker-5/INFO]: Downloading library org.javassist.javassist-3.22.0-CR1 from https://jcenter.bintray.com/org/javassist/javassist/3.22.0-CR1/javassist-3.22.0-CR1.jar. Expected hash: 1a955bad6b2755153f5abb8ee808b4ac002dc26f8d9c391ebba5d6743d5dd06efc2a1dcb70e5eac0396696f7583ea89f6b5d8c05f971f54f2d56a12a2bb50e82 [12:19:32] [ForkJoinPool.commonPool-worker-4/INFO]: Downloading library me.nallar.whocalled.WhoCalled-1.1 from https://jcenter.bintray.com/me/nallar/whocalled/WhoCalled/1.1/WhoCalled-1.1.jar. Expected hash: 6d4275e1b41ba7ce297ccb00db0afda0e5add3e07aea80220550d11a90d9a1fe01340d3f44c7d9fe67f463c96a0a6df233a28df882515bb05834868cdcdbc04f [12:19:32] [ForkJoinPool.commonPool-worker-2/INFO]: Downloading library com.eclipsesource.minimal-json.minimal-json-0.9.4 from https://jcenter.bintray.com/com/eclipsesource/minimal-json/minimal-json/0.9.4/minimal-json-0.9.4.jar. Expected hash: e9bbb53aa9c4b8275866a71e9bd83b0d7f64ac2d9417b52159c5b304807e73fef37f0c2eec03c00c6edf8b7c29ea20bf0bc5d30c644ad5ed033a3963296fa086 [12:19:32] [main/INFO]: Downloading library com.github.javaparser.javaparser-core-3.2.4 from https://jcenter.bintray.com/com/github/javaparser/javaparser-core/3.2.4/javaparser-core-3.2.4.jar. Expected hash: e9ecfe1bd5b9e0532d88093ba565e1420a694b10353243e1c9ba0a32c2aa5a743442df532deb5deeb6d8ab1c3c541e440cc57f1d64b86263e4b1207ed6c12163 [12:19:33] [main/ERROR]: Unable to launch java.lang.RuntimeException: An error occurred trying to configure the Minecraft home at C:\Users\lexal\curseforge\minecraft\Instances\FoolCraft 3 for Forge Mod Loader     at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupHome(FMLLaunchHandler.java:111) ~[forge-1.12.2-14.23.5.2860.jar:?]     at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupClient(FMLLaunchHandler.java:81) ~[forge-1.12.2-14.23.5.2860.jar:?]     at net.minecraftforge.fml.relauncher.FMLLaunchHandler.configureForClientLaunch(FMLLaunchHandler.java:42) ~[forge-1.12.2-14.23.5.2860.jar:?]     at net.minecraftforge.fml.common.launcher.FMLTweaker.injectIntoClassLoader(FMLTweaker.java:141) ~[forge-1.12.2-14.23.5.2860.jar:?]     at net.minecraft.launchwrapper.Launch.launch(Launch.java:115) [launchwrapper-1.12.jar:?]     at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.12.jar:?] Caused by: javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target     at sun.security.ssl.Alerts.getSSLException(Alerts.java:192) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1949) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:302) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:296) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1497) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:212) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.processLoop(Handshaker.java:979) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.process_record(Handshaker.java:914) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1062) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1375) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1403) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1387) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:563) ~[?:1.8.0_51]     at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1512) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.access$200(HttpURLConnection.java:90) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1432) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1430) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(AccessController.java:713) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1429) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254) ~[?:1.8.0_51]     at org.minimallycorrect.libloader.LibLoaderChained$Library.openStream(LibLoaderChained.java:208) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$Library.save(LibLoaderChained.java:258) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained.lambda$init$1(LibLoaderChained.java:68) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$$Lambda$34/873993427.accept(Unknown Source) ~[?:?]     at java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:184) ~[?:1.8.0_51]     at java.util.concurrent.ConcurrentHashMap$ValueSpliterator.forEachRemaining(ConcurrentHashMap.java:3566) ~[?:1.8.0_51]     at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:512) ~[?:1.8.0_51]     at java.util.stream.ForEachOps$ForEachTask.compute(ForEachOps.java:291) ~[?:1.8.0_51]     at java.util.concurrent.CountedCompleter.exec(CountedCompleter.java:731) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1689) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157) ~[?:1.8.0_51] Caused by: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target     at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:387) ~[?:1.8.0_51]     at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.java:292) ~[?:1.8.0_51]     at sun.security.validator.Validator.validate(Validator.java:260) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.java:324) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerImpl.java:229) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:124) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1479) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:212) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.processLoop(Handshaker.java:979) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.process_record(Handshaker.java:914) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1062) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1375) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1403) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1387) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:563) ~[?:1.8.0_51]     at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1512) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.access$200(HttpURLConnection.java:90) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1432) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1430) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(AccessController.java:713) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1429) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254) ~[?:1.8.0_51]     at org.minimallycorrect.libloader.LibLoaderChained$Library.openStream(LibLoaderChained.java:208) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$Library.save(LibLoaderChained.java:258) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained.lambda$init$1(LibLoaderChained.java:68) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$$Lambda$34/873993427.accept(Unknown Source) ~[?:?]     at java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:184) ~[?:1.8.0_51]     at java.util.concurrent.ConcurrentHashMap$ValueSpliterator.forEachRemaining(ConcurrentHashMap.java:3566) ~[?:1.8.0_51]     at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:512) ~[?:1.8.0_51]     at java.util.stream.ForEachOps$ForEachTask.compute(ForEachOps.java:291) ~[?:1.8.0_51]     at java.util.concurrent.CountedCompleter.exec(CountedCompleter.java:731) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1689) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157) ~[?:1.8.0_51] Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target     at sun.security.provider.certpath.SunCertPathBuilder.build(SunCertPathBuilder.java:145) ~[?:1.8.0_51]     at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(SunCertPathBuilder.java:131) ~[?:1.8.0_51]     at java.security.cert.CertPathBuilder.build(CertPathBuilder.java:280) ~[?:1.8.0_51]     at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:382) ~[?:1.8.0_51]     at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.java:292) ~[?:1.8.0_51]     at sun.security.validator.Validator.validate(Validator.java:260) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.java:324) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerImpl.java:229) ~[?:1.8.0_51]     at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:124) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1479) ~[?:1.8.0_51]     at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:212) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.processLoop(Handshaker.java:979) ~[?:1.8.0_51]     at sun.security.ssl.Handshaker.process_record(Handshaker.java:914) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1062) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1375) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1403) ~[?:1.8.0_51]     at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1387) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:563) ~[?:1.8.0_51]     at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1512) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.access$200(HttpURLConnection.java:90) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1432) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection$9.run(HttpURLConnection.java:1430) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_51]     at java.security.AccessController.doPrivileged(AccessController.java:713) ~[?:1.8.0_51]     at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1429) ~[?:1.8.0_51]     at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:254) ~[?:1.8.0_51]     at org.minimallycorrect.libloader.LibLoaderChained$Library.openStream(LibLoaderChained.java:208) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$Library.save(LibLoaderChained.java:258) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained.lambda$init$1(LibLoaderChained.java:68) ~[%23%20LibLoader.jar:0.1-SNAPSHOT+Jenkins-b39.git-83f5a19f50db8bf0700b1e9abc953bae1c3ae517]     at org.minimallycorrect.libloader.LibLoaderChained$$Lambda$34/873993427.accept(Unknown Source) ~[?:?]     at java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:184) ~[?:1.8.0_51]     at java.util.concurrent.ConcurrentHashMap$ValueSpliterator.forEachRemaining(ConcurrentHashMap.java:3566) ~[?:1.8.0_51]     at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:512) ~[?:1.8.0_51]     at java.util.stream.ForEachOps$ForEachTask.compute(ForEachOps.java:291) ~[?:1.8.0_51]     at java.util.concurrent.CountedCompleter.exec(CountedCompleter.java:731) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1689) ~[?:1.8.0_51]     at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157) ~[?:1.8.0_51] [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]: net.minecraftforge.fml.relauncher.FMLSecurityManager$ExitTrappedException [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at net.minecraftforge.fml.relauncher.FMLSecurityManager.checkPermission(FMLSecurityManager.java:49) [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at java.lang.SecurityManager.checkExit(SecurityManager.java:761) [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at java.lang.Runtime.exit(Runtime.java:107) [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at java.lang.System.exit(System.java:971) [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at net.minecraft.launchwrapper.Launch.launch(Launch.java:138) [12:19:33] [main/INFO]: [java.lang.ThreadGroup:uncaughtException:1052]:     at net.minecraft.launchwrapper.Launch.main(Launch.java:28)  
    • im having the exact same issue and I have tried with normal forge and neoforge but still wont work i have also made sure i was using the correct java installation as well so if you find a fix please share
    • Add crash-reports with sites like https://mclo.gs/   Remove randompatches      
    • 'm having a problem with modded Minecraft when using CurseForge to install modpacks. Every time I launch the game with Forge, I get a black screen, but I can still hear the main menu music and button sounds when I click around. The game doesn't crash—it just stays black, making it unplayable. I've tried: Reinstalling the modpack Updating my graphics drivers Allocating more RAM Vanilla Minecraft runs fine, and even Forge loads without errors, but as soon as I start a modpack through CurseForge, I get this black screen issue. Has anyone else experienced this or know a fix?
  • Topics

×
×
  • Create New...

Important Information

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