Jump to content

Recommended Posts

Posted

Heyho Guys!

 

I have a small problem concerning GUIs.

I created a GUI wich should show you how to craft something. I didnt use a container for this, I created the rendering positions and textures on my own. Basically there are a few itemstacks rendered after each other. When you hover over them you can see their ItemTooltip. Each tooltip is shown (if necessary) directly after the corresponding stack has been rendered. The problem is: The tooltip is rendered below the stacks that are drawn later although it shouldn't because of the zLevel (200 for the Items and 300 for the tooltip).

 

How can I fix this?

Posted

 

GL11.glDisable(GL11.GL_LIGHTING);
				GL11.glEnable(GL11.GL_BLEND);
				GL11.glTranslatef(0, 0, 400);
				this.fontRendererObj.drawString(I18n.format("container.crafting", new Object[0]), x + 5, y + 10, 0);
				GL11.glTranslatef(0, 0, -400);
				GLUtil.resetColour();
				this.mc.getTextureManager().bindTexture(overlay_craft);
				this.zLevel = 30;
				this.drawTexturedModalRectWithSize(x, y, 160, 174, 0, 0, 160, 174);
				GLUtil.resetColour();
				this.drawItemStack((ItemStack) entry.getCommand_data()[args[0]], x + 109, y + 80, "");
				if (this.isMouseInside(mousex, mousey, x + 109, y + 80, x + 125, y + 96))
					this.renderToolTip((ItemStack) entry.getCommand_data()[args[0]], mousex, mousey);
				for (int i = 0; i < 3; i ++) {
					for (int j = 0; j < 3; j ++) {
						GLUtil.resetColour();
						GL11.glDisable(GL11.GL_LIGHTING);
						this.drawItemStack((ItemStack) entry.getCommand_data()[args[j + i*3 + 1]], x + 25 + 18 * j, y + 62 + 18 * i, "");
					}
				}
				for (int i = 0; i < 3; i ++) {
					for (int j = 0; j < 3; j ++) {
						if (this.isMouseInside(mousex, mousey, x + 25 + 18 * j, y + 62 + 18 * i, x + 41 + 18 * j, y + 78 + 18 * i))
							this.renderToolTip((ItemStack) entry.getCommand_data()[args[j + i*3 + 1]], mousex, mousey);
					}
				}

 

 

The methods renderToolTip and renderItemStack are taken from GuiContainer

Posted

Hmmm... I'm really not sure. Maybe you could take a look at NEI on github. It is open source, as is all of ChickenBones's mods.

I ask complicated questions, and apparently like to write really long detailed posts. But I also help others when I can.

Posted
The tooltip is rendered below the stacks that are drawn later although it shouldn't because of the zLevel (200 for the Items and 300 for the tooltip).

…If you can read you have an advantage.

 

And I can't change the order because the crafting grid should be rendered twice on screen and this must happen one after another because of some other code structures.

 

I looked into the Code of NEI and I didn't understand much,  but it seems like ChickenBones renders the tooltips after the items, exactly like it's done in GUIContainer.

 

I also checked out the drawToolTip method and found out that it diaables GL_DEPTH_TEST while it draws the tooltip on the screen. Its re-enabled afterwards, but can this be the cause of this problem? And if, what can I do against it?

Posted

Solution A:

Do -not- render the tooltip while rendering the item-stacks.  Iterate over your stacks a -second- time after the initial rendering, only rendering the tooltip for the mouse-over stack the second pass.

 

 

Solution B:

Implement a deferred tooltip render.  Again instead of rendering the tooltip immediately with the stack, setup a deferred rendering.  I do this in my GUIs by grabing a reference to the item-stack and the x,y position the tooltip is supposed to render at (this is setup while doing the initial stack rendering).  After stack rendering I quickly grab my deferred tooltip data and render that.  If the mouse is over a stack in the stack rendering, set the tooltip stack reference to that stack and set the x,y position, render the tooltip after the stacks, and set the tooltip stack back to null -- that way you know if the tooltip stack is -not- null that you have a tooltip to render.

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

    • So i have a forge modded aternos server that worked just fine for a month untill today it suddenly crashes most of the time giving errors and idk which mod is causing the error or its smth else here is the crash log link https://mclo.gs/gGkzGKT
    • Struggling to decipher a crash report I'm getting in a custom modpack I'm tinkering with. The crash happens on startup, but weirdly, only some of the time. It seems to be related to Steves Carts, but weirdly it only started happening recently, and I can't identify if another mod is conflicting, or why it is only happening some of the time:   java.lang.NullPointerException: Cannot invoke "net.minecraft.world.entity.player.Player.m_20202_()" because "player" is null at vswe.stevescarts.events.OverlayEventHandler.onRenderTick(OverlayEventHandler.java:24) ~[stevescarts-1.20.1-1.1.14.jar%23527!/:1.20.1-1.1.14] {re:classloading} at net.minecraftforge.eventbus.EventBus.doCastFilter(EventBus.java:260) ~[eventbus-6.0.5.jar%23127!/:?] {} at net.minecraftforge.eventbus.EventBus.lambda$addListener$11(EventBus.java:252) ~[eventbus-6.0.5.jar%23127!/:?] {} at net.minecraftforge.eventbus.EventBus.post(EventBus.java:315) ~[eventbus-6.0.5.jar%23127!/:?] {} at net.minecraftforge.eventbus.EventBus.post(EventBus.java:296) ~[eventbus-6.0.5.jar%23127!/:?] {} at net.minecraftforge.event.ForgeEventFactory.onRenderTickEnd(ForgeEventFactory.java:919) ~[forge-1.20.1-47.1.106-universal.jar%23581!/:?] {re:mixin,re:classloading,pl:mixin:APP:modernfix-forge.mixins.json:perf.potential_spawns_alloc.ForgeEventFactoryMixin,pl:mixin:A} at net.minecraft.client.Minecraft.m_91383_(Minecraft.java:1148) ~[client-1.20.1-20230612.114412-srg.jar%23576!/:?] {re:mixin,pl:accesstransformer:B,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick_render_call,xf:fml:xaerominimap:xaero_minecraftclient,xf:fml:xaeroworldmap:xaero_wm_minecraftclient,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick_render_call,xf:fml:xaerominimap:xaero_minecraftclient,xf:fml:xaeroworldmap:xaero_wm_minecraftclient,pl:mixin:A,pl:runtimedistcleaner:A} at net.minecraft.client.Minecraft.m_91374_(Minecraft.java:718) ~[client-1.20.1-20230612.114412-srg.jar%23576!/:?] {re:mixin,pl:accesstransformer:B,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick_render_call,xf:fml:xaerominimap:xaero_minecraftclient,xf:fml:xaeroworldmap:xaero_wm_minecraftclient,pl:runtimedistcleaner:A,re:classloading,pl:accesstransformer:B,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick,xf:fml:xaeroworldmap:xaero_wm_minecraft_runtick_render_call,xf:fml:xaerominimap:xaero_minecraftclient,xf:fml:xaeroworldmap:xaero_wm_minecraftclient,pl:mixin:A,pl:runtimedistcleaner:A} at net.minecraft.client.main.Main.main(Main.java:218) ~[minecraft-1.20.1-client.jar:?] {re:mixin,pl:runtimedistcleaner:A,re:classloading,pl:mixin:APP:flywheel.mixins.json:ClientMainMixin,pl:mixin:A,pl:runtimedistcleaner:A}     Including some extra info in case any of it is relevant^. Appreciate any ideas/advice!    
    • Try the JVM argument in this post, just sub xmx/xms numbers for what you want/need allocated.  https://www.reddit.com/r/feedthebeast/s/lzmKUNZFrG I'm having the same issue with a huge modpack using the 3 culprits to your issue.  Let me know if this helps!
    • i have been trying to  lauch a modpack and it crashes in the lauching phase   
    • nope, even the log is the exact same, i also tried with the Dimensional doors just in case and nothing.
  • Topics

×
×
  • Create New...

Important Information

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