Jump to content

[1.7] [Solved] Need Help With Item Rendering


jharb52207

Recommended Posts

Hi all, I need some help figuring out how to do a proper item renderer.  I have spent a good bit of the last two days working on this issue and I have reset the code base back to what I have below to get a clean start.  My goal with this was to do a custom render for everything, but inventory and use the helper where possible.

 

I have comments in the code explaining my thought process, any help is welcomed.

 

Thanks

 


package magica.client.render;

import cpw.mods.fml.client.FMLClientHandler;
import magica.items.ItemRune;
import magica.reference.Names;
import magica.reference.Reference;
import net.minecraft.client.renderer.ItemRenderer;
import net.minecraft.client.renderer.Tessellator;
import net.minecraft.item.ItemStack;
import net.minecraft.util.IIcon;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.IItemRenderer;
import org.lwjgl.opengl.GL11;

public class RenderRune implements IItemRenderer
{

@Override
public boolean handleRenderType (ItemStack itemStack, ItemRenderType itemRenderType) {

	return itemRenderType != ItemRenderType.INVENTORY;

}

@Override
public boolean shouldUseRenderHelper (ItemRenderType itemRenderType, ItemStack itemStack, ItemRendererHelper itemRendererHelper) {

	return itemRendererHelper == ItemRendererHelper.ENTITY_ROTATION || itemRendererHelper == ItemRendererHelper.ENTITY_BOBBING;
}

@Override
public void renderItem (ItemRenderType itemRenderType, ItemStack itemStack, Object... data) {

	switch (itemRenderType) {
		case ENTITY: {
			GL11.glPushMatrix();
			GL11.glTranslatef(-0.5F, 0F, 0F);
			if (itemStack.isOnItemFrame()) {
				GL11.glTranslatef(0F, -0.3F, 0.01F);
			}
			render(itemStack);
			GL11.glPopMatrix();
			break;
		}
		case EQUIPPED: {
			render(itemStack);
			break;
		}
		case EQUIPPED_FIRST_PERSON: {
			render(itemStack);
			break;
		}
		default:
			break;
	}

}

private void render (ItemStack itemStack) {

	IIcon icon = itemStack.getIconIndex();

	Tessellator t = Tessellator.instance;

	float f = icon.getMinU();
	float f1 = icon.getMaxU();
	float f2 = icon.getMinV();
	float f3 = icon.getMaxV();
	float scale = 1F / 16F;

	GL11.glColor4f(1F, 1F, 1F, 1F);

	// draw the background image, 64 x 64 scaled to 16

	ItemRenderer.renderItemIn2D(Tessellator.instance, f1, f2, f, f3, icon.getIconWidth(), icon.getIconHeight(), scale);

	if (itemStack.getItem() instanceof ItemRune && itemStack.stackTagCompound != null) {

		// The textures for the slots overlap on the edges but that part is a transparent so it is ok

		if (itemStack.stackTagCompound.hasKey("RuneSlot01") && !itemStack.stackTagCompound.getString("RuneSlot01").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot01")));

			// draw it in slot 1 ( 0,0 to 31,31)

			t.startDrawingQuads();

			// Need the stuff to go here

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot02") && !itemStack.stackTagCompound.getString("RuneSlot02").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot02")));

			// draw it in slot 2 ( 31,0 to 63,31)

			t.startDrawingQuads();

			// Need the stuff to go here

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot03") && !itemStack.stackTagCompound.getString("RuneSlot03").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot03")));

			// draw it in slot 3 ( 0,31 to 31,63)

			t.startDrawingQuads();

			// Need the stuff to go here

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot04") && !itemStack.stackTagCompound.getString("RuneSlot04").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot04")));

			// draw it in slot 4 ( 31,31 to 63,63)

			t.startDrawingQuads();

			// Need the stuff to go here

			t.draw();

		}

	}

	GL11.glColor4f(1, 1, 1, 1.0F);

}

private ResourceLocation findRuneTexture (String runeName) {

	if (runeName.equalsIgnoreCase(Names.Runes.UR)) {

		return new ResourceLocation(Reference.MOD_ID, "textures/models/" + Names.Runes.UR + ".png");

	}

	return new ResourceLocation("minecraft", ":missingno");

}

}

Link to comment
Share on other sites

After trying multiple times to get the slot textures to render correctly I haven't been able to figure that part out.  The best result I had so far was getting it to render in the slot 3 position (I was trying for slot 1) and it was only on the back side (in third person it would be the side facing the ground) of the item. 

 

The main texture is rendering fine in all conditions, but I am just unable to find a working example or tutorial that I can understand about how to render the runes correctly in the correct positions and and both visible sides.  One of my main hang ups is figuring out the positioning system and the sizing system since the slot textures are 1/4 of the main texture.

Link to comment
Share on other sites

What do you mean by slots? Is it your custom slot texture?

Also, are you getting the problem on every renderType?

I. Stellarium for Minecraft: Configurable Universe for Minecraft! (WIP)

II. Stellar Sky, Better Star Rendering&Sky Utility mod, had separated from Stellarium.

Link to comment
Share on other sites

Slots might not be the right word here since not at all what I meant.

 

The texture is of a wood rune which a player will carve into up to 4 times.  The base rendering of the wooden rune is working fine for all render types.  What I am lacking the knowledge of implementing is drawing the up to 4 runes on top of the texture in their proper positions and sizes. 

 

I made several attempts to get that functionality in there and each failed with amazing results.  So at this point I am just looking to get pointed into the correct direction to get this done and actually learn this rendering thing finally.

 

Thanks

Link to comment
Share on other sites

1. Do you know how to use Tessellator?

2. I think you should use GL11.pushMatrix() and GL11.popMatrix(). Google how to use them.

I. Stellarium for Minecraft: Configurable Universe for Minecraft! (WIP)

II. Stellar Sky, Better Star Rendering&Sky Utility mod, had separated from Stellarium.

Link to comment
Share on other sites

This has been my first dance with the Tessellator.  I have used GL11 to do some overlay work and GUI work but not anything like this.  When I was using the Tessellator I used this as a reference for what I attempted http://www.minecraftforge.net/wiki/Tessellator but all my attempts with the addVertex and addvertexwithUV got muddled around.

 

Besides the bad positioning attempt I had one attempt that did render the texture on the other, but it was full sized and not scaled down.  Is there a better example that you can point me to that explains how to calculate the vertex positions relative to the background texture?  I think the big issue here is just me having issues understanding the given references I have found.

Link to comment
Share on other sites

You can scale the rendering using GL11.glScalef(float xScale, float yScale, float zScale).

Note that you should work on new matrix when scaling, using GL11.pushMatrix() and GL11.popMatrix().

(So pushMatix -> scale -> rendering -> popMatrix)

I. Stellarium for Minecraft: Configurable Universe for Minecraft! (WIP)

II. Stellar Sky, Better Star Rendering&Sky Utility mod, had separated from Stellarium.

Link to comment
Share on other sites

Ok I got this worked out.  The scale wasn't needed after all, but it lead me to the right path while I was researching it.  This is my final renderer for this item and it seems to be working properly.

 

Thanks again for the help on this.

 


package magica.client.render;

import cpw.mods.fml.client.FMLClientHandler;
import magica.items.ItemRune;
import magica.reference.Reference;
import net.minecraft.client.renderer.ItemRenderer;
import net.minecraft.client.renderer.Tessellator;
import net.minecraft.item.ItemStack;
import net.minecraft.util.IIcon;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.IItemRenderer;
import org.lwjgl.opengl.GL11;

public class RenderRune implements IItemRenderer
{

@Override
public boolean handleRenderType (ItemStack itemStack, ItemRenderType itemRenderType) {

	return itemRenderType != ItemRenderType.INVENTORY;

}

@Override
public boolean shouldUseRenderHelper (ItemRenderType itemRenderType, ItemStack itemStack, ItemRendererHelper itemRendererHelper) {

	return itemRendererHelper == ItemRendererHelper.ENTITY_ROTATION || itemRendererHelper == ItemRendererHelper.ENTITY_BOBBING;
}

@Override
public void renderItem (ItemRenderType itemRenderType, ItemStack itemStack, Object... data) {

	switch (itemRenderType) {
		case ENTITY: {
			GL11.glPushMatrix();
			GL11.glTranslatef(-0.5F, 0F, 0F);
			if (itemStack.isOnItemFrame()) {
				GL11.glTranslatef(0F, -0.3F, 0.01F);
			}
			render(itemStack);
			GL11.glPopMatrix();
			break;
		}
		case EQUIPPED: {
			render(itemStack);
			break;
		}
		case EQUIPPED_FIRST_PERSON: {
			render(itemStack);
			break;
		}
		default:
			break;
	}

}

private void render (ItemStack itemStack) {

	IIcon icon = itemStack.getIconIndex();

	Tessellator t = Tessellator.instance;

	float f = icon.getMinU();
	float f1 = icon.getMaxU();
	float f2 = icon.getMinV();
	float f3 = icon.getMaxV();
	float scale = 1F / 16F;

	float p_78439_1_ = f1;
	float p_78439_2_ = f2;
	float p_78439_3_ = f;
	float p_78439_4_ = f3;
	int p_78439_5_ = 32;
	int p_78439_6_ = 32;
	float p_78439_7_ = scale;

	// draw the background image, 64 x 64 scaled to 16

	ItemRenderer.renderItemIn2D(Tessellator.instance, f1, f2, f, f3, icon.getIconWidth(), icon.getIconHeight(), scale);

	if (!itemStack.isOnItemFrame()) {

		GL11.glPushMatrix();

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

		GL11.glTranslatef(-1.0F, 0.0F, 0.1F);

	}

	if (itemStack.getItem() instanceof ItemRune && itemStack.stackTagCompound != null) {

		// The textures for the slots overlap on the edges but that part is a transparent so it is ok

		if (itemStack.stackTagCompound.hasKey("RuneSlot01") && !itemStack.stackTagCompound.getString("RuneSlot01").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot01")));

			// draw it in slot 1 ( 0,0 to 31,31)

			t.startDrawingQuads();

			t.addVertexWithUV(0.0D, 0.5D, 0.0D, 0, 1);
			t.addVertexWithUV(0.5D, 0.5D, 0.0D, 1, 1);
			t.addVertexWithUV(1.0D, 1.0D, 0.0D, 1, 0);
			t.addVertexWithUV(0.0D, 1.0D, 0.0D, 0, 0);

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot02") && !itemStack.stackTagCompound.getString("RuneSlot02").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot02")));

			// draw it in slot 2 ( 31,0 to 63,31)

			t.startDrawingQuads();

			t.addVertexWithUV(0.5D, 0.5D, 0.0D, 0, 1);
			t.addVertexWithUV(1.0D, 0.5D, 0.0D, 1, 1);
			t.addVertexWithUV(1.0D, 1.0D, 0.0D, 1, 0);
			t.addVertexWithUV(0.5D, 1.0D, 0.0D, 0, 0);

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot03") && !itemStack.stackTagCompound.getString("RuneSlot03").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot03")));

			// draw it in slot 3 ( 0,31 to 31,63)

			t.startDrawingQuads();

			t.addVertexWithUV(0.0D, 0.0D, 0.0D, 0, 1);
			t.addVertexWithUV(0.5D, 0.0D, 0.0D, 1, 1);
			t.addVertexWithUV(1.0D, 0.5D, 0.0D, 1, 0);
			t.addVertexWithUV(0.0D, 0.5D, 0.0D, 0, 0);

			t.draw();

		}

		if (itemStack.stackTagCompound.hasKey("RuneSlot04") && !itemStack.stackTagCompound.getString("RuneSlot04").isEmpty()) {

			// Bind to the correct texture, one for now 24 are planned.  They are 32 x 32

			FMLClientHandler.instance().getClient().renderEngine.bindTexture(findRuneTexture(itemStack.stackTagCompound.getString("RuneSlot04")));

			// draw it in slot 4 ( 31,31 to 63,63)

			t.startDrawingQuads();

			t.addVertexWithUV(0.5D, 0.0D, 0.0D, 0, 1);
			t.addVertexWithUV(1.0D, 0.0D, 0.0D, 1, 1);
			t.addVertexWithUV(1.0D, 0.5D, 0.0D, 1, 0);
			t.addVertexWithUV(0.5D, 0.5D, 0.0D, 0, 0);

			t.draw();

		}

		if (!itemStack.isOnItemFrame()) {

			GL11.glPopMatrix();

		}

	}

}

private ResourceLocation findRuneTexture (String runeName) {

	return new ResourceLocation(Reference.MOD_ID, "textures/models/" + runeName + ".png");

}

}

 

Jfi7DUe.png

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.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Description of issue: Tried to run MC client, crashing with java.lang.NoSuchFieldError. I Went into SRG fields, found that f_271198 does exist, but Forge thinks this field does not exist.   Crash Report: ---- Minecraft Crash Report ---- // I let you down. Sorry Time: 2024-02-22 09:21:29 Description: Mod loading error has occurred java.lang.Exception: Mod Loading has failed     at net.minecraftforge.logging.CrashReportExtender.dumpModLoadingCrashReport(CrashReportExtender.java:48) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading}     at net.minecraftforge.client.loading.ClientModLoader.completeModLoading(ClientModLoader.java:119) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:runtimedistcleaner:A}     at net.minecraft.client.Minecraft.lambda$new$6(Minecraft.java:611) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A}     at net.minecraft.Util.ifElse(Util.java:432) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading}     at net.minecraft.client.Minecraft.lambda$new$7(Minecraft.java:602) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A}     at net.minecraftforge.client.loading.ForgeLoadingOverlay.render(ForgeLoadingOverlay.java:146) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading}     at net.minecraft.client.renderer.GameRenderer.render(GameRenderer.java:931) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A}     at net.minecraft.client.Minecraft.runTick(Minecraft.java:1250) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A}     at net.minecraft.client.Minecraft.run(Minecraft.java:801) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A}     at net.minecraft.client.main.Main.main(Main.java:234) ~[forge-1.20.4-49.0.30_mapped_official_1.20.4.jar:?] {re:classloading,pl:runtimedistcleaner:A}     at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?] {}     at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[?:?] {}     at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] {}     at java.lang.reflect.Method.invoke(Method.java:568) ~[?:?] {}     at net.minecraftforge.fml.loading.targets.CommonLaunchHandler.runTarget(CommonLaunchHandler.java:91) ~[fmlloader-1.20.4-49.0.30.jar:?] {}     at net.minecraftforge.fml.loading.targets.CommonLaunchHandler.lambda$makeService$0(CommonLaunchHandler.java:75) ~[fmlloader-1.20.4-49.0.30.jar:?] {}     at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:54) ~[modlauncher-10.1.2.jar:?] {}     at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:74) ~[modlauncher-10.1.2.jar:?] {}     at cpw.mods.modlauncher.Launcher.run(Launcher.java:114) ~[modlauncher-10.1.2.jar:?] {}     at cpw.mods.modlauncher.Launcher.main(Launcher.java:73) ~[modlauncher-10.1.2.jar:?] {}     at cpw.mods.modlauncher.BootstrapEntry.main(BootstrapEntry.java:17) ~[modlauncher-10.1.2.jar:?] {}     at net.minecraftforge.bootstrap.Bootstrap.moduleMain(Bootstrap.java:97) ~[bootstrap-2.0.0.jar!/:?] {}     at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?] {}     at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77) ~[?:?] {}     at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] {}     at java.lang.reflect.Method.invoke(Method.java:568) ~[?:?] {}     at net.minecraftforge.bootstrap.Bootstrap.start(Bootstrap.java:48) ~[bootstrap-2.0.0.jar!/:?] {}     at net.minecraftforge.bootstrap.ForgeBootstrap.main(ForgeBootstrap.java:18) ~[bootstrap-2.0.0.jar!/:?] {} A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- Head -- Thread: Render thread Suspected Mod:      Better Biomes (betterbiomes), Version: 0.1.4.3         at TRANSFORMER/betterbiomes@0.1.4.3/net.crypticverse.betterbiomes.util.BetterBiomeWoodTypes.<clinit>(BetterBiomeWoodTypes.java:8) Stacktrace:     at net.crypticverse.betterbiomes.util.BetterBiomeWoodTypes.<clinit>(BetterBiomeWoodTypes.java:8) ~[betterbiomes-forge-2.1.4.6-1.20.4.jar!/:2.1.4.6-1.20.4] {re:classloading} -- MOD betterbiomes -- Details:     Mod File: /C:/Users/myUser/BetterBiomes-Forge/run/mods/betterbiomes-forge-2.1.4.6-1.20.4.jar     Failure message: Better Biomes (betterbiomes) has failed to load correctly         java.lang.NoSuchFieldError: f_271198_     Mod Version: 0.1.4.3     Mod Issue URL: NOT PROVIDED     Exception message: java.lang.NoSuchFieldError: f_271198_ Stacktrace:     at net.crypticverse.betterbiomes.util.BetterBiomeWoodTypes.<clinit>(BetterBiomeWoodTypes.java:8) ~[main/:?] {re:classloading}     at net.crypticverse.betterbiomes.BetterBiomes.<init>(BetterBiomes.java:55) ~[main/:?] {re:classloading}     at jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[?:?] {}     at jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:77) ~[?:?] {}     at jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[?:?] {}     at java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:499) ~[?:?] {}     at java.lang.reflect.Constructor.newInstance(Constructor.java:480) ~[?:?] {}     at net.minecraftforge.fml.javafmlmod.FMLModContainer.constructMod(FMLModContainer.java:66) ~[javafmllanguage-1.20.4-49.0.30.jar!/:49.0.30] {}     at net.minecraftforge.fml.ModContainer.lambda$buildTransitionHandler$5(ModContainer.java:125) ~[fmlcore-1.20.4-49.0.30.jar!/:1.0] {}     at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) ~[?:?] {}     at java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1796) ~[?:?] {}     at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373) ~[?:?] {}     at java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182) ~[?:?] {}     at java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655) ~[?:?] {}     at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622) ~[?:?] {}     at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165) ~[?:?] {} -- System Details -- Details:     Minecraft Version: 1.20.4     Minecraft Version ID: 1.20.4     Operating System: Windows 10 (amd64) version 10.0     Java Version: 17.0.9, Eclipse Adoptium     Java VM Version: OpenJDK 64-Bit Server VM (mixed mode, sharing), Eclipse Adoptium     Memory: 578548144 bytes (551 MiB) / 1128267776 bytes (1076 MiB) up to 8522825728 bytes (8128 MiB)     CPUs: 20     Processor Vendor: GenuineIntel     Processor Name: 12th Gen Intel(R) Core(TM) i7-12700K     Identifier: Intel64 Family 6 Model 151 Stepping 2     Microarchitecture: Alder Lake     Frequency (GHz): 3.61     Number of physical packages: 1     Number of physical CPUs: 12     Number of logical CPUs: 20     Graphics card #0 name: NVIDIA GeForce RTX 3070 Ti     Graphics card #0 vendor: NVIDIA (0x10de)     Graphics card #0 VRAM (MB): 4095.00     Graphics card #0 deviceId: 0x2482     Graphics card #0 versionInfo: DriverVersion=31.0.15.3699     Memory slot #0 capacity (MB): 16384.00     Memory slot #0 clockSpeed (GHz): 4.80     Memory slot #0 type: Unknown     Memory slot #1 capacity (MB): 16384.00     Memory slot #1 clockSpeed (GHz): 4.80     Memory slot #1 type: Unknown     Virtual memory max (MB): 37373.42     Virtual memory used (MB): 22391.79     Swap memory total (MB): 4864.00     Swap memory used (MB): 95.69     JVM Flags: 1 total; -XX:HeapDumpPath=MojangTricksIntelDriversForPerformance_javaw.exe_minecraft.exe.heapdump     ModLauncher: 10.1.2     ModLauncher launch target: forge_userdev_client     ModLauncher naming: mcp     ModLauncher services:          / slf4jfixer PLUGINSERVICE          / runtimedistcleaner PLUGINSERVICE          / runtime_enum_extender PLUGINSERVICE          / object_holder_definalize PLUGINSERVICE          / capability_token_subclass PLUGINSERVICE          / accesstransformer PLUGINSERVICE          / eventbus PLUGINSERVICE          / mixin PLUGINSERVICE          / fml TRANSFORMATIONSERVICE          / mixin TRANSFORMATIONSERVICE      FML Language Providers:          lowcodefml@49         minecraft@1.0         javafml@49.0.30     Mod List:                                                            |Minecraft                     |minecraft                     |1.20.4              |COMMON_SET|Manifest: NOSIGNATURE         TerraBlender-forge-1.20.4-3.3.0.12_mapped_official|TerraBlender                  |terrablender                  |3.3.0.12            |COMMON_SET|Manifest: NOSIGNATURE                                                           |Forge                         |forge                         |49.0.30             |COMMON_SET|Manifest: NOSIGNATURE         betterbiomes-forge-2.1.4.6-1.20.4.jar             |Better Biomes                 |betterbiomes                  |0.1.4.3             |ERROR     |Manifest: NOSIGNATURE         Notebook-api-forge-1.20.4-1.1.0.4_mapped_official_|Notebook                      |notebook                      |1.1.0.4             |COMMON_SET|Manifest: NOSIGNATURE     Crash Report UUID: ad19c004-038a-4777-adbc-0504acf15d93     FML: 0.0     Forge: net.minecraftforge:49.0.30
    • Some kind of issue/conflict with eureka - also try other builds of it
    • doesn't work But after trying to make a boat with Valkyrien Skies, I got this : https://pastebin.com/bxnDcHr3 maybe the problem comes from valkyrien skies itself ?
    • yeah, I was about to try other builds for Valkyrien Skies but i'm scared of breaking everything again
  • Topics

×
×
  • Create New...

Important Information

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