Merge branch 'mapStyle' of github.com:Matchlighter/MinecraftForge into Matchlighter-mapStyle

This commit is contained in:
Christian 2013-09-13 20:11:13 -05:00
commit 65165cd41c
2 changed files with 74 additions and 14 deletions

View file

@ -69,7 +69,17 @@ public interface IItemRenderer
* RenderEngine engine - The RenderEngine instance * RenderEngine engine - The RenderEngine instance
* MapData mapData - The map data * MapData mapData - The map data
*/ */
FIRST_PERSON_MAP FIRST_PERSON_MAP,
/**
* The render type used when in first person and an item similar to a map should be rendered.
* All appropriate rotations have been applied.
*
* Data Parameters:
* EntityPlayer player - The player holding the map
* RenderEngine engine - The RenderEngine instance
*/
FIRST_PERSON_HOLDING,
} }
public enum ItemRendererHelper public enum ItemRendererHelper
@ -102,7 +112,17 @@ public interface IItemRenderer
* Determines if the item should be rendered in GUI inventory slots as a 3D * Determines if the item should be rendered in GUI inventory slots as a 3D
* block or as a 2D texture. * block or as a 2D texture.
*/ */
INVENTORY_BLOCK INVENTORY_BLOCK,
/**
* Determines if hands should be rendered when being held.
*/
HOLD_HANDS,
/**
* Determines if the map background should be rendered when being held.
*/
HOLD_BACKGROUND,
} }
/** /**

View file

@ -67,16 +67,48 @@
{ {
GL11.glDepthFunc(GL11.GL_EQUAL); GL11.glDepthFunc(GL11.GL_EQUAL);
GL11.glDisable(GL11.GL_LIGHTING); GL11.glDisable(GL11.GL_LIGHTING);
@@ -266,7 +292,7 @@ @@ -266,8 +292,10 @@
Render render; Render render;
RenderPlayer renderplayer; RenderPlayer renderplayer;
- if (itemstack != null && itemstack.itemID == Item.map.itemID) - if (itemstack != null && itemstack.itemID == Item.map.itemID)
+ if (itemstack != null && itemstack.getItem() instanceof ItemMap) - {
{ + IItemRenderer custom = null;
+ if (itemstack != null && (itemstack.getItem() instanceof ItemMap || (custom=MinecraftForgeClient.getItemRenderer(itemstack, FIRST_PERSON_HOLDING))!=null))
+ {
+ boolean isMap = itemstack.getItem() instanceof ItemMap;
GL11.glPushMatrix(); GL11.glPushMatrix();
f12 = 0.8F; f12 = 0.8F;
@@ -333,11 +359,20 @@ f7 = entityclientplayermp.getSwingProgress(par1);
@@ -291,6 +319,9 @@
GL11.glRotatef(90.0F, 0.0F, 1.0F, 0.0F);
GL11.glRotatef(f7 * -85.0F, 0.0F, 0.0F, 1.0F);
GL11.glEnable(GL12.GL_RESCALE_NORMAL);
+
+ if (isMap || custom.shouldUseRenderHelper(FIRST_PERSON_HOLDING, itemstack, HOLD_HANDS))
+ {
this.mc.getTextureManager().bindTexture(entityclientplayermp.getLocationSkin());
for (k = 0; k < 2; ++k)
@@ -309,6 +340,7 @@
renderplayer.renderFirstPersonArm(this.mc.thePlayer);
GL11.glPopMatrix();
}
+ }
f8 = entityclientplayermp.getSwingProgress(par1);
f6 = MathHelper.sin(f8 * f8 * (float)Math.PI);
@@ -323,6 +355,9 @@
GL11.glTranslatef(-1.0F, -1.0F, 0.0F);
f11 = 0.015625F;
GL11.glScalef(f11, f11, f11);
+
+ if (isMap || custom.shouldUseRenderHelper(FIRST_PERSON_HOLDING, itemstack, HOLD_BACKGROUND))
+ {
this.mc.getTextureManager().bindTexture(RES_MAP_BACKGROUND);
Tessellator tessellator = Tessellator.instance;
GL11.glNormal3f(0.0F, 0.0F, -1.0F);
@@ -333,11 +368,28 @@
tessellator.addVertexWithUV((double)(128 + b0), (double)(0 - b0), 0.0D, 1.0D, 0.0D); tessellator.addVertexWithUV((double)(128 + b0), (double)(0 - b0), 0.0D, 1.0D, 0.0D);
tessellator.addVertexWithUV((double)(0 - b0), (double)(0 - b0), 0.0D, 0.0D, 0.0D); tessellator.addVertexWithUV((double)(0 - b0), (double)(0 - b0), 0.0D, 0.0D, 0.0D);
tessellator.draw(); tessellator.draw();
@ -85,24 +117,32 @@
- if (mapdata != null) - if (mapdata != null)
- { - {
- this.mapItemRenderer.renderMap(this.mc.thePlayer, this.mc.getTextureManager(), mapdata); - this.mapItemRenderer.renderMap(this.mc.thePlayer, this.mc.getTextureManager(), mapdata);
+ }
+ +
+ IItemRenderer custom = MinecraftForgeClient.getItemRenderer(itemstack, FIRST_PERSON_MAP); + if (isMap)
+ MapData mapdata = ((ItemMap)itemstack.getItem()).getMapData(itemstack, this.mc.theWorld);
+
+ if (custom == null)
+ { + {
+ if (mapdata != null) + custom = MinecraftForgeClient.getItemRenderer(itemstack, FIRST_PERSON_MAP);
+ MapData mapdata = ((ItemMap)itemstack.getItem()).getMapData(itemstack, this.mc.theWorld);
+
+ if (custom == null)
+ { + {
+ this.mapItemRenderer.renderMap(this.mc.thePlayer, this.mc.getTextureManager(), mapdata); + if (mapdata != null)
+ {
+ this.mapItemRenderer.renderMap(this.mc.thePlayer, this.mc.getTextureManager(), mapdata);
+ }
+ }
+ else
+ {
+ custom.renderItem(FIRST_PERSON_MAP, itemstack, mc.thePlayer, mc.getTextureManager(), mapdata);
+ } + }
+ } + }
+ else + else
+ { + {
+ custom.renderItem(FIRST_PERSON_MAP, itemstack, mc.thePlayer, mc.getTextureManager(), mapdata); + custom.renderItem(FIRST_PERSON_HOLDING, itemstack, mc.thePlayer, mc.renderEngine);
} }
GL11.glPopMatrix(); GL11.glPopMatrix();
@@ -439,17 +474,20 @@ @@ -439,17 +491,20 @@
if (itemstack.getItem().requiresMultipleRenderPasses()) if (itemstack.getItem().requiresMultipleRenderPasses())
{ {