Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package net.minecraft.client.gui;
- import java.io.BufferedReader;
- import java.io.ByteArrayOutputStream;
- import java.io.DataInputStream;
- import java.io.DataOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.InputStreamReader;
- import java.io.OutputStream;
- import java.net.InetAddress;
- import java.net.InetSocketAddress;
- import java.net.Socket;
- import java.net.SocketAddress;
- import java.net.URI;
- import java.util.ArrayList;
- import java.util.Calendar;
- import java.util.Date;
- import java.util.Random;
- import net.minecraft.client.Minecraft;
- import net.minecraft.client.multiplayer.GuiConnecting;
- import net.minecraft.client.multiplayer.ServerData;
- import net.minecraft.client.renderer.OpenGlHelper;
- import net.minecraft.client.renderer.Tessellator;
- import net.minecraft.client.renderer.texture.DynamicTexture;
- import net.minecraft.client.resources.I18n;
- import net.minecraft.realms.RealmsBridge;
- import net.minecraft.util.EnumChatFormatting;
- import net.minecraft.util.MathHelper;
- import net.minecraft.util.ResourceLocation;
- import net.minecraft.world.demo.DemoWorldServer;
- import net.minecraft.world.storage.ISaveFormat;
- import net.minecraft.world.storage.WorldInfo;
- import org.apache.commons.io.Charsets;
- import org.apache.logging.log4j.LogManager;
- import org.apache.logging.log4j.Logger;
- import org.lwjgl.opengl.GL11;
- import org.lwjgl.opengl.GLContext;
- import org.lwjgl.util.glu.Project;
- import com.google.gson.Gson;
- import com.google.gson.JsonElement;
- import com.google.gson.JsonObject;
- import com.google.gson.JsonParser;
- import cpw.mods.fml.client.FMLClientHandler;
- public class GuiMainMenu extends GuiScreen implements GuiYesNoCallback
- {
- static boolean loaded = false;
- //Настройки
- public static String serverIp = "localhost"; //IP сервака
- public static String serverPort = "25565"; //Порт сервака
- public static String siteAddress = "http://mysuperproject.ru/"; //Адрес сайта (с протоколом!). Укадите "none", если Вам это не надо.
- public static String forumAddress = "http://forum.mysuperproject.ru/"; //Адрес форума (с протоколом!). Укадите "none", если Вам это не надо.
- public static String joinToServer = "§bЗайти на сервер§3:"; //Текст для кнопки мультиплеера (если сервер онлайн)
- public static String numberOfPlayersColor = "§a"; //Цвет значения количества человек на сервере
- public static String dividerColor = "§2"; //Цвет слеша для разделения количества человек от маскимального количества человек
- public static String serverIsNotResponding = "Сервер недоступен"; //Если сервер недоступен, мало ли у человека инет говно (или хост :D)
- private String waitTime = "10"; //Каждые waitTime сек будет обновляться онлайн
- public static String updating = "§7Обновление..."; //Обновление
- private String bottomLeftText = "Текст слева"; //Для удобства
- private String bottomRightText = "Текст справа"; //Тоже для удобства
- private String customSplash = "helloPlayer"; //Жёстко установить значение сплеша (пульсирующего жёлтого текста)
- private String ourSite = "§aНаш сайт"; //Текст кнопки для сайта
- private String ourForum = "§1Форум"; //Текст кнопки для форума
- private static final Logger logger = LogManager.getLogger();
- /** The RNG used by the Main Menu Screen. */
- private static final Random rand = new Random();
- /** Counts the number of screen updates. */
- private float updateCounter;
- /** The splash message. */
- private String splashText;
- private GuiButton buttonResetDemo;
- /** Timer used to rotate the panorama, increases every tick. */
- private int panoramaTimer;
- /**
- * Texture allocated for the current viewport of the main menu's panorama background.
- */
- private DynamicTexture viewportTexture;
- private final Object field_104025_t = new Object();
- private String field_92025_p;
- private String field_146972_A;
- private String field_104024_v;
- private static final ResourceLocation splashTexts = new ResourceLocation("texts/splashes.txt");
- private static final ResourceLocation minecraftTitleTextures = new ResourceLocation("textures/gui/title/minecraft.png");
- /** An array of all the paths to the panorama pictures. */
- private static final ResourceLocation[] titlePanoramaPaths = new ResourceLocation[] {new ResourceLocation("textures/gui/title/background/panorama_0.png"), new ResourceLocation("textures/gui/title/background/panorama_1.png"), new ResourceLocation("textures/gui/title/background/panorama_2.png"), new ResourceLocation("textures/gui/title/background/panorama_3.png"), new ResourceLocation("textures/gui/title/background/panorama_4.png"), new ResourceLocation("textures/gui/title/background/panorama_5.png")};
- public static final String field_96138_a = "Please click " + EnumChatFormatting.UNDERLINE + "here" + EnumChatFormatting.RESET + " for more information.";
- private int field_92024_r;
- private int field_92023_s;
- private int field_92022_t;
- private int field_92021_u;
- private int field_92020_v;
- private int field_92019_w;
- private ResourceLocation field_110351_G;
- private static final String __OBFID = "CL_00001154";
- public GuiMainMenu()
- {
- this.field_146972_A = field_96138_a;
- this.splashText = "missingno";
- BufferedReader var1 = null;
- try
- {
- ArrayList var2 = new ArrayList();
- var1 = new BufferedReader(new InputStreamReader(Minecraft.getMinecraft().getResourceManager().getResource(splashTexts).getInputStream(), Charsets.UTF_8));
- String var3;
- while ((var3 = var1.readLine()) != null)
- {
- var3 = var3.trim();
- if (!var3.isEmpty())
- {
- var2.add(var3);
- }
- }
- if (!var2.isEmpty())
- {
- do
- {
- this.splashText = (String)var2.get(rand.nextInt(var2.size()));
- }
- while (this.splashText.hashCode() == 125780783);
- }
- }
- catch (IOException var12)
- {
- ;
- }
- finally
- {
- if (var1 != null)
- {
- try
- {
- var1.close();
- }
- catch (IOException var11)
- {
- ;
- }
- }
- }
- this.updateCounter = rand.nextFloat();
- this.field_92025_p = "";
- if (!GLContext.getCapabilities().OpenGL20 && !OpenGlHelper.func_153193_b())
- {
- this.field_92025_p = I18n.format("title.oldgl1", new Object[0]);
- this.field_146972_A = I18n.format("title.oldgl2", new Object[0]);
- this.field_104024_v = "https://help.mojang.com/customer/portal/articles/325948?ref=game";
- }
- FMLClientHandler.instance().setupServerList();
- }
- /**
- * Called from the main game loop to update the screen.
- */
- public void updateScreen()
- {
- ++this.panoramaTimer;
- }
- /**
- * Returns true if this GUI should pause the game when it is displayed in single-player
- */
- public boolean doesGuiPauseGame()
- {
- return false;
- }
- /**
- * Fired when a key is typed. This is the equivalent of KeyListener.keyTyped(KeyEvent e).
- */
- protected void keyTyped(char p_73869_1_, int p_73869_2_) {}
- /**
- * Adds the buttons (and other controls) to the screen in question.
- */
- public void initGui()
- {
- this.viewportTexture = new DynamicTexture(256, 256);
- this.field_110351_G = this.mc.getTextureManager().getDynamicTextureLocation("background", this.viewportTexture);
- Calendar var1 = Calendar.getInstance();
- var1.setTime(new Date());
- if (var1.get(2) + 1 == 11 && var1.get(5) == 9)
- {
- this.splashText = "С Днём рождения, ez!";
- }
- else if (var1.get(2) + 1 == 6 && var1.get(5) == 1)
- {
- this.splashText = "С Днём рождения, Notch!";
- }
- else if (var1.get(2) + 1 == 12 && var1.get(5) == 24)
- {
- this.splashText = "С Рождеством!";
- }
- else if (var1.get(2) + 1 == 12 && var1.get(5) == 31) {
- this.splashText = "Скорее бы!";
- }
- else if (var1.get(2) + 1 == 1 && var1.get(5) == 1)
- {
- this.splashText = "С Новым годом!";
- }
- else if (var1.get(2) + 1 == 10 && var1.get(5) == 31)
- {
- this.splashText = "ОООоооООООоооо! Страшно!";
- }
- else if (var1.get(2) + 1 == 5 && var1.get(5) == 9)
- {
- this.splashText = "Слава ветеранам!";
- }
- else if (var1.get(2) + 1 == 6 && var1.get(5) == 12)
- {
- this.splashText = "Россия - наша держава!";
- }
- else if (var1.get(2) + 1 == 7 && var1.get(5) == 15)
- {
- this.splashText = "1-ая половина лета просрана успешно";
- }
- else if (var1.get(2) + 1 == 8 && var1.get(5) == 31)
- {
- this.splashText = "Завтра самый ужасный день :(";
- }
- else if (var1.get(2) + 1 == 9 && var1.get(5) == 1)
- {
- this.splashText = "Этот день настал D:";
- }
- else {
- if (customSplash=="helloPlayer") {
- this.splashText = "Привет, " + this.mc.getSession().getUsername() + "!";
- } else
- this.splashText = customSplash;
- }
- boolean var2 = true;
- int var3 = this.height / 4 + 48;
- if (this.mc.isDemo())
- {
- this.addDemoButtons(var3, 24);
- }
- else
- {
- this.addSingleplayerMultiplayerButtons(var3, 24);
- }
- this.buttonList.add(new GuiButton(0, this.width / 2 - 100, var3 + 72 + 12, 98, 20, I18n.format("menu.options", new Object[0])));
- this.buttonList.add(new GuiButton(4, this.width / 2 + 2, var3 + 72 + 12, 98, 20, I18n.format("menu.quit", new Object[0])));
- this.buttonList.add(new GuiButtonLanguage(5, this.width / 2 - 124, var3 + 72 + 12));
- Object var4 = this.field_104025_t;
- synchronized (this.field_104025_t)
- {
- this.field_92023_s = this.fontRendererObj.getStringWidth(this.field_92025_p);
- this.field_92024_r = this.fontRendererObj.getStringWidth(this.field_146972_A);
- int var5 = Math.max(this.field_92023_s, this.field_92024_r);
- this.field_92022_t = (this.width - var5) / 2;
- this.field_92021_u = ((GuiButton)this.buttonList.get(0)).field_146129_i - 24;
- this.field_92020_v = this.field_92022_t + var5;
- this.field_92019_w = this.field_92021_u + 24;
- }
- }
- /**
- * Adds Singleplayer and Multiplayer buttons on Main Menu for players who have bought the game.
- */
- GuiButton mult;
- int time = Integer.valueOf(waitTime);
- boolean isTimerStarted = false;
- private void addSingleplayerMultiplayerButtons(int p_73969_1_, int p_73969_2_)
- {
- this.buttonList.add(new GuiButton(1, this.width / 2 - 100, p_73969_1_, I18n.format("menu.singleplayer", new Object[0])));
- mult = new GuiButton(2, this.width / 2 - 100, p_73969_1_ + p_73969_2_ * 1, I18n.format("menu.multiplayer", new Object[0]));
- getOnlineMaxOnline(mult);
- this.buttonList.add(mult);
- if (siteAddress!="none" && forumAddress=="none") this.buttonList.add(new GuiButton(14, this.width / 2 - 100, p_73969_1_ + p_73969_2_ * 2, I18n.format(ourSite, new Object[0])));
- else if (siteAddress!="none" && forumAddress!="none") {
- this.buttonList.add(new GuiButton(14, this.width / 2 - 100, p_73969_1_ + p_73969_2_ * 2, 98, 20, I18n.format(ourSite, new Object[0])));
- this.buttonList.add(new GuiButton(400, this.width / 2 + 2, p_73969_1_ + p_73969_2_ * 2, 98, 20, I18n.format(ourForum, new Object[0])));
- }
- Thread timer = new Thread(new Runnable(){
- @Override
- public void run() {
- while (true) {
- for (int i=time; i>0; i--) {
- try {
- time = i;
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- loaded = false;
- time = Integer.valueOf(waitTime);
- getOnlineMaxOnline(mult);
- }
- }
- });
- if (!isTimerStarted) {
- timer.start();
- isTimerStarted = true;
- }
- }
- /**
- * Adds Demo buttons on Main Menu for players who are playing Demo.
- */
- private void addDemoButtons(int p_73972_1_, int p_73972_2_)
- {
- this.buttonList.add(new GuiButton(11, this.width / 2 - 100, p_73972_1_, I18n.format("menu.playdemo", new Object[0])));
- this.buttonList.add(this.buttonResetDemo = new GuiButton(12, this.width / 2 - 100, p_73972_1_ + p_73972_2_ * 1, I18n.format("menu.resetdemo", new Object[0])));
- ISaveFormat var3 = this.mc.getSaveLoader();
- WorldInfo var4 = var3.getWorldInfo("Demo_World");
- if (var4 == null)
- {
- this.buttonResetDemo.enabled = false;
- }
- }
- protected void actionPerformed(GuiButton p_146284_1_)
- {
- if (p_146284_1_.id == 0)
- {
- this.mc.displayGuiScreen(new GuiOptions(this, this.mc.gameSettings));
- }
- if (p_146284_1_.id == 5)
- {
- this.mc.displayGuiScreen(new GuiLanguage(this, this.mc.gameSettings, this.mc.getLanguageManager()));
- }
- if (p_146284_1_.id == 1)
- {
- this.mc.displayGuiScreen(new GuiSelectWorld(this));
- }
- if (p_146284_1_.id == 2)
- {
- FMLClientHandler.instance().connectToServer(this, new ServerData("MySuperServer", serverIp+":"+serverPort));
- }
- if (p_146284_1_.id == 14)
- {
- try
- {
- Class var3 = Class.forName("java.awt.Desktop");
- Object var4 = var3.getMethod("getDesktop", new Class[0]).invoke((Object)null, new Object[0]);
- var3.getMethod("browse", new Class[] {URI.class}).invoke(var4, new Object[] {new URI(siteAddress)});
- }
- catch (Throwable var5)
- {
- logger.error("Couldn\'t open link", var5);
- }
- }
- if (p_146284_1_.id == 400)
- {
- try
- {
- Class var3 = Class.forName("java.awt.Desktop");
- Object var4 = var3.getMethod("getDesktop", new Class[0]).invoke((Object)null, new Object[0]);
- var3.getMethod("browse", new Class[] {URI.class}).invoke(var4, new Object[] {new URI(forumAddress)});
- }
- catch (Throwable var5)
- {
- logger.error("Couldn\'t open link", var5);
- }
- }
- if (p_146284_1_.id == 4)
- {
- this.mc.shutdown();
- }
- if (p_146284_1_.id == 11)
- {
- this.mc.launchIntegratedServer("Demo_World", "Demo_World", DemoWorldServer.demoWorldSettings);
- }
- if (p_146284_1_.id == 12)
- {
- ISaveFormat var2 = this.mc.getSaveLoader();
- WorldInfo var3 = var2.getWorldInfo("Demo_World");
- if (var3 != null)
- {
- GuiYesNo var4 = GuiSelectWorld.func_152129_a(this, var3.getWorldName(), 12);
- this.mc.displayGuiScreen(var4);
- }
- }
- }
- private void func_140005_i()
- {
- RealmsBridge var1 = new RealmsBridge();
- var1.switchToRealms(this);
- }
- public void confirmClicked(boolean p_73878_1_, int p_73878_2_)
- {
- if (p_73878_1_ && p_73878_2_ == 12)
- {
- ISaveFormat var6 = this.mc.getSaveLoader();
- var6.flushCache();
- var6.deleteWorldDirectory("Demo_World");
- this.mc.displayGuiScreen(this);
- }
- else if (p_73878_2_ == 13)
- {
- if (p_73878_1_)
- {
- try
- {
- Class var3 = Class.forName("java.awt.Desktop");
- Object var4 = var3.getMethod("getDesktop", new Class[0]).invoke((Object)null, new Object[0]);
- var3.getMethod("browse", new Class[] {URI.class}).invoke(var4, new Object[] {new URI(this.field_104024_v)});
- }
- catch (Throwable var5)
- {
- logger.error("Couldn\'t open link", var5);
- }
- }
- this.mc.displayGuiScreen(this);
- }
- }
- /**
- * Draws the main menu panorama
- */
- private void drawPanorama(int p_73970_1_, int p_73970_2_, float p_73970_3_)
- {
- Tessellator var4 = Tessellator.instance;
- GL11.glMatrixMode(GL11.GL_PROJECTION);
- GL11.glPushMatrix();
- GL11.glLoadIdentity();
- Project.gluPerspective(120.0F, 1.0F, 0.05F, 10.0F);
- GL11.glMatrixMode(GL11.GL_MODELVIEW);
- GL11.glPushMatrix();
- GL11.glLoadIdentity();
- GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
- GL11.glRotatef(180.0F, 1.0F, 0.0F, 0.0F);
- GL11.glRotatef(90.0F, 0.0F, 0.0F, 1.0F);
- GL11.glEnable(GL11.GL_BLEND);
- GL11.glDisable(GL11.GL_ALPHA_TEST);
- GL11.glDisable(GL11.GL_CULL_FACE);
- GL11.glDepthMask(false);
- OpenGlHelper.glBlendFunc(770, 771, 1, 0);
- byte var5 = 8;
- for (int var6 = 0; var6 < var5 * var5; ++var6)
- {
- GL11.glPushMatrix();
- float var7 = ((float)(var6 % var5) / (float)var5 - 0.5F) / 64.0F;
- float var8 = ((float)(var6 / var5) / (float)var5 - 0.5F) / 64.0F;
- float var9 = 0.0F;
- GL11.glTranslatef(var7, var8, var9);
- GL11.glRotatef(MathHelper.sin(((float)this.panoramaTimer + p_73970_3_) / 400.0F) * 25.0F + 20.0F, 1.0F, 0.0F, 0.0F);
- GL11.glRotatef(-((float)this.panoramaTimer + p_73970_3_) * 0.1F, 0.0F, 1.0F, 0.0F);
- for (int var10 = 0; var10 < 6; ++var10)
- {
- GL11.glPushMatrix();
- if (var10 == 1)
- {
- GL11.glRotatef(90.0F, 0.0F, 1.0F, 0.0F);
- }
- if (var10 == 2)
- {
- GL11.glRotatef(180.0F, 0.0F, 1.0F, 0.0F);
- }
- if (var10 == 3)
- {
- GL11.glRotatef(-90.0F, 0.0F, 1.0F, 0.0F);
- }
- if (var10 == 4)
- {
- GL11.glRotatef(90.0F, 1.0F, 0.0F, 0.0F);
- }
- if (var10 == 5)
- {
- GL11.glRotatef(-90.0F, 1.0F, 0.0F, 0.0F);
- }
- this.mc.getTextureManager().bindTexture(titlePanoramaPaths[var10]);
- var4.startDrawingQuads();
- var4.setColorRGBA_I(16777215, 255 / (var6 + 1));
- float var11 = 0.0F;
- var4.addVertexWithUV(-1.0D, -1.0D, 1.0D, (double)(0.0F + var11), (double)(0.0F + var11));
- var4.addVertexWithUV(1.0D, -1.0D, 1.0D, (double)(1.0F - var11), (double)(0.0F + var11));
- var4.addVertexWithUV(1.0D, 1.0D, 1.0D, (double)(1.0F - var11), (double)(1.0F - var11));
- var4.addVertexWithUV(-1.0D, 1.0D, 1.0D, (double)(0.0F + var11), (double)(1.0F - var11));
- var4.draw();
- GL11.glPopMatrix();
- }
- GL11.glPopMatrix();
- GL11.glColorMask(true, true, true, false);
- }
- var4.setTranslation(0.0D, 0.0D, 0.0D);
- GL11.glColorMask(true, true, true, true);
- GL11.glMatrixMode(GL11.GL_PROJECTION);
- GL11.glPopMatrix();
- GL11.glMatrixMode(GL11.GL_MODELVIEW);
- GL11.glPopMatrix();
- GL11.glDepthMask(true);
- GL11.glEnable(GL11.GL_CULL_FACE);
- GL11.glEnable(GL11.GL_DEPTH_TEST);
- }
- /**
- * Rotate and blurs the skybox view in the main menu
- */
- private void rotateAndBlurSkybox(float p_73968_1_)
- {
- this.mc.getTextureManager().bindTexture(this.field_110351_G);
- GL11.glTexParameteri(GL11.GL_TEXTURE_2D, GL11.GL_TEXTURE_MIN_FILTER, GL11.GL_LINEAR);
- GL11.glTexParameteri(GL11.GL_TEXTURE_2D, GL11.GL_TEXTURE_MAG_FILTER, GL11.GL_LINEAR);
- GL11.glCopyTexSubImage2D(GL11.GL_TEXTURE_2D, 0, 0, 0, 0, 0, 256, 256);
- GL11.glEnable(GL11.GL_BLEND);
- OpenGlHelper.glBlendFunc(770, 771, 1, 0);
- GL11.glColorMask(true, true, true, false);
- Tessellator var2 = Tessellator.instance;
- var2.startDrawingQuads();
- GL11.glDisable(GL11.GL_ALPHA_TEST);
- byte var3 = 3;
- for (int var4 = 0; var4 < var3; ++var4)
- {
- var2.setColorRGBA_F(1.0F, 1.0F, 1.0F, 1.0F / (float)(var4 + 1));
- int var5 = this.width;
- int var6 = this.height;
- float var7 = (float)(var4 - var3 / 2) / 256.0F;
- var2.addVertexWithUV((double)var5, (double)var6, (double)this.zLevel, (double)(0.0F + var7), 1.0D);
- var2.addVertexWithUV((double)var5, 0.0D, (double)this.zLevel, (double)(1.0F + var7), 1.0D);
- var2.addVertexWithUV(0.0D, 0.0D, (double)this.zLevel, (double)(1.0F + var7), 0.0D);
- var2.addVertexWithUV(0.0D, (double)var6, (double)this.zLevel, (double)(0.0F + var7), 0.0D);
- }
- var2.draw();
- GL11.glEnable(GL11.GL_ALPHA_TEST);
- GL11.glColorMask(true, true, true, true);
- }
- /**
- * Renders the skybox in the main menu
- */
- private void renderSkybox(int p_73971_1_, int p_73971_2_, float p_73971_3_)
- {
- this.mc.getFramebuffer().unbindFramebuffer();
- GL11.glViewport(0, 0, 256, 256);
- this.drawPanorama(p_73971_1_, p_73971_2_, p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.rotateAndBlurSkybox(p_73971_3_);
- this.mc.getFramebuffer().bindFramebuffer(true);
- GL11.glViewport(0, 0, this.mc.displayWidth, this.mc.displayHeight);
- Tessellator var4 = Tessellator.instance;
- var4.startDrawingQuads();
- float var5 = this.width > this.height ? 120.0F / (float)this.width : 120.0F / (float)this.height;
- float var6 = (float)this.height * var5 / 256.0F;
- float var7 = (float)this.width * var5 / 256.0F;
- var4.setColorRGBA_F(1.0F, 1.0F, 1.0F, 1.0F);
- int var8 = this.width;
- int var9 = this.height;
- var4.addVertexWithUV(0.0D, (double)var9, (double)this.zLevel, (double)(0.5F - var6), (double)(0.5F + var7));
- var4.addVertexWithUV((double)var8, (double)var9, (double)this.zLevel, (double)(0.5F - var6), (double)(0.5F - var7));
- var4.addVertexWithUV((double)var8, 0.0D, (double)this.zLevel, (double)(0.5F + var6), (double)(0.5F - var7));
- var4.addVertexWithUV(0.0D, 0.0D, (double)this.zLevel, (double)(0.5F + var6), (double)(0.5F + var7));
- var4.draw();
- }
- /**
- * Draws the screen and all the components in it.
- */
- public void drawScreen(int p_73863_1_, int p_73863_2_, float p_73863_3_)
- {
- GL11.glDisable(GL11.GL_ALPHA_TEST);
- this.renderSkybox(p_73863_1_, p_73863_2_, p_73863_3_);
- GL11.glEnable(GL11.GL_ALPHA_TEST);
- Tessellator var4 = Tessellator.instance;
- short var5 = 274;
- int var6 = this.width / 2 - var5 / 2;
- byte var7 = 30;
- this.drawGradientRect(0, 0, this.width, this.height, -2130706433, 16777215);
- this.drawGradientRect(0, 0, this.width, this.height, 0, Integer.MIN_VALUE);
- this.mc.getTextureManager().bindTexture(minecraftTitleTextures);
- GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
- if ((double)this.updateCounter < 1.0E-4D)
- {
- this.drawTexturedModalRect(var6 + 0, var7 + 0, 0, 0, 99, 44);
- this.drawTexturedModalRect(var6 + 99, var7 + 0, 129, 0, 27, 44);
- this.drawTexturedModalRect(var6 + 99 + 26, var7 + 0, 126, 0, 3, 44);
- this.drawTexturedModalRect(var6 + 99 + 26 + 3, var7 + 0, 99, 0, 26, 44);
- this.drawTexturedModalRect(var6 + 155, var7 + 0, 0, 45, 155, 44);
- }
- else
- {
- this.drawTexturedModalRect(var6 + 0, var7 + 0, 0, 0, 155, 44);
- this.drawTexturedModalRect(var6 + 155, var7 + 0, 0, 45, 155, 44);
- }
- var4.setColorOpaque_I(-1);
- GL11.glPushMatrix();
- GL11.glTranslatef((float)(this.width / 2 + 90), 70.0F, 0.0F);
- GL11.glRotatef(-20.0F, 0.0F, 0.0F, 1.0F);
- float var8 = 1.8F - MathHelper.abs(MathHelper.sin((float)(Minecraft.getSystemTime() % 1000L) / 1000.0F * (float)Math.PI * 2.0F) * 0.1F);
- var8 = var8 * 100.0F / (float)(this.fontRendererObj.getStringWidth(this.splashText) + 32);
- GL11.glScalef(var8, var8, var8);
- this.drawCenteredString(this.fontRendererObj, this.splashText, 0, -8, -256);
- GL11.glPopMatrix();
- String var9 = bottomLeftText;
- this.drawString(this.fontRendererObj, var9, 2, this.height - 10, -1);
- String var10 = bottomRightText;
- this.drawString(this.fontRendererObj, var10, this.width - this.fontRendererObj.getStringWidth(var10) - 2, this.height - 10, -1);
- if (this.field_92025_p != null && this.field_92025_p.length() > 0)
- {
- drawRect(this.field_92022_t - 2, this.field_92021_u - 2, this.field_92020_v + 2, this.field_92019_w - 1, 1428160512);
- this.drawString(this.fontRendererObj, this.field_92025_p, this.field_92022_t, this.field_92021_u, -1);
- this.drawString(this.fontRendererObj, this.field_146972_A, (this.width - this.field_92024_r) / 2, ((GuiButton)this.buttonList.get(0)).field_146129_i - 12, -1);
- }
- super.drawScreen(p_73863_1_, p_73863_2_, p_73863_3_);
- }
- /**
- * Called when the mouse is clicked.
- */
- protected void mouseClicked(int p_73864_1_, int p_73864_2_, int p_73864_3_)
- {
- super.mouseClicked(p_73864_1_, p_73864_2_, p_73864_3_);
- Object var4 = this.field_104025_t;
- synchronized (this.field_104025_t)
- {
- if (this.field_92025_p.length() > 0 && p_73864_1_ >= this.field_92022_t && p_73864_1_ <= this.field_92020_v && p_73864_2_ >= this.field_92021_u && p_73864_2_ <= this.field_92019_w)
- {
- GuiConfirmOpenLink var5 = new GuiConfirmOpenLink(this, this.field_104024_v, 13, true);
- var5.func_146358_g();
- this.mc.displayGuiScreen(var5);
- }
- }
- }
- public static int readVarInt(DataInputStream in) throws IOException {
- int i = 0;
- int j = 0;
- while (true) {
- int k = in.readByte();
- i |= (k & 0x7F) << j++ * 7;
- if (j > 5) throw new RuntimeException("VarInt too big");
- if ((k & 0x80) != 128) break;
- }
- return i;
- }
- public static void writeVarInt(DataOutputStream out, int paramInt) throws IOException {
- while (true) {
- if ((paramInt & 0xFFFFFF80) == 0) {
- out.writeByte(paramInt);
- return;
- }
- out.writeByte(paramInt & 0x7F | 0x80);
- paramInt >>>= 7;
- }
- }
- static String toButton;
- static boolean enabled = true;
- @SuppressWarnings("resource")
- public static void getOnlineMaxOnline(GuiButton button) {
- if (!loaded) {
- if (updating!="none") {
- button.displayString = updating;
- try {
- Thread.sleep(1400);
- } catch (InterruptedException e1) {
- // TODO Auto-generated catch block
- e1.printStackTrace();
- }
- } else {
- button.displayString = toButton;
- }
- try {
- Socket socket = new Socket(serverIp, Integer.valueOf(serverPort));
- OutputStream outputStream;
- DataOutputStream dataOutputStream;
- InputStream inputStream;
- InputStreamReader inputStreamReader;
- socket.setSoTimeout(3000);
- outputStream = socket.getOutputStream();
- dataOutputStream = new DataOutputStream(outputStream);
- inputStream = socket.getInputStream();
- inputStreamReader = new InputStreamReader(inputStream);
- ByteArrayOutputStream b = new ByteArrayOutputStream();
- DataOutputStream handshake = new DataOutputStream(b);
- handshake.writeByte(0x00); //packet id for handshake
- writeVarInt(handshake, 5); //protocol version
- writeVarInt(handshake, serverIp.length()); //host length
- handshake.writeBytes(serverIp); //host string
- handshake.writeShort(Short.valueOf(serverPort)); //port
- writeVarInt(handshake, 1); //state (1 for handshake)
- writeVarInt(dataOutputStream, b.size()); //prepend size
- dataOutputStream.write(b.toByteArray()); //write handshake packet
- dataOutputStream.writeByte(0x01); //size is only 1
- dataOutputStream.writeByte(0x00); //packet id for ping
- DataInputStream dataInputStream = new DataInputStream(inputStream);
- int size = readVarInt(dataInputStream); //size of packet
- int id = readVarInt(dataInputStream); //packet id
- if (id == -1) {
- throw new IOException("Premature end of stream.");
- }
- if (id != 0x00) { //we want a status response
- throw new IOException("Invalid packetID");
- }
- int length = readVarInt(dataInputStream); //length of json string
- if (length == -1) {
- throw new IOException("Premature end of stream.");
- }
- if (length == 0) {
- throw new IOException("Invalid string length.");
- }
- byte[] in = new byte[length];
- dataInputStream.readFully(in); //read json string
- String json = new String(in);
- long now = System.currentTimeMillis();
- dataOutputStream.writeByte(0x09); //size of packet
- dataOutputStream.writeByte(0x01); //0x01 for ping
- dataOutputStream.writeLong(now); //time!?
- readVarInt(dataInputStream);
- id = readVarInt(dataInputStream);
- if (id == -1) {
- throw new IOException("Premature end of stream.");
- }
- if (id != 0x01) {
- throw new IOException("Invalid packetID");
- }
- long pingtime = dataInputStream.readLong(); //read response
- Gson gson = new Gson();
- StatusResponse response = gson.fromJson(json, StatusResponse.class);
- response.setTime((int) (now - pingtime));
- dataOutputStream.close();
- outputStream.close();
- inputStreamReader.close();
- inputStream.close();
- socket.close();
- int players = response.getPlayers().getOnline();
- int maxPlayers = response.getPlayers().getMax();
- toButton = GuiMainMenu.joinToServer + " " + GuiMainMenu.numberOfPlayersColor + Integer.toString(players) + GuiMainMenu.dividerColor + " / " + GuiMainMenu.numberOfPlayersColor + Integer.toString(maxPlayers);
- socket.close();
- enabled = true;
- } catch (IOException e) {
- enabled = false;
- toButton = GuiMainMenu.serverIsNotResponding;
- }
- loaded = true;
- }
- button.enabled = enabled;
- button.displayString = toButton;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement