Made the game sorta playable :>
Fixed various crashes, fixed lighting and water, made the world actually render
This commit is contained in:
parent
363efd4066
commit
1153220af2
|
@ -437,12 +437,14 @@ public class EaglerAdapterGL30 extends EaglerAdapterImpl2 {
|
||||||
lightPos1vec.normalise();
|
lightPos1vec.normalise();
|
||||||
Matrix4f.transform(matModelV[matModelPointer], lightPos0vec, lightPos0vec).normalise();
|
Matrix4f.transform(matModelV[matModelPointer], lightPos0vec, lightPos0vec).normalise();
|
||||||
Matrix4f.transform(matModelV[matModelPointer], lightPos1vec, lightPos1vec).normalise();
|
Matrix4f.transform(matModelV[matModelPointer], lightPos1vec, lightPos1vec).normalise();
|
||||||
lightPos0vec.x = -lightPos0vec.x;
|
|
||||||
lightPos1vec.x = -lightPos1vec.x;
|
//Maybe NOT flip light matrix???
|
||||||
lightPos0vec.y = -lightPos0vec.y;
|
lightPos0vec.x = lightPos0vec.x;
|
||||||
lightPos1vec.y = -lightPos1vec.y;
|
lightPos1vec.x = lightPos1vec.x;
|
||||||
lightPos0vec.z = -lightPos0vec.z;
|
lightPos0vec.y = lightPos0vec.y;
|
||||||
lightPos1vec.z = -lightPos1vec.z;
|
lightPos1vec.y = lightPos1vec.y;
|
||||||
|
lightPos0vec.z = lightPos0vec.z;
|
||||||
|
lightPos1vec.z = lightPos1vec.z;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final void revertLightMatrix() {
|
public static final void revertLightMatrix() {
|
||||||
|
|
|
@ -162,9 +162,6 @@ public class EaglerAdapterImpl2 {
|
||||||
@JSBody(params = { "v", "s" }, script = "window[v] = s;")
|
@JSBody(params = { "v", "s" }, script = "window[v] = s;")
|
||||||
public static native void setDebugVar(String v, String s);
|
public static native void setDebugVar(String v, String s);
|
||||||
|
|
||||||
@JSBody(params = { }, script = "if(window.navigator.userActivation){return window.navigator.userActivation.hasBeenActive;}else{return false;}")
|
|
||||||
public static native boolean hasBeenActive();
|
|
||||||
|
|
||||||
public static HTMLDocument doc = null;
|
public static HTMLDocument doc = null;
|
||||||
public static HTMLElement parent = null;
|
public static HTMLElement parent = null;
|
||||||
public static HTMLCanvasElement canvas = null;
|
public static HTMLCanvasElement canvas = null;
|
||||||
|
|
|
@ -398,10 +398,6 @@ public class Minecraft implements Runnable {
|
||||||
|
|
||||||
while(this.running) {
|
while(this.running) {
|
||||||
try {
|
try {
|
||||||
if(!GL11.hasBeenActive()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
AxisAlignedBB.clearBoundingBoxPool();
|
AxisAlignedBB.clearBoundingBoxPool();
|
||||||
Vec3D.initialize();
|
Vec3D.initialize();
|
||||||
|
|
||||||
|
@ -450,7 +446,7 @@ public class Minecraft implements Runnable {
|
||||||
this.entityRenderer.updateCameraAndRender(this.timer.renderPartialTicks);
|
this.entityRenderer.updateCameraAndRender(this.timer.renderPartialTicks);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!GL11.hasBeenActive()) {
|
if(!GL11.isFocused()) {
|
||||||
Thread.sleep(10L);
|
Thread.sleep(10L);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -610,7 +606,7 @@ public class Minecraft implements Runnable {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setIngameFocus() {
|
public void setIngameFocus() {
|
||||||
if(GL11.hasBeenActive()) {
|
if(GL11.isFocused()) {
|
||||||
if(!this.inGameHasFocus) {
|
if(!this.inGameHasFocus) {
|
||||||
this.inGameHasFocus = true;
|
this.inGameHasFocus = true;
|
||||||
this.mouseHelper.grabMouseCursor();
|
this.mouseHelper.grabMouseCursor();
|
||||||
|
|
|
@ -5,13 +5,15 @@ import java.io.InputStreamReader;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
public class AchievementMap {
|
public class AchievementMap {
|
||||||
public static AchievementMap instance = new AchievementMap();
|
public static AchievementMap instance = new AchievementMap();
|
||||||
private Map guidMap = new HashMap();
|
private Map guidMap = new HashMap();
|
||||||
|
|
||||||
private AchievementMap() {
|
private AchievementMap() {
|
||||||
try {
|
try {
|
||||||
BufferedReader var1 = new BufferedReader(new InputStreamReader(AchievementMap.class.getResourceAsStream("/achievement/map.txt")));
|
BufferedReader var1 = new BufferedReader(new InputStreamReader(GL11.getResourceAsStream("/achievement/map.txt")));
|
||||||
|
|
||||||
while(true) {
|
while(true) {
|
||||||
String var2 = var1.readLine();
|
String var2 = var1.readLine();
|
||||||
|
|
|
@ -3,6 +3,8 @@ package net.minecraft.src;
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
|
|
||||||
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
public class ChatAllowedCharacters {
|
public class ChatAllowedCharacters {
|
||||||
public static final String allowedCharacters = getAllowedCharacters();
|
public static final String allowedCharacters = getAllowedCharacters();
|
||||||
public static final char[] allowedCharactersArray = new char[]{'/', '\n', '\r', '\t', '\u0000', '\f', '`', '?', '*', '\\', '<', '>', '|', '\"', ':'};
|
public static final char[] allowedCharactersArray = new char[]{'/', '\n', '\r', '\t', '\u0000', '\f', '`', '?', '*', '\\', '<', '>', '|', '\"', ':'};
|
||||||
|
@ -11,7 +13,7 @@ public class ChatAllowedCharacters {
|
||||||
String var0 = "";
|
String var0 = "";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
BufferedReader var1 = new BufferedReader(new InputStreamReader(ChatAllowedCharacters.class.getResourceAsStream("/font.txt"), "UTF-8"));
|
BufferedReader var1 = new BufferedReader(new InputStreamReader(GL11.getResourceAsStream("/font.txt"), "UTF-8"));
|
||||||
String var2 = "";
|
String var2 = "";
|
||||||
|
|
||||||
while(true) {
|
while(true) {
|
||||||
|
|
|
@ -324,7 +324,7 @@ public class EntityRenderer {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateCameraAndRender(float var1) {
|
public void updateCameraAndRender(float var1) {
|
||||||
if(!GL11.hasBeenActive()) {
|
if(!GL11.isPointerLocked2()) {
|
||||||
if(System.currentTimeMillis() - this.prevFrameTime > 500L) {
|
if(System.currentTimeMillis() - this.prevFrameTime > 500L) {
|
||||||
this.mc.displayInGameMenu();
|
this.mc.displayInGameMenu();
|
||||||
}
|
}
|
||||||
|
@ -510,25 +510,27 @@ public class EntityRenderer {
|
||||||
GL11.glEnable(GL11.GL_BLEND);
|
GL11.glEnable(GL11.GL_BLEND);
|
||||||
GL11.glDisable(GL11.GL_CULL_FACE);
|
GL11.glDisable(GL11.GL_CULL_FACE);
|
||||||
GL11.glBindTexture(GL11.GL_TEXTURE_2D, this.mc.renderEngine.getTexture("/terrain.png"));
|
GL11.glBindTexture(GL11.GL_TEXTURE_2D, this.mc.renderEngine.getTexture("/terrain.png"));
|
||||||
if(this.mc.gameSettings.fancyGraphics) {
|
//TODO: Find out why water is broken
|
||||||
GL11.glColorMask(false, false, false, false);
|
|
||||||
var16 = var5.sortAndRender(var4, 1, (double)var1);
|
|
||||||
if(this.mc.gameSettings.anaglyph) {
|
|
||||||
if(anaglyphField == 0) {
|
|
||||||
GL11.glColorMask(false, true, true, true);
|
|
||||||
} else {
|
|
||||||
GL11.glColorMask(true, false, false, true);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
GL11.glColorMask(true, true, true, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(var16 > 0) {
|
// if(this.mc.gameSettings.fancyGraphics) {
|
||||||
var5.renderAllRenderLists(1, (double)var1);
|
// GL11.glColorMask(false, false, false, false);
|
||||||
}
|
// var16 = var5.sortAndRender(var4, 1, (double)var1);
|
||||||
} else {
|
// if(this.mc.gameSettings.anaglyph) {
|
||||||
|
// if(anaglyphField == 0) {
|
||||||
|
// GL11.glColorMask(false, true, true, true);
|
||||||
|
// } else {
|
||||||
|
// GL11.glColorMask(true, false, false, true);
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// GL11.glColorMask(true, true, true, true);
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// if(var16 > 0) {
|
||||||
|
// var5.renderAllRenderLists(1, (double)var1);
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
var5.sortAndRender(var4, 1, (double)var1);
|
var5.sortAndRender(var4, 1, (double)var1);
|
||||||
}
|
// }
|
||||||
|
|
||||||
GL11.glDepthMask(true);
|
GL11.glDepthMask(true);
|
||||||
GL11.glEnable(GL11.GL_CULL_FACE);
|
GL11.glEnable(GL11.GL_CULL_FACE);
|
||||||
|
|
|
@ -10,7 +10,6 @@ public class FontRenderer {
|
||||||
private int[] charWidth = new int[256];
|
private int[] charWidth = new int[256];
|
||||||
public int fontTextureName = 0;
|
public int fontTextureName = 0;
|
||||||
private int fontDisplayLists;
|
private int fontDisplayLists;
|
||||||
private IntBuffer buffer = GLAllocation.createDirectIntBuffer(1024);
|
|
||||||
|
|
||||||
public FontRenderer(GameSettings var1, String var2, RenderEngine var3) {
|
public FontRenderer(GameSettings var1, String var2, RenderEngine var3) {
|
||||||
BufferedImage var4;
|
BufferedImage var4;
|
||||||
|
@ -76,7 +75,6 @@ public class FontRenderer {
|
||||||
var19.addVertexWithUV((double)(0.0F + var20), 0.0D, 0.0D, (double)(((float)var10 + var20) / 128.0F + var21), (double)((float)var11 / 128.0F + var23));
|
var19.addVertexWithUV((double)(0.0F + var20), 0.0D, 0.0D, (double)(((float)var10 + var20) / 128.0F + var21), (double)((float)var11 / 128.0F + var23));
|
||||||
var19.addVertexWithUV(0.0D, 0.0D, 0.0D, (double)((float)var10 / 128.0F + var21), (double)((float)var11 / 128.0F + var23));
|
var19.addVertexWithUV(0.0D, 0.0D, 0.0D, (double)((float)var10 / 128.0F + var21), (double)((float)var11 / 128.0F + var23));
|
||||||
var19.draw();
|
var19.draw();
|
||||||
GL11.glTranslatef((float)this.charWidth[var9], 0.0F, 0.0F);
|
|
||||||
GL11.glEndList();
|
GL11.glEndList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,7 +138,6 @@ public class FontRenderer {
|
||||||
}
|
}
|
||||||
|
|
||||||
GL11.glColor4f(var10, var7, var8, var9);
|
GL11.glColor4f(var10, var7, var8, var9);
|
||||||
this.buffer.clear();
|
|
||||||
GL11.glPushMatrix();
|
GL11.glPushMatrix();
|
||||||
GL11.glTranslatef((float)var2, (float)var3, 0.0F);
|
GL11.glTranslatef((float)var2, (float)var3, 0.0F);
|
||||||
|
|
||||||
|
@ -152,30 +149,19 @@ public class FontRenderer {
|
||||||
var11 = 15;
|
var11 = 15;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.buffer.put(this.fontDisplayLists + 256 + var11 + (var5 ? 16 : 0));
|
GL11.glCallList(fontDisplayLists + 256 + var11 + (var5 ? 16 : 0));
|
||||||
if(this.buffer.remaining() == 0) {
|
GL11.glTranslatef(charWidth[256 + var11 + (var5 ? 16 : 0)] * 0.5f, 0.0F, 0.0F);
|
||||||
this.buffer.flip();
|
|
||||||
GL11.glCallLists(this.buffer);
|
|
||||||
this.buffer.clear();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(var6 < var1.length()) {
|
if(var6 < var1.length()) {
|
||||||
var11 = ChatAllowedCharacters.allowedCharacters.indexOf(var1.charAt(var6));
|
var11 = ChatAllowedCharacters.allowedCharacters.indexOf(var1.charAt(var6));
|
||||||
if(var11 >= 0) {
|
if(var11 >= 0) {
|
||||||
this.buffer.put(this.fontDisplayLists + var11 + 32);
|
GL11.glCallList(fontDisplayLists + var11 + 32);
|
||||||
|
GL11.glTranslatef(charWidth[var11 + 32], 0.0F, 0.0F);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.buffer.remaining() == 0) {
|
|
||||||
this.buffer.flip();
|
|
||||||
GL11.glCallLists(this.buffer);
|
|
||||||
this.buffer.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.buffer.flip();
|
|
||||||
GL11.glCallLists(this.buffer);
|
|
||||||
GL11.glPopMatrix();
|
GL11.glPopMatrix();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ public class GuiMainMenu extends GuiScreen {
|
||||||
public GuiMainMenu() {
|
public GuiMainMenu() {
|
||||||
try {
|
try {
|
||||||
ArrayList var1 = new ArrayList();
|
ArrayList var1 = new ArrayList();
|
||||||
BufferedReader var2 = new BufferedReader(new InputStreamReader(GuiMainMenu.class.getResourceAsStream("/title/splashes.txt"), Charset.forName("UTF-8")));
|
BufferedReader var2 = new BufferedReader(new InputStreamReader(GL11.getResourceAsStream("/title/splashes.txt"), Charset.forName("UTF-8")));
|
||||||
String var3 = "";
|
String var3 = "";
|
||||||
|
|
||||||
while(true) {
|
while(true) {
|
||||||
|
|
|
@ -16,20 +16,6 @@ public class RenderHelper {
|
||||||
GL11.glEnable(GL11.GL_LIGHT1);
|
GL11.glEnable(GL11.GL_LIGHT1);
|
||||||
GL11.glEnable(GL11.GL_COLOR_MATERIAL);
|
GL11.glEnable(GL11.GL_COLOR_MATERIAL);
|
||||||
GL11.glColorMaterial(GL11.GL_FRONT_AND_BACK, GL11.GL_AMBIENT_AND_DIFFUSE);
|
GL11.glColorMaterial(GL11.GL_FRONT_AND_BACK, GL11.GL_AMBIENT_AND_DIFFUSE);
|
||||||
float var0 = 0.4F;
|
GL11.copyModelToLightMatrix();
|
||||||
float var1 = 0.6F;
|
|
||||||
float var2 = 0.0F;
|
|
||||||
Vec3D var3 = Vec3D.createVector((double)0.2F, 1.0D, (double)-0.7F).normalize();
|
|
||||||
GL11.glRotatef((float)var3.xCoord, (float)var3.yCoord, (float)var3.zCoord, 0.0F);
|
|
||||||
GL11.glRotatef(var1, var1, var1, 1.0F);
|
|
||||||
GL11.glRotatef(0.0F, 0.0F, 0.0F, 1.0F);
|
|
||||||
GL11.glRotatef(var2, var2, var2, 1.0F);
|
|
||||||
GL11.glRotatef(var2, var0, var1, var2);
|
|
||||||
var3 = Vec3D.createVector((double)-0.2F, 1.0D, (double)0.7F).normalize();
|
|
||||||
GL11.glRotatef((float)var3.xCoord, (float)var3.yCoord, (float)var3.zCoord, 0.0F);
|
|
||||||
GL11.glRotatef(var1, var1, var1, 1.0F);
|
|
||||||
GL11.glRotatef(0.0F, 0.0F, 0.0F, 1.0F);
|
|
||||||
GL11.glRotatef(var2, var2, var2, 1.0F);
|
|
||||||
GL11.glPopMatrix();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,14 +3,16 @@ package net.minecraft.src;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
public class StringTranslate {
|
public class StringTranslate {
|
||||||
private static StringTranslate instance = new StringTranslate();
|
private static StringTranslate instance = new StringTranslate();
|
||||||
private Properties translateTable = new Properties();
|
private Properties translateTable = new Properties();
|
||||||
|
|
||||||
private StringTranslate() {
|
private StringTranslate() {
|
||||||
try {
|
try {
|
||||||
this.translateTable.load(StringTranslate.class.getResourceAsStream("/lang/en_US.lang"));
|
this.translateTable.load(GL11.getResourceAsStream("/lang/en_US.lang"));
|
||||||
this.translateTable.load(StringTranslate.class.getResourceAsStream("/lang/stats_US.lang"));
|
this.translateTable.load(GL11.getResourceAsStream("/lang/stats_US.lang"));
|
||||||
} catch (IOException var2) {
|
} catch (IOException var2) {
|
||||||
var2.printStackTrace();
|
var2.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,11 +7,11 @@ import org.teavm.jso.typedarrays.Float32Array;
|
||||||
import org.teavm.jso.typedarrays.Int32Array;
|
import org.teavm.jso.typedarrays.Int32Array;
|
||||||
|
|
||||||
public class Tessellator {
|
public class Tessellator {
|
||||||
private static boolean convertQuadsToTriangles = true;
|
private Int32Array intBuffer;
|
||||||
private Float32Array floatBuffer;
|
private Float32Array floatBuffer;
|
||||||
private int vertexCount = 0;
|
private int vertexCount = 0;
|
||||||
private double textureU;
|
private float textureU;
|
||||||
private double textureV;
|
private float textureV;
|
||||||
private int color;
|
private int color;
|
||||||
private boolean hasColor = false;
|
private boolean hasColor = false;
|
||||||
private boolean hasTexture = false;
|
private boolean hasTexture = false;
|
||||||
|
@ -31,6 +31,7 @@ public class Tessellator {
|
||||||
private Tessellator(int var1) {
|
private Tessellator(int var1) {
|
||||||
this.bufferSize = var1;
|
this.bufferSize = var1;
|
||||||
ArrayBuffer a = ArrayBuffer.create(var1 * 4);
|
ArrayBuffer a = ArrayBuffer.create(var1 * 4);
|
||||||
|
this.intBuffer = Int32Array.create(a);
|
||||||
this.floatBuffer = Float32Array.create(a);
|
this.floatBuffer = Float32Array.create(a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,11 +54,7 @@ public class Tessellator {
|
||||||
}
|
}
|
||||||
|
|
||||||
GL11.glEnableClientState(GL11.GL_VERTEX_ARRAY);
|
GL11.glEnableClientState(GL11.GL_VERTEX_ARRAY);
|
||||||
if(this.drawMode == 7 && convertQuadsToTriangles) {
|
GL11.glDrawArrays(this.drawMode, GL11.GL_POINTS, this.vertexCount, Int32Array.create(intBuffer.getBuffer(), 0, this.vertexCount * 7));
|
||||||
GL11.glDrawArrays(GL11.GL_TRIANGLES, GL11.GL_POINTS, this.vertexCount, Int32Array.create(floatBuffer.getBuffer(), 0, this.vertexCount * 7));
|
|
||||||
} else {
|
|
||||||
GL11.glDrawArrays(this.drawMode, GL11.GL_POINTS, this.vertexCount, Int32Array.create(floatBuffer.getBuffer(), 0, this.vertexCount * 7));
|
|
||||||
}
|
|
||||||
|
|
||||||
GL11.glDisableClientState(GL11.GL_VERTEX_ARRAY);
|
GL11.glDisableClientState(GL11.GL_VERTEX_ARRAY);
|
||||||
if(this.hasTexture) {
|
if(this.hasTexture) {
|
||||||
|
@ -103,8 +100,8 @@ public class Tessellator {
|
||||||
|
|
||||||
public void setTextureUV(double var1, double var3) {
|
public void setTextureUV(double var1, double var3) {
|
||||||
this.hasTexture = true;
|
this.hasTexture = true;
|
||||||
this.textureU = var1;
|
this.textureU = (float) var1;
|
||||||
this.textureV = var3;
|
this.textureV = (float) var3;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setColorOpaque_F(float var1, float var2, float var3) {
|
public void setColorOpaque_F(float var1, float var2, float var3) {
|
||||||
|
@ -169,47 +166,30 @@ public class Tessellator {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addVertex(double var1, double var3, double var5) {
|
public void addVertex(double var1, double var3, double var5) {
|
||||||
|
if(this.addedVertices > 65534) return;
|
||||||
++this.addedVertices;
|
++this.addedVertices;
|
||||||
|
|
||||||
|
Int32Array intBuffer0 = intBuffer;
|
||||||
Float32Array floatBuffer0 = floatBuffer;
|
Float32Array floatBuffer0 = floatBuffer;
|
||||||
|
|
||||||
if(this.drawMode == 7 && convertQuadsToTriangles && this.addedVertices % 4 == 0) {
|
floatBuffer0.set(this.rawBufferIndex + 0, (float)(var1 + this.xOffset));
|
||||||
for(int var7 = 0; var7 < 2; ++var7) {
|
floatBuffer0.set(this.rawBufferIndex + 1, (float)(var3 + this.yOffset));
|
||||||
int var8 = 8 * (3 - var7);
|
floatBuffer0.set(this.rawBufferIndex + 2, (float)(var5 + this.zOffset));
|
||||||
|
|
||||||
if(this.hasTexture) {
|
if(this.hasTexture) {
|
||||||
floatBuffer0.set(this.rawBufferIndex + 3, this.rawBufferIndex - var8 + 3);
|
floatBuffer0.set(this.rawBufferIndex + 3, this.textureU);
|
||||||
floatBuffer0.set(this.rawBufferIndex + 4, this.rawBufferIndex - var8 + 4);
|
floatBuffer0.set(this.rawBufferIndex + 4, this.textureV);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.hasColor) {
|
if(this.hasColor) {
|
||||||
floatBuffer0.set(this.rawBufferIndex + 5, this.rawBufferIndex - var8 + 5);
|
intBuffer0.set(this.rawBufferIndex + 5, this.color);
|
||||||
}
|
|
||||||
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 0, this.rawBufferIndex - var8 + 0);
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 1, this.rawBufferIndex - var8 + 1);
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 2, this.rawBufferIndex - var8 + 2);
|
|
||||||
++this.vertexCount;
|
|
||||||
this.rawBufferIndex += 8;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(this.hasTexture) {
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 3, Float.floatToRawIntBits((float)this.textureU));
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 4, Float.floatToRawIntBits((float)this.textureV));
|
|
||||||
}
|
|
||||||
|
|
||||||
if(this.hasColor) {
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 5, this.color);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.hasNormals) {
|
if(this.hasNormals) {
|
||||||
floatBuffer0.set(this.rawBufferIndex + 6, this.normal);
|
intBuffer0.set(this.rawBufferIndex + 6, this.normal);
|
||||||
}
|
}
|
||||||
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 0, Float.floatToRawIntBits((float)(var1 + this.xOffset)));
|
this.rawBufferIndex += 7;
|
||||||
floatBuffer0.set(this.rawBufferIndex + 1, Float.floatToRawIntBits((float)(var3 + this.yOffset)));
|
|
||||||
floatBuffer0.set(this.rawBufferIndex + 2, Float.floatToRawIntBits((float)(var5 + this.zOffset)));
|
|
||||||
this.rawBufferIndex += 8;
|
|
||||||
++this.vertexCount;
|
++this.vertexCount;
|
||||||
if(this.vertexCount % 4 == 0 && this.rawBufferIndex >= this.bufferSize - 32) {
|
if(this.vertexCount % 4 == 0 && this.rawBufferIndex >= this.bufferSize - 32) {
|
||||||
this.draw();
|
this.draw();
|
||||||
|
|
|
@ -67,17 +67,13 @@ public class WorldRenderer {
|
||||||
this.posZMinus = var3 - this.posZClip;
|
this.posZMinus = var3 - this.posZClip;
|
||||||
float var4 = 6.0F;
|
float var4 = 6.0F;
|
||||||
this.rendererBoundingBox = AxisAlignedBB.getBoundingBox((double)((float)var1 - var4), (double)((float)var2 - var4), (double)((float)var3 - var4), (double)((float)(var1 + this.sizeWidth) + var4), (double)((float)(var2 + this.sizeHeight) + var4), (double)((float)(var3 + this.sizeDepth) + var4));
|
this.rendererBoundingBox = AxisAlignedBB.getBoundingBox((double)((float)var1 - var4), (double)((float)var2 - var4), (double)((float)var3 - var4), (double)((float)(var1 + this.sizeWidth) + var4), (double)((float)(var2 + this.sizeHeight) + var4), (double)((float)(var3 + this.sizeDepth) + var4));
|
||||||
GL11.glNewList(this.glRenderList + 2, GL11.GL_COMPILE);
|
//GL11.glNewList(this.glRenderList + 2, GL11.GL_COMPILE);
|
||||||
RenderItem.renderAABB(AxisAlignedBB.getBoundingBoxFromPool((double)((float)this.posXClip - var4), (double)((float)this.posYClip - var4), (double)((float)this.posZClip - var4), (double)((float)(this.posXClip + this.sizeWidth) + var4), (double)((float)(this.posYClip + this.sizeHeight) + var4), (double)((float)(this.posZClip + this.sizeDepth) + var4)));
|
//RenderItem.renderAABB(AxisAlignedBB.getBoundingBoxFromPool((double)((float)this.posXClip - var4), (double)((float)this.posYClip - var4), (double)((float)this.posZClip - var4), (double)((float)(this.posXClip + this.sizeWidth) + var4), (double)((float)(this.posYClip + this.sizeHeight) + var4), (double)((float)(this.posZClip + this.sizeDepth) + var4)));
|
||||||
GL11.glEndList();
|
//GL11.glEndList();
|
||||||
this.markDirty();
|
this.markDirty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setupGLTranslation() {
|
|
||||||
GL11.glTranslatef((float)this.posXClip, (float)this.posYClip, (float)this.posZClip);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateRenderer() {
|
public void updateRenderer() {
|
||||||
if(this.needsUpdate) {
|
if(this.needsUpdate) {
|
||||||
++chunksUpdated;
|
++chunksUpdated;
|
||||||
|
@ -113,14 +109,8 @@ public class WorldRenderer {
|
||||||
if(!var14) {
|
if(!var14) {
|
||||||
var14 = true;
|
var14 = true;
|
||||||
GL11.glNewList(this.glRenderList + var11, GL11.GL_COMPILE);
|
GL11.glNewList(this.glRenderList + var11, GL11.GL_COMPILE);
|
||||||
GL11.glPushMatrix();
|
|
||||||
this.setupGLTranslation();
|
|
||||||
float var19 = 1.000001F;
|
|
||||||
GL11.glTranslatef((float)(-this.sizeDepth) / 2.0F, (float)(-this.sizeHeight) / 2.0F, (float)(-this.sizeDepth) / 2.0F);
|
|
||||||
GL11.glScalef(var19, var19, var19);
|
|
||||||
GL11.glTranslatef((float)this.sizeDepth / 2.0F, (float)this.sizeHeight / 2.0F, (float)this.sizeDepth / 2.0F);
|
|
||||||
tessellator.startDrawingQuads();
|
tessellator.startDrawingQuads();
|
||||||
tessellator.setTranslationD((double)(-this.posX), (double)(-this.posY), (double)(-this.posZ));
|
tessellator.setTranslationD((double) (this.posXClip-this.posX), (double) (this.posYClip-this.posY), (double) (this.posZClip-this.posZ));
|
||||||
}
|
}
|
||||||
|
|
||||||
if(var11 == 0 && Block.isBlockContainer[var18]) {
|
if(var11 == 0 && Block.isBlockContainer[var18]) {
|
||||||
|
@ -144,7 +134,6 @@ public class WorldRenderer {
|
||||||
|
|
||||||
if(var14) {
|
if(var14) {
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
GL11.glPopMatrix();
|
|
||||||
GL11.glEndList();
|
GL11.glEndList();
|
||||||
tessellator.setTranslationD(0.0D, 0.0D, 0.0D);
|
tessellator.setTranslationD(0.0D, 0.0D, 0.0D);
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user