mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-22 15:06:58 +00:00
Add back item frame rendering for printouts
Also fix a recipe loading issue, due to capitalisation of enums
This commit is contained in:
parent
05eada427b
commit
649acbae1c
@ -9,7 +9,11 @@ import com.mojang.blaze3d.systems.RenderSystem;
|
|||||||
import dan200.computercraft.core.terminal.TextBuffer;
|
import dan200.computercraft.core.terminal.TextBuffer;
|
||||||
import dan200.computercraft.shared.common.ContainerHeldItem;
|
import dan200.computercraft.shared.common.ContainerHeldItem;
|
||||||
import dan200.computercraft.shared.media.items.ItemPrintout;
|
import dan200.computercraft.shared.media.items.ItemPrintout;
|
||||||
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.screen.inventory.ContainerScreen;
|
import net.minecraft.client.gui.screen.inventory.ContainerScreen;
|
||||||
|
import net.minecraft.client.renderer.IRenderTypeBuffer;
|
||||||
|
import net.minecraft.client.renderer.Matrix4f;
|
||||||
|
import net.minecraft.client.renderer.TransformationMatrix;
|
||||||
import net.minecraft.entity.player.PlayerInventory;
|
import net.minecraft.entity.player.PlayerInventory;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import org.lwjgl.glfw.GLFW;
|
import org.lwjgl.glfw.GLFW;
|
||||||
@ -18,6 +22,8 @@ import static dan200.computercraft.client.render.PrintoutRenderer.*;
|
|||||||
|
|
||||||
public class GuiPrintout extends ContainerScreen<ContainerHeldItem>
|
public class GuiPrintout extends ContainerScreen<ContainerHeldItem>
|
||||||
{
|
{
|
||||||
|
private static final Matrix4f IDENTITY = TransformationMatrix.identity().getMatrix();
|
||||||
|
|
||||||
private final boolean m_book;
|
private final boolean m_book;
|
||||||
private final int m_pages;
|
private final int m_pages;
|
||||||
private final TextBuffer[] m_text;
|
private final TextBuffer[] m_text;
|
||||||
@ -91,8 +97,10 @@ public class GuiPrintout extends ContainerScreen<ContainerHeldItem>
|
|||||||
RenderSystem.color4f( 1.0f, 1.0f, 1.0f, 1.0f );
|
RenderSystem.color4f( 1.0f, 1.0f, 1.0f, 1.0f );
|
||||||
RenderSystem.enableDepthTest();
|
RenderSystem.enableDepthTest();
|
||||||
|
|
||||||
drawBorder( guiLeft, guiTop, getBlitOffset(), m_page, m_pages, m_book );
|
IRenderTypeBuffer.Impl renderer = Minecraft.getInstance().getRenderTypeBuffers().getBufferSource();
|
||||||
drawText( guiLeft + X_TEXT_MARGIN, guiTop + Y_TEXT_MARGIN, ItemPrintout.LINES_PER_PAGE * m_page, m_text, m_colours );
|
drawBorder( IDENTITY, renderer, guiLeft, guiTop, getBlitOffset(), m_page, m_pages, m_book );
|
||||||
|
drawText( IDENTITY, renderer, guiLeft + X_TEXT_MARGIN, guiTop + Y_TEXT_MARGIN, ItemPrintout.LINES_PER_PAGE * m_page, m_text, m_colours );
|
||||||
|
renderer.finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -52,13 +52,16 @@ public abstract class ItemMapLikeRenderer
|
|||||||
/**
|
/**
|
||||||
* Renders the item to one side of the player.
|
* Renders the item to one side of the player.
|
||||||
*
|
*
|
||||||
|
* @param transform The matrix transformation stack
|
||||||
|
* @param render The buffer to render to
|
||||||
|
* @param combinedLight The current light level
|
||||||
* @param side The side to render on
|
* @param side The side to render on
|
||||||
* @param equipProgress The equip progress of this item
|
* @param equipProgress The equip progress of this item
|
||||||
* @param swingProgress The swing progress of this item
|
* @param swingProgress The swing progress of this item
|
||||||
* @param stack The stack to render
|
* @param stack The stack to render
|
||||||
* @see FirstPersonRenderer#renderMapFirstPersonSide(MatrixStack, IRenderTypeBuffer, int, float, HandSide, float, ItemStack)
|
* @see FirstPersonRenderer#renderMapFirstPersonSide(MatrixStack, IRenderTypeBuffer, int, float, HandSide, float, ItemStack)
|
||||||
*/
|
*/
|
||||||
private void renderItemFirstPersonSide( MatrixStack transform, IRenderTypeBuffer render, int lightTexture, HandSide side, float equipProgress, float swingProgress, ItemStack stack )
|
private void renderItemFirstPersonSide( MatrixStack transform, IRenderTypeBuffer render, int combinedLight, HandSide side, float equipProgress, float swingProgress, ItemStack stack )
|
||||||
{
|
{
|
||||||
Minecraft minecraft = Minecraft.getInstance();
|
Minecraft minecraft = Minecraft.getInstance();
|
||||||
float offset = side == HandSide.RIGHT ? 1f : -1f;
|
float offset = side == HandSide.RIGHT ? 1f : -1f;
|
||||||
@ -68,8 +71,8 @@ public abstract class ItemMapLikeRenderer
|
|||||||
if( !minecraft.player.isInvisible() )
|
if( !minecraft.player.isInvisible() )
|
||||||
{
|
{
|
||||||
transform.push();
|
transform.push();
|
||||||
transform.rotate( Vector3f.field_229183_f_.func_229187_a_( offset * 10f ) );
|
transform.rotate( Vector3f.ZP.rotationDegrees( offset * 10f ) );
|
||||||
minecraft.getFirstPersonRenderer().renderArmFirstPerson( transform, render, lightTexture, equipProgress, swingProgress, side );
|
minecraft.getFirstPersonRenderer().renderArmFirstPerson( transform, render, combinedLight, equipProgress, swingProgress, side );
|
||||||
transform.pop();
|
transform.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,8 +86,8 @@ public abstract class ItemMapLikeRenderer
|
|||||||
float f4 = 0.4f * MathHelper.sin( f1 * ((float) Math.PI * 2f) );
|
float f4 = 0.4f * MathHelper.sin( f1 * ((float) Math.PI * 2f) );
|
||||||
float f5 = -0.3f * MathHelper.sin( swingProgress * (float) Math.PI );
|
float f5 = -0.3f * MathHelper.sin( swingProgress * (float) Math.PI );
|
||||||
transform.translate( offset * f3, f4 - 0.3f * f2, f5 );
|
transform.translate( offset * f3, f4 - 0.3f * f2, f5 );
|
||||||
transform.rotate( Vector3f.field_229179_b_.func_229187_a_( f2 * -45f ) );
|
transform.rotate( Vector3f.XP.rotationDegrees( f2 * -45f ) );
|
||||||
transform.rotate( Vector3f.field_229181_d_.func_229187_a_( offset * f2 * -30f ) );
|
transform.rotate( Vector3f.YP.rotationDegrees( offset * f2 * -30f ) );
|
||||||
|
|
||||||
renderItem( transform, render, stack );
|
renderItem( transform, render, stack );
|
||||||
|
|
||||||
@ -94,13 +97,16 @@ public abstract class ItemMapLikeRenderer
|
|||||||
/**
|
/**
|
||||||
* Render an item in the middle of the screen.
|
* Render an item in the middle of the screen.
|
||||||
*
|
*
|
||||||
|
* @param transform The matrix transformation stack
|
||||||
|
* @param render The buffer to render to
|
||||||
|
* @param combinedLight The current light level
|
||||||
* @param pitch The pitch of the player
|
* @param pitch The pitch of the player
|
||||||
* @param equipProgress The equip progress of this item
|
* @param equipProgress The equip progress of this item
|
||||||
* @param swingProgress The swing progress of this item
|
* @param swingProgress The swing progress of this item
|
||||||
* @param stack The stack to render
|
* @param stack The stack to render
|
||||||
* @see FirstPersonRenderer#renderMapFirstPerson(MatrixStack, IRenderTypeBuffer, int, float, float, float)
|
* @see FirstPersonRenderer#renderMapFirstPerson(MatrixStack, IRenderTypeBuffer, int, float, float, float)
|
||||||
*/
|
*/
|
||||||
private void renderItemFirstPersonCenter( MatrixStack transform, IRenderTypeBuffer render, int lightTexture, float pitch, float equipProgress, float swingProgress, ItemStack stack )
|
private void renderItemFirstPersonCenter( MatrixStack transform, IRenderTypeBuffer render, int combinedLight, float pitch, float equipProgress, float swingProgress, ItemStack stack )
|
||||||
{
|
{
|
||||||
Minecraft minecraft = Minecraft.getInstance();
|
Minecraft minecraft = Minecraft.getInstance();
|
||||||
FirstPersonRenderer renderer = minecraft.getFirstPersonRenderer();
|
FirstPersonRenderer renderer = minecraft.getFirstPersonRenderer();
|
||||||
@ -114,18 +120,18 @@ public abstract class ItemMapLikeRenderer
|
|||||||
|
|
||||||
float pitchAngle = renderer.getMapAngleFromPitch( pitch );
|
float pitchAngle = renderer.getMapAngleFromPitch( pitch );
|
||||||
transform.translate( 0, 0.04F + equipProgress * -1.2f + pitchAngle * -0.5f, -0.72f );
|
transform.translate( 0, 0.04F + equipProgress * -1.2f + pitchAngle * -0.5f, -0.72f );
|
||||||
transform.rotate( Vector3f.field_229179_b_.func_229187_a_( pitchAngle * -85.0f ) );
|
transform.rotate( Vector3f.XP.rotationDegrees( pitchAngle * -85.0f ) );
|
||||||
if( !minecraft.player.isInvisible() )
|
if( !minecraft.player.isInvisible() )
|
||||||
{
|
{
|
||||||
transform.push();
|
transform.push();
|
||||||
transform.rotate( Vector3f.field_229181_d_.func_229187_a_( 90.0F ) );
|
transform.rotate( Vector3f.YP.rotationDegrees( 90.0F ) );
|
||||||
renderer.renderArm( transform, render, lightTexture, HandSide.RIGHT );
|
renderer.renderArm( transform, render, combinedLight, HandSide.RIGHT );
|
||||||
renderer.renderArm( transform, render, lightTexture, HandSide.LEFT );
|
renderer.renderArm( transform, render, combinedLight, HandSide.LEFT );
|
||||||
transform.pop();
|
transform.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
float rX = MathHelper.sin( swingRt * (float) Math.PI );
|
float rX = MathHelper.sin( swingRt * (float) Math.PI );
|
||||||
transform.rotate( Vector3f.field_229179_b_.func_229187_a_( rX * 20.0F ) );
|
transform.rotate( Vector3f.XP.rotationDegrees( rX * 20.0F ) );
|
||||||
transform.scale( 2.0F, 2.0F, 2.0F );
|
transform.scale( 2.0F, 2.0F, 2.0F );
|
||||||
|
|
||||||
renderItem( transform, render, stack );
|
renderItem( transform, render, stack );
|
@ -5,13 +5,16 @@
|
|||||||
*/
|
*/
|
||||||
package dan200.computercraft.client.render;
|
package dan200.computercraft.client.render;
|
||||||
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.matrix.MatrixStack;
|
||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.shared.media.items.ItemPrintout;
|
import dan200.computercraft.shared.media.items.ItemPrintout;
|
||||||
|
import net.minecraft.client.renderer.IRenderTypeBuffer;
|
||||||
|
import net.minecraft.client.renderer.Matrix4f;
|
||||||
|
import net.minecraft.client.renderer.Vector3f;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
import net.minecraftforge.client.event.RenderHandEvent;
|
||||||
import net.minecraftforge.client.event.RenderItemInFrameEvent;
|
import net.minecraftforge.client.event.RenderItemInFrameEvent;
|
||||||
import net.minecraftforge.client.event.RenderSpecificHandEvent;
|
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.common.Mod;
|
import net.minecraftforge.fml.common.Mod;
|
||||||
|
|
||||||
@ -33,31 +36,28 @@ public final class ItemPrintoutRenderer extends ItemMapLikeRenderer
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
// TODO: @SubscribeEvent
|
||||||
public static void onRenderInHand( RenderSpecificHandEvent event )
|
public static void onRenderInHand( RenderHandEvent event )
|
||||||
{
|
{
|
||||||
ItemStack stack = event.getItemStack();
|
ItemStack stack = event.getItemStack();
|
||||||
if( !(stack.getItem() instanceof ItemPrintout) ) return;
|
if( !(stack.getItem() instanceof ItemPrintout) ) return;
|
||||||
|
|
||||||
event.setCanceled( true );
|
event.setCanceled( true );
|
||||||
INSTANCE.renderItemFirstPerson( event.getHand(), event.getInterpolatedPitch(), event.getEquipProgress(), event.getSwingProgress(), event.getItemStack() );
|
INSTANCE.renderItemFirstPerson(
|
||||||
|
event.getMatrixStack(), event.getBuffers(), event.getLight(),
|
||||||
|
event.getHand(), event.getInterpolatedPitch(), event.getEquipProgress(), event.getSwingProgress(), event.getItemStack()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void renderItem( ItemStack stack )
|
protected void renderItem( MatrixStack transform, IRenderTypeBuffer render, ItemStack stack )
|
||||||
{
|
{
|
||||||
// Setup various transformations. Note that these are partially adapated from the corresponding method
|
transform.rotate( Vector3f.XP.rotationDegrees( 180f ) );
|
||||||
// in FirstPersonRenderer.renderFirstPersonMap
|
transform.rotate( Vector3f.ZP.rotationDegrees( 180f ) );
|
||||||
RenderSystem.disableLighting();
|
transform.scale( 0.42f, 0.42f, -0.42f );
|
||||||
|
transform.translate( -0.5f, -0.48f, 0.0f );
|
||||||
|
|
||||||
RenderSystem.rotatef( 180f, 0f, 1f, 0f );
|
drawPrintout( transform, render, stack );
|
||||||
RenderSystem.rotatef( 180f, 0f, 0f, 1f );
|
|
||||||
RenderSystem.scalef( 0.42f, 0.42f, -0.42f );
|
|
||||||
RenderSystem.translatef( -0.5f, -0.48f, 0.0f );
|
|
||||||
|
|
||||||
drawPrintout( stack );
|
|
||||||
|
|
||||||
RenderSystem.enableLighting();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
@ -65,24 +65,20 @@ public final class ItemPrintoutRenderer extends ItemMapLikeRenderer
|
|||||||
{
|
{
|
||||||
ItemStack stack = event.getItem();
|
ItemStack stack = event.getItem();
|
||||||
if( !(stack.getItem() instanceof ItemPrintout) ) return;
|
if( !(stack.getItem() instanceof ItemPrintout) ) return;
|
||||||
|
|
||||||
event.setCanceled( true );
|
event.setCanceled( true );
|
||||||
|
|
||||||
RenderSystem.disableLighting();
|
MatrixStack transform = event.getMatrix();
|
||||||
|
|
||||||
// Move a little bit forward to ensure we're not clipping with the frame
|
// Move a little bit forward to ensure we're not clipping with the frame
|
||||||
RenderSystem.translatef( 0.0f, 0.0f, -0.001f );
|
transform.translate( 0.0f, 0.0f, -0.001f );
|
||||||
RenderSystem.rotatef( 180f, 0f, 0f, 1f );
|
transform.rotate( Vector3f.ZP.rotationDegrees( 180f ) );
|
||||||
RenderSystem.scalef( 0.95f, 0.95f, -0.95f );
|
transform.scale( 0.95f, 0.95f, -0.95f );
|
||||||
RenderSystem.translatef( -0.5f, -0.5f, 0.0f );
|
transform.translate( -0.5f, -0.5f, 0.0f );
|
||||||
|
|
||||||
drawPrintout( stack );
|
drawPrintout( transform, event.getBuffers(), stack );
|
||||||
|
|
||||||
RenderSystem.enableLighting();
|
|
||||||
RenderSystem.disableBlend();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawPrintout( ItemStack stack )
|
private static void drawPrintout( MatrixStack transform, IRenderTypeBuffer render, ItemStack stack )
|
||||||
{
|
{
|
||||||
int pages = ItemPrintout.getPageCount( stack );
|
int pages = ItemPrintout.getPageCount( stack );
|
||||||
boolean book = ((ItemPrintout) stack.getItem()).getType() == ItemPrintout.Type.BOOK;
|
boolean book = ((ItemPrintout) stack.getItem()).getType() == ItemPrintout.Type.BOOK;
|
||||||
@ -105,11 +101,14 @@ public final class ItemPrintoutRenderer extends ItemMapLikeRenderer
|
|||||||
double max = Math.max( visualHeight, visualWidth );
|
double max = Math.max( visualHeight, visualWidth );
|
||||||
|
|
||||||
// Scale the printout to fit correctly.
|
// Scale the printout to fit correctly.
|
||||||
double scale = 1.0 / max;
|
float scale = (float) (1.0 / max);
|
||||||
RenderSystem.scaled( scale, scale, scale );
|
transform.scale( scale, scale, scale );
|
||||||
RenderSystem.translated( (max - width) / 2.0, (max - height) / 2.0, 0.0 );
|
transform.translate( (max - width) / 2.0, (max - height) / 2.0, 0.0 );
|
||||||
|
|
||||||
drawBorder( 0, 0, -0.01, 0, pages, book );
|
Matrix4f matrix = transform.getLast().getPositionMatrix();
|
||||||
drawText( X_TEXT_MARGIN, Y_TEXT_MARGIN, 0, ItemPrintout.getText( stack ), ItemPrintout.getColours( stack ) );
|
drawBorder( matrix, render, 0, 0, -0.01f, 0, pages, book );
|
||||||
|
drawText( matrix, render,
|
||||||
|
X_TEXT_MARGIN, Y_TEXT_MARGIN, 0, ItemPrintout.getText( stack ), ItemPrintout.getColours( stack )
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -5,15 +5,14 @@
|
|||||||
*/
|
*/
|
||||||
package dan200.computercraft.client.render;
|
package dan200.computercraft.client.render;
|
||||||
|
|
||||||
import com.mojang.blaze3d.platform.GlStateManager.DestFactor;
|
import com.mojang.blaze3d.vertex.IVertexBuilder;
|
||||||
import com.mojang.blaze3d.platform.GlStateManager.SourceFactor;
|
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
|
||||||
import dan200.computercraft.client.gui.FixedWidthFontRenderer;
|
import dan200.computercraft.client.gui.FixedWidthFontRenderer;
|
||||||
import dan200.computercraft.core.terminal.TextBuffer;
|
import dan200.computercraft.core.terminal.TextBuffer;
|
||||||
import dan200.computercraft.shared.util.Palette;
|
import dan200.computercraft.shared.util.Palette;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.renderer.IRenderTypeBuffer;
|
||||||
import net.minecraft.client.renderer.BufferBuilder;
|
import net.minecraft.client.renderer.Matrix4f;
|
||||||
import net.minecraft.client.renderer.Tessellator;
|
import net.minecraft.client.renderer.RenderState;
|
||||||
|
import net.minecraft.client.renderer.RenderType;
|
||||||
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
|
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import org.lwjgl.opengl.GL11;
|
import org.lwjgl.opengl.GL11;
|
||||||
@ -61,66 +60,71 @@ public final class PrintoutRenderer
|
|||||||
|
|
||||||
private PrintoutRenderer() {}
|
private PrintoutRenderer() {}
|
||||||
|
|
||||||
public static void drawText( int x, int y, int start, TextBuffer[] text, TextBuffer[] colours )
|
public static void drawText( Matrix4f transform, IRenderTypeBuffer renderer, int x, int y, int start, TextBuffer[] text, TextBuffer[] colours )
|
||||||
{
|
{
|
||||||
|
IVertexBuilder buffer = renderer.getBuffer( FixedWidthFontRenderer.TYPE );
|
||||||
for( int line = 0; line < LINES_PER_PAGE && line < text.length; line++ )
|
for( int line = 0; line < LINES_PER_PAGE && line < text.length; line++ )
|
||||||
{
|
{
|
||||||
FixedWidthFontRenderer.drawString(
|
FixedWidthFontRenderer.drawString( transform, buffer,
|
||||||
x, y + line * FONT_HEIGHT, text[start + line], colours[start + line], null, Palette.DEFAULT,
|
x, y + line * FONT_HEIGHT, text[start + line], colours[start + line], null, Palette.DEFAULT,
|
||||||
false, 0, 0
|
false, 0, 0
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void drawBorder( double x, double y, double z, int page, int pages, boolean isBook )
|
public static void drawText( Matrix4f transform, IRenderTypeBuffer renderer, int x, int y, int start, String[] text, String[] colours )
|
||||||
{
|
{
|
||||||
RenderSystem.color4f( 1.0f, 1.0f, 1.0f, 1.0f );
|
IVertexBuilder buffer = renderer.getBuffer( FixedWidthFontRenderer.TYPE );
|
||||||
RenderSystem.enableBlend();
|
for( int line = 0; line < LINES_PER_PAGE && line < text.length; line++ )
|
||||||
RenderSystem.enableTexture();
|
{
|
||||||
RenderSystem.blendFuncSeparate( SourceFactor.SRC_ALPHA, DestFactor.ONE_MINUS_SRC_ALPHA, SourceFactor.ONE, DestFactor.ZERO );
|
FixedWidthFontRenderer.drawString( transform, buffer,
|
||||||
|
x, y + line * FONT_HEIGHT,
|
||||||
Minecraft.getInstance().getTextureManager().bindTexture( BG );
|
new TextBuffer( text[start + line] ), new TextBuffer( colours[start + line] ),
|
||||||
|
null, Palette.DEFAULT, false, 0, 0
|
||||||
Tessellator tessellator = Tessellator.getInstance();
|
);
|
||||||
BufferBuilder buffer = tessellator.getBuffer();
|
}
|
||||||
buffer.begin( GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX );
|
}
|
||||||
|
|
||||||
|
public static void drawBorder( Matrix4f transform, IRenderTypeBuffer renderer, float x, float y, float z, int page, int pages, boolean isBook )
|
||||||
|
{
|
||||||
int leftPages = page;
|
int leftPages = page;
|
||||||
int rightPages = pages - page - 1;
|
int rightPages = pages - page - 1;
|
||||||
|
|
||||||
|
IVertexBuilder buffer = renderer.getBuffer( Type.TYPE );
|
||||||
|
|
||||||
if( isBook )
|
if( isBook )
|
||||||
{
|
{
|
||||||
// Border
|
// Border
|
||||||
double offset = offsetAt( pages );
|
float offset = offsetAt( pages );
|
||||||
final double left = x - 4 - offset;
|
float left = x - 4 - offset;
|
||||||
final double right = x + X_SIZE + offset - 4;
|
float right = x + X_SIZE + offset - 4;
|
||||||
|
|
||||||
// Left and right border
|
// Left and right border
|
||||||
drawTexture( buffer, left - 4, y - 8, z - 0.02, COVER_X, 0, COVER_SIZE, Y_SIZE + COVER_SIZE * 2 );
|
drawTexture( transform, buffer, left - 4, y - 8, z - 0.02f, COVER_X, 0, COVER_SIZE, Y_SIZE + COVER_SIZE * 2 );
|
||||||
drawTexture( buffer, right, y - 8, z - 0.02, COVER_X + COVER_SIZE, 0, COVER_SIZE, Y_SIZE + COVER_SIZE * 2 );
|
drawTexture( transform, buffer, right, y - 8, z - 0.02f, COVER_X + COVER_SIZE, 0, COVER_SIZE, Y_SIZE + COVER_SIZE * 2 );
|
||||||
|
|
||||||
// Draw centre panel (just stretched texture, sorry).
|
// Draw centre panel (just stretched texture, sorry).
|
||||||
drawTexture( buffer,
|
drawTexture( transform, buffer,
|
||||||
x - offset, y, z - 0.02, X_SIZE + offset * 2, Y_SIZE,
|
x - offset, y, z - 0.02f, X_SIZE + offset * 2, Y_SIZE,
|
||||||
COVER_X + COVER_SIZE / 2.0f, COVER_SIZE, COVER_SIZE, Y_SIZE
|
COVER_X + COVER_SIZE / 2.0f, COVER_SIZE, COVER_SIZE, Y_SIZE
|
||||||
);
|
);
|
||||||
|
|
||||||
double borderX = left;
|
float borderX = left;
|
||||||
while( borderX < right )
|
while( borderX < right )
|
||||||
{
|
{
|
||||||
double thisWidth = Math.min( right - borderX, X_SIZE );
|
double thisWidth = Math.min( right - borderX, X_SIZE );
|
||||||
drawTexture( buffer, borderX, y - 8, z - 0.02, 0, COVER_Y, (float) thisWidth, COVER_SIZE );
|
drawTexture( transform, buffer, borderX, y - 8, z - 0.02f, 0, COVER_Y, (float) thisWidth, COVER_SIZE );
|
||||||
drawTexture( buffer, borderX, y + Y_SIZE - 4, z - 0.02, 0, COVER_Y + COVER_SIZE, (float) thisWidth, COVER_SIZE );
|
drawTexture( transform, buffer, borderX, y + Y_SIZE - 4, z - 0.02f, 0, COVER_Y + COVER_SIZE, (float) thisWidth, COVER_SIZE );
|
||||||
borderX += thisWidth;
|
borderX += thisWidth;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Left half
|
// Left half
|
||||||
drawTexture( buffer, x, y, z, X_FOLD_SIZE * 2, 0, X_SIZE / 2.0f, Y_SIZE );
|
drawTexture( transform, buffer, x, y, z, X_FOLD_SIZE * 2, 0, X_SIZE / 2.0f, Y_SIZE );
|
||||||
for( int n = 0; n <= leftPages; n++ )
|
for( int n = 0; n <= leftPages; n++ )
|
||||||
{
|
{
|
||||||
drawTexture( buffer,
|
drawTexture( transform, buffer,
|
||||||
x - offsetAt( n ), y, z - 1e-3 * n,
|
x - offsetAt( n ), y, z - 1e-3f * n,
|
||||||
// Use the left "bold" fold for the outermost page
|
// Use the left "bold" fold for the outermost page
|
||||||
n == leftPages ? 0 : X_FOLD_SIZE, 0,
|
n == leftPages ? 0 : X_FOLD_SIZE, 0,
|
||||||
X_FOLD_SIZE, Y_SIZE
|
X_FOLD_SIZE, Y_SIZE
|
||||||
@ -128,38 +132,54 @@ public final class PrintoutRenderer
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Right half
|
// Right half
|
||||||
drawTexture( buffer, x + X_SIZE / 2.0f, y, z, X_FOLD_SIZE * 2 + X_SIZE / 2.0f, 0, X_SIZE / 2.0f, Y_SIZE );
|
drawTexture( transform, buffer, x + X_SIZE / 2.0f, y, z, X_FOLD_SIZE * 2 + X_SIZE / 2.0f, 0, X_SIZE / 2.0f, Y_SIZE );
|
||||||
for( int n = 0; n <= rightPages; n++ )
|
for( int n = 0; n <= rightPages; n++ )
|
||||||
{
|
{
|
||||||
drawTexture( buffer,
|
drawTexture( transform, buffer,
|
||||||
x + (X_SIZE - X_FOLD_SIZE) + offsetAt( n ), y, z - 1e-3 * n,
|
x + (X_SIZE - X_FOLD_SIZE) + offsetAt( n ), y, z - 1e-3f * n,
|
||||||
// Two folds, then the main page. Use the right "bold" fold for the outermost page.
|
// Two folds, then the main page. Use the right "bold" fold for the outermost page.
|
||||||
X_FOLD_SIZE * 2 + X_SIZE + (n == rightPages ? X_FOLD_SIZE : 0), 0,
|
X_FOLD_SIZE * 2 + X_SIZE + (n == rightPages ? X_FOLD_SIZE : 0), 0,
|
||||||
X_FOLD_SIZE, Y_SIZE
|
X_FOLD_SIZE, Y_SIZE
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
tessellator.draw();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawTexture( BufferBuilder buffer, double x, double y, double z, float u, float v, float width, float height )
|
private static void drawTexture( Matrix4f matrix, IVertexBuilder buffer, float x, float y, float z, float u, float v, float width, float height )
|
||||||
{
|
{
|
||||||
buffer.pos( x, y + height, z ).tex( u / BG_SIZE, (v + height) / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x, y + height, z ).tex( u / BG_SIZE, (v + height) / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x + width, y + height, z ).tex( (u + width) / BG_SIZE, (v + height) / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x + width, y + height, z ).tex( (u + width) / BG_SIZE, (v + height) / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x + width, y, z ).tex( (u + width) / BG_SIZE, v / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x + width, y, z ).tex( (u + width) / BG_SIZE, v / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x, y, z ).tex( u / BG_SIZE, v / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x, y, z ).tex( u / BG_SIZE, v / BG_SIZE ).endVertex();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawTexture( BufferBuilder buffer, double x, double y, double z, double width, double height, float u, float v, float tWidth, float tHeight )
|
private static void drawTexture( Matrix4f matrix, IVertexBuilder buffer, float x, float y, float z, float width, float height, float u, float v, float tWidth, float tHeight )
|
||||||
{
|
{
|
||||||
buffer.pos( x, y + height, z ).tex( u / BG_SIZE, (v + tHeight) / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x, y + height, z ).tex( u / BG_SIZE, (v + tHeight) / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x + width, y + height, z ).tex( (u + tWidth) / BG_SIZE, (v + tHeight) / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x + width, y + height, z ).tex( (u + tWidth) / BG_SIZE, (v + tHeight) / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x + width, y, z ).tex( (u + tWidth) / BG_SIZE, v / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x + width, y, z ).tex( (u + tWidth) / BG_SIZE, v / BG_SIZE ).endVertex();
|
||||||
buffer.pos( x, y, z ).tex( u / BG_SIZE, v / BG_SIZE ).endVertex();
|
buffer.pos( matrix, x, y, z ).tex( u / BG_SIZE, v / BG_SIZE ).endVertex();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static double offsetAt( int page )
|
public static float offsetAt( int page )
|
||||||
{
|
{
|
||||||
return 32 * (1 - Math.pow( 1.2, -page ));
|
return (float) (32 * (1 - Math.pow( 1.2, -page )));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final class Type extends RenderState
|
||||||
|
{
|
||||||
|
static final RenderType TYPE = RenderType.get(
|
||||||
|
"printout_background", DefaultVertexFormats.POSITION_TEX, GL11.GL_QUADS, 1024,
|
||||||
|
false, false, // useDelegate, needsSorting
|
||||||
|
RenderType.State.builder()
|
||||||
|
.texture( new RenderState.TextureState( BG, false, false ) ) // blur, minimap
|
||||||
|
.alpha( DEFAULT_ALPHA )
|
||||||
|
.lightmap( LIGHTMAP_DISABLED )
|
||||||
|
.build( false )
|
||||||
|
);
|
||||||
|
|
||||||
|
private Type( String name, Runnable setup, Runnable destroy )
|
||||||
|
{
|
||||||
|
super( name, setup, destroy );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -103,28 +103,14 @@ public final class RecipeUtil
|
|||||||
return new ShapedTemplate( width, height, ingredients );
|
return new ShapedTemplate( width, height, ingredients );
|
||||||
}
|
}
|
||||||
|
|
||||||
public static NonNullList<Ingredient> getIngredients( JsonObject json )
|
|
||||||
{
|
|
||||||
NonNullList<Ingredient> ingredients = NonNullList.create();
|
|
||||||
for( JsonElement ele : JSONUtils.getJsonArray( json, "ingredients" ) )
|
|
||||||
{
|
|
||||||
ingredients.add( Ingredient.deserialize( ele ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
if( ingredients.isEmpty() ) throw new JsonParseException( "No ingredients for recipe" );
|
|
||||||
return ingredients;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static ComputerFamily getFamily( JsonObject json, String name )
|
public static ComputerFamily getFamily( JsonObject json, String name )
|
||||||
{
|
{
|
||||||
String familyName = JSONUtils.getString( json, name );
|
String familyName = JSONUtils.getString( json, name );
|
||||||
try
|
for( ComputerFamily family : ComputerFamily.values() )
|
||||||
{
|
{
|
||||||
return ComputerFamily.valueOf( familyName );
|
if( family.name().equalsIgnoreCase( familyName ) ) return family;
|
||||||
}
|
|
||||||
catch( IllegalArgumentException e )
|
|
||||||
{
|
|
||||||
throw new JsonSyntaxException( "Unknown computer family '" + familyName + "' for field " + name );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
throw new JsonSyntaxException( "Unknown computer family '" + familyName + "' for field " + name );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,6 @@
|
|||||||
"#": { "tag": "forge:ingots/gold" },
|
"#": { "tag": "forge:ingots/gold" },
|
||||||
"C": { "item": "computercraft:computer_normal" }
|
"C": { "item": "computercraft:computer_normal" }
|
||||||
},
|
},
|
||||||
"family": "Advanced",
|
"family": "advanced",
|
||||||
"result": { "item": "computercraft:computer_advanced" }
|
"result": { "item": "computercraft:computer_advanced" }
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,6 @@
|
|||||||
"#": { "tag": "forge:ingots/gold" },
|
"#": { "tag": "forge:ingots/gold" },
|
||||||
"C": { "item": "computercraft:pocket_computer_normal" }
|
"C": { "item": "computercraft:pocket_computer_normal" }
|
||||||
},
|
},
|
||||||
"family": "Advanced",
|
"family": "advanced",
|
||||||
"result": { "item": "computercraft:pocket_computer_advanced" }
|
"result": { "item": "computercraft:pocket_computer_advanced" }
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,6 @@
|
|||||||
"C": { "item": "computercraft:computer_advanced" },
|
"C": { "item": "computercraft:computer_advanced" },
|
||||||
"I": { "tag": "forge:chests/wooden" }
|
"I": { "tag": "forge:chests/wooden" }
|
||||||
},
|
},
|
||||||
"family": "Advanced",
|
"family": "advanced",
|
||||||
"result": { "item": "computercraft:turtle_advanced" }
|
"result": { "item": "computercraft:turtle_advanced" }
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,6 @@
|
|||||||
"B": { "tag": "forge:storage_blocks/gold" },
|
"B": { "tag": "forge:storage_blocks/gold" },
|
||||||
"C": { "item": "computercraft:turtle_normal" }
|
"C": { "item": "computercraft:turtle_normal" }
|
||||||
},
|
},
|
||||||
"family": "Advanced",
|
"family": "advanced",
|
||||||
"result": { "item": "computercraft:turtle_advanced" }
|
"result": { "item": "computercraft:turtle_advanced" }
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,6 @@
|
|||||||
"C": { "item": "computercraft:computer_normal" },
|
"C": { "item": "computercraft:computer_normal" },
|
||||||
"I": { "tag": "forge:chests/wooden" }
|
"I": { "tag": "forge:chests/wooden" }
|
||||||
},
|
},
|
||||||
"family": "Normal",
|
"family": "normal",
|
||||||
"result": { "item": "computercraft:turtle_normal" }
|
"result": { "item": "computercraft:turtle_normal" }
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user