Jump to content

Recommended Posts

Posted

I'm trying to render an item/block in game. However, the textures look to me like they are all in shades of grey. The textures are visible, barely, but the colors aren't there. It's just all grey. I've toyed around with the OpenGL functions, but quite frankly I'm crap at it and don't really know what's going on. Could use some help.

 

Here is my code:

	@Override
public void renderTileEntityAt(TileEntity te, double x, double y,
									 double z, float partialTick) 
{
	if(te == null || !(te instanceof TileEntityProjectBench))
	{
		return;
	}
	TileEntityProjectBench tpb = (TileEntityProjectBench)te;
	renderBlocks = new RenderBlocks(te.worldObj);
	renderBlocks.renderBlockByRenderType(ProjectBench.instance.projectBench, 
													 (int)x, (int)y, (int)z);
	renderBlocks.useInventoryTint = false;
	ItemStack craftingResult = tpb.findRecipe();
	if(craftingResult != null)
	{
            GL11.glPushMatrix();
		GL11.glEnable(GL12.GL_RESCALE_NORMAL);
		GL11.glDisable(GL11.GL_LIGHTING);
		GL11.glPushMatrix();
		glTranslatef((float)x, (float)y, (float)z);
		glTranslatef(0.5F, 1.2F, 0.5F);
		glScalef(0.3F, 0.3F, 0.3F);
            GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
            GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
            this.overrideTexture(craftingResult);
            this.renderBlocks.renderBlockAsItem(Block.blocksList[craftingResult.itemID], craftingResult.getItemDamage(), 1.0F);
            GL11.glPopMatrix();
            GL11.glDisable(GL12.GL_RESCALE_NORMAL);
            GL11.glEnable(GL11.GL_LIGHTING);
            GL11.glPopMatrix();
	}
}

 

Picture of problem:

KlXcn.png

 

*Edit, sorry code isn't formatting correctly

Posted

I had this problem with textures in my GUI, but dunno if you can apply this, too. I used this before rendering:

RenderHelper.disableStandardItemLighting();

 

Put that before:

this.renderBlocks.renderBlockAsItem(Block.blocksList[craftingResult.itemID], craftingResult.getItemDamage(), 1.0F);

 

Then after that:

RenderHelper.enableStandardItemLighting();

 

If that doesn't work, swap these methods around and test it then.

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Posted

I had this problem with textures in my GUI, but dunno if you can apply this, too. I used this before rendering:

RenderHelper.disableStandardItemLighting();

 

Put that before:

this.renderBlocks.renderBlockAsItem(Block.blocksList[craftingResult.itemID], craftingResult.getItemDamage(), 1.0F);

 

Then after that:

RenderHelper.enableStandardItemLighting();

 

If that doesn't work, swap these methods around and test it then.

Thanks for the suggestion, but it didn't do anything. It's weird, it's like OpenGL isn't responding to any of the functions I throw in for lighting. I don't get it.

Posted

Okay, then try this code:

int var5 = entityliving.getBrightnessForRender(f);
int var6 = var5 % 65536;
int var7 = var5 / 65536;
OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, var6 / 1.0F, var7 / 1.0F);

 

above:

this.renderBlocks.renderBlockAsItem(Block.blocksList[craftingResult.itemID], craftingResult.getItemDamage(), 1.0F);

 

and replace this:

entityliving.getBrightnessForRender(f)

 

with this:

(float)te.worldObj.getBlockLightValue(te.xCoord, te.yCoord, te.zCoord) / 15F

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Posted

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F);

        int var6 = var5 % 65536;

        int var7 = var5 / 65536;

        OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, var6 / 1.0F, var7 / 1.0F);

 

This is the closest I could come. Didn't change a thing.

 

Here's the code on https://github.com/bau5/ProjectBench/blob/master/bau5/mods/projectbench/client/TEProjectBenchRenderer.java

Posted

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F);

        int var6 = var5 % 65536;

        int var7 = var5 / 65536;

        OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, var6 / 1.0F, var7 / 1.0F);

 

This is the closest I could come. Didn't change a thing.

 

Here's the code on https://github.com/bau5/ProjectBench/blob/master/bau5/mods/projectbench/client/TEProjectBenchRenderer.java

 

use this:

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F * 240F);

 

instead of this:

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F);

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Posted

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F);

        int var6 = var5 % 65536;

        int var7 = var5 / 65536;

        OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, var6 / 1.0F, var7 / 1.0F);

 

This is the closest I could come. Didn't change a thing.

 

Here's the code on https://github.com/bau5/ProjectBench/blob/master/bau5/mods/projectbench/client/TEProjectBenchRenderer.java

 

use this:

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F * 240F);

 

instead of this:

int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F);

 

Still no change...So frustrating. Code now looks like this:

glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
	glPushMatrix();
	glEnable(32826 /*rescale*/);
	glTranslatef((float)x,(float)y,(float)z);
	glTranslatef(0.5F, 1.2F, 0.5F);
	glScalef(0.3F, 0.3F, 0.3F);
	bindTextureByName("/terrain.png");
	int var5 = (int) (tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord) / 15F * 240F);
	int var6 = var5 % 65536;
	int var7 = var5 / 65536;
	OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, var6 / 1.0F, var7 / 1.0F);
	renderBlocks.renderBlockAsItem(Block.blocksList[stack.itemID], stack.getItemDamage(), 1.0F);
	glDisable(32826 /* GL_RESCALE_NORMAL_EXT */);
	glPopMatrix();
	glColor4f(1.0F, 1.0F, 1.0F, 1.0F);

Posted

Put this line after the OpenGLHelper method:

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

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Posted

I got it....I finally got it. For some reason var6 and var7 were both zero, there must have been something weird going on with the get block light value method.

 

I debugged the code for the enderman, figured out what were the appropriate values and hardcoded it in.

 

Success.

 

OTY14.png

Posted

But if you hardcoded them in, then they'll glow in the dark ;)

 

EDIT: I forgot something in my code:

int var5 = (int) (((float)tpb.worldObj.getBlockLightValue(tpb.xCoord, tpb.yCoord, tpb.zCoord)) / 15F * 240F);

 

I forgot to parse the getBlockLightValue method to float, which causes calculation errors: (int)9 / 15F = 0 (and not 0.6F). Try this before you hardcode anything in.

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

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

    • I haven't tested it but under https://minecraft.wiki/w/Items_model_definition it says now:   So I guess the resource location must have changed with 1.24.4, which means you need to move your models/item/ to the new source. But as I said I haven't tested this so it also may be that this wont work. Nevertheless give it a try      EDIT (important) So now I tested it and found out how it works   Let the model files (e.g. the .json from blockbench) within "assets/<your_mod_id>/models/item" In addition to that do the following: Every model you added will need a new file under "assets/<your_mod_id>/items" That file is also a JSON and looks like this: { "model": { "type": "minecraft:model", "model": "your_mod_id:item/custom_item" } } - "type" can be minecraft:model, minecraft:composite, minecraft:condition, minecraft:select, minecraft:range_dispatch, minecraft:empty, minecraft:bundle/selected_item or minecraft:special. (In most cases you would need minecraft:model) - "model" is the path to your actual model for this item. For example the value above would point to "assets/your_mod_id/models/item/custom_item"
    • On version 1.20.1 there is a build with the AE2 mod, and when opening the reference book for this mod inside Minecraft, it just freezes and closes
    • public ExampleMod(FMLJavaModLoadingContext context) { var modEventBus = context.getModEventBus(); } Refer to the javadocs and MDK for more pointers and examples.
    • Does it work without Cobblemon GTS?
    • I recently updated my mod from 1.21 to 1.21.4. Didn't change anything on the data generation code (even though methods are now marked as deprecated) and had to change the block and item registration to explicitly add the id to avoid the "null pointer exception no id supplied" error The problem is that the block models work fine, as they did before, textures and all, but not the item ones. Is it because of this registration change? Did something in the datapack structure change on minecraft itself?   Here is one of the registration lines im using as reference:   RegistryObject<Item> CUSTOMITEM = ITEMS.register("item", () -> new RawMaterial(new Item.Properties().useItemDescriptionPrefix().setId(ResourceKey.create(Registries.ITEM, ResourceLocation.fromNamespaceAndPath(MOD_ID, "item"))))));   and same for blocks:   private static <T extends Block> RegistryObject<Item> registerBlockItem(String name, RegistryObject<T> block) {     //T is the block type. It will register the block and the block item.     return ModItems.ITEMS.register(name, () -> new BlockItem(block.get(), new Item.Properties().useBlockDescriptionPrefix().setId(ResourceKey.create(Registries.ITEM, ResourceLocation.fromNamespaceAndPath(MOD_ID, name))))); } RegistryObject<Block> CUSTOMORE = registerBlock("ore", () -> new CustomOre(Block.Properties.ofFullCopy(Blocks.STONE).setId(ResourceKey.create(Registries.BLOCK, ResourceLocation.fromNamespaceAndPath(MOD_ID,"ore"))))));   Note that this made the translation keys i had pre 1.21.4 correctly show the translatable component, so im guessing that is okay, but just in case.  
  • Topics

×
×
  • Create New...

Important Information

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