Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package net.minecraft.client.gui;
- import java.awt.Desktop;
- import java.io.BufferedReader;
- import java.io.IOException;
- import java.io.InputStreamReader;
- import java.net.URI;
- import java.util.ArrayList;
- import java.util.Calendar;
- import java.util.Date;
- import java.util.Random;
- 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 net.minecraft.client.ApiInfo;
- import net.minecraft.client.Minecraft;
- 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.realms.RealmsScreen;
- 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;
- public class GuiMainMenu extends GuiScreen implements GuiYesNoCallback
- {
- private ApiInfo infos = new ApiInfo("Vanadia", "vanadia.fr:28000");
- 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");
- /** An array of all the paths to the panorama pictures. */
- private final ResourceLocation backGround = new ResourceLocation("textures/gui/title/back.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()
- {
- infos.pre_init();
- this.field_146972_A = field_96138_a;
- this.splashText = "";
- 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";
- }
- }
- /**
- * Called from the main game loop to update the screen.
- */
- public void updateScreen()
- {
- ++this.panoramaTimer;
- infos.refresh();
- }
- public void onGuiClosed()
- {
- infos.close();
- super.onGuiClosed();
- }
- /**
- * 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 = "Happy birthday, ez!";
- }
- else if (var1.get(2) + 1 == 6 && var1.get(5) == 1)
- {
- this.splashText = "Happy birthday, Notch!";
- }
- else if (var1.get(2) + 1 == 12 && var1.get(5) == 24)
- {
- this.splashText = "Merry X-mas!";
- }
- else if (var1.get(2) + 1 == 1 && var1.get(5) == 1)
- {
- this.splashText = "Happy new year!";
- }
- else if (var1.get(2) + 1 == 10 && var1.get(5) == 31)
- {
- this.splashText = "OOoooOOOoooo! Spooky!";
- }
- 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 + 0, 98, 20, I18n.format("menu.options", new Object[0])));
- this.buttonList.add(new GuiButton(4, this.width / 2 + 2, var3 + 72 + 0, 98, 20, I18n.format("menu.quit", new Object[0])));
- //-------------------------------------------------------------------------------
- //Boutons
- this.buttonList.add(new GuiButton(80, this.width / 2 + -100, var3 + 72 + -24, 98, 20, I18n.format("\u00A79Site", new Object[0])));
- this.buttonList.add(new GuiButton(81, this.width / 2 + 2, var3 + 72 + -24, 98, 20, I18n.format("\u00A79Teamspeak", new Object[0])));
- //-------------------------------------------------------------------------------
- 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.
- */
- private void addSingleplayerMultiplayerButtons(int p_73969_1_, int p_73969_2_)
- {
- this.buttonList.add(new GuiButton(2, this.width / 2 - 100, p_73969_1_, I18n.format("\u00A7a Se connecter sur Vanadia", new Object[0])));
- this.buttonList.add(new GuiButton(1, this.width / 2 - 100, p_73969_1_ + p_73969_2_ * 1, I18n.format("\u00A76 Monde solo", new Object[0])));
- }
- /**
- * 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)
- {
- this.mc.displayGuiScreen(new GuiLoadingScreen()); }
- if (p_146284_1_.id == 14)
- {
- this.func_140005_i();
- }
- if (p_146284_1_.id == 4)
- {
- this.mc.shutdown();
- }
- //-----------------------------------------------------------------------------------------------------
- //Boutons
- if (p_146284_1_.id == 80)
- {
- URI u = URI.create("http://vanadia.fr");
- try{
- Desktop.getDesktop().browse(u);
- } catch(IOException e) {
- e.printStackTrace();
- }
- }
- if (p_146284_1_.id == 81)
- {
- URI u = URI.create("ts3server://ts.vanadia.fr?port=PORT");
- try{
- Desktop.getDesktop().browse(u);
- } catch(IOException e) {
- e.printStackTrace();
- }
- }
- //-----------------------------------------------------------------------------------------------------
- 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);
- }
- }
- private void renderBackGround()
- {
- GL11.glViewport(0, 0, 256, 256);
- this.mc.getTextureManager().bindTexture(backGround);
- GL11.glDisable(GL11.GL_TEXTURE_2D);
- GL11.glEnable(GL11.GL_TEXTURE_2D);
- GL11.glViewport(0, 0, this.mc.displayWidth, this.mc.displayHeight);
- Tessellator tessellator = Tessellator.instance;
- tessellator.startDrawingQuads();
- 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);
- tessellator.setColorRGBA_F(1.0F, 1.0F, 1.0F, 1.0F);
- int k = this.width;
- int l = this.height;
- tessellator.addVertexWithUV(0, 0, this.zLevel, 0, 0);
- tessellator.addVertexWithUV(0, l, this.zLevel, 0, 1);
- tessellator.addVertexWithUV(k, l, this.zLevel, 1, 1);
- tessellator.addVertexWithUV(k, 0, this.zLevel, 1, 0);
- tessellator.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.renderBackGround();
- GL11.glEnable(GL11.GL_ALPHA_TEST);
- Tessellator var4 = Tessellator.instance;
- short var5 = 274;
- int var6 = this.width / 2 - var5 / 2;
- byte var7 = 30;
- int x = this.width / 2 + 0;
- int y = this.height / 2 + 35;
- int var53 = this.height - 144;
- 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();
- drawPlayerSkin(this.mc.getSession().getUsername(), 10, var53, 4);
- 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);
- }
- this.drawRectangle();
- super.drawScreen(p_73863_1_, p_73863_2_, p_73863_3_);
- int var50 = this.width / 2;
- int var51 = this.height / 4 + 48;
- String infoServ;
- if (infos.getPopulation().equals("???")){
- infoServ = "§eChargement...";
- }
- else if (infos.getPopulation().equals("")){
- infoServ = "§cServeur Fermé";
- }
- else{
- infoServ = ("§7Il y a actuellement " + infos.getPopulation()+ " joueurs de connecté(s) !");
- }
- int titleLen = this.fontRendererObj.getStringWidth("§7" + "@Copyright Vanadia");
- int titleLen2 = this.fontRendererObj.getStringWidth(infoServ);
- int titleLen3 = this.fontRendererObj.getStringWidth("§7" + "Vanadia V1 - 1.7.10");
- int titleLen4 = this.fontRendererObj.getStringWidth("§7" + "Informations concernant le serveur:");
- this.drawString(this.fontRendererObj, "§7" + "@Copyright Vanadia", var50 - titleLen / 2 ,var51 +118 , 0xffffff);
- this.drawString(this.fontRendererObj, "§7" + "Informations concernant le serveur:", var50 - titleLen4 / 2 ,var51 -40 , 0xffffff);
- this.drawString(this.fontRendererObj, infoServ, var50 -titleLen2 / 2, var51 -30 , 0xffffff);
- this.drawString(this.fontRendererObj, "§7" + "Vanadia V1 - 1.7.10", var50 - titleLen3 / 2, var51 -20 , 0xffffff);
- // pour le ping infos.drawIconPing(this, 85, 20, true);
- super.drawScreen(p_73863_1_, p_73863_2_, p_73863_3_);
- }
- public void drawPlayerSkin(String username, int x, int y, float scale)
- {
- RealmsScreen.bindFace(username);
- GL11.glColor4f(1.0f, 1.0f, 1.0f, 1.0f);
- GL11.glPushMatrix();
- GL11.glTranslatef(x, y, 0.0f);
- GL11.glScalef(scale, scale, 0.0f);
- // Tête
- this.drawTexturedModalRectSkin(4, 0, 8, 8, 8, 8);
- // Corps
- this.drawTexturedModalRectSkin(4, 8, 20, 20, 8, 12);
- // Bras G
- this.drawTexturedModalRectSkin(0, 8, 44, 20, 4, 12);
- // Bras D
- this.drawTexturedModalRectSkin(12, 8, 52, 20, 4, 12);
- // Jambe G
- this.drawTexturedModalRectSkin(8, 20, 12, 20, 4, 12);
- // Jambe D
- this.drawTexturedModalRectSkin(4, 20, 4, 20, 4, 12);
- GL11.glPopMatrix();
- }
- public void drawRectangle(){
- int var3 = this.height / 4 + 48;
- int xx = this.width / 2 - 120, widthX = this.width / 2 + 120; //milieu
- int yy = var3 + 116, heightY = var3 - 12;
- drawRect(xx, heightY, widthX, yy, 0x99000000);
- int x2 = this.width / 2 - 134, widthX2 = this.width / 2 + 134; //haut
- int y2 = var3 - 12, heightY2 = var3 - 48;
- drawRect(x2, heightY2, widthX2, y2, 0x99000000);
- int x3 = this.width / 2 - 50, widthX3 = this.width / 2 + 50; //bas
- int y3 = var3 + 116, heightY3 = var3 + 130;
- drawRect(x3, heightY3, widthX3, y3, 0x99000000);
- }
- public void drawTexturedModalRectSkin(int x, int y, int u, int v, int width, int height)
- {
- // La taille de la texture change
- float var7 = 0.015625f;
- float var8 = 0.03125f;
- Tessellator var9 = Tessellator.instance;
- var9.startDrawingQuads();
- var9.addVertexWithUV((double) (x + 0), (double) (y + height), (double) this.zLevel, (double) ((float) (u + 0) * var7), (double) ((float) (v + height) * var8));
- var9.addVertexWithUV((double) (x + width), (double) (y + height), (double) this.zLevel, (double) ((float) (u + width) * var7), (double) ((float) (v + height) * var8));
- var9.addVertexWithUV((double) (x + width), (double) (y + 0), (double) this.zLevel, (double) ((float) (u + width) * var7), (double) ((float) (v + 0) * var8));
- var9.addVertexWithUV((double) (x + 0), (double) (y + 0), (double) this.zLevel, (double) ((float) (u + 0) * var7), (double) ((float) (v + 0) * var8));
- var9.draw();
- }
- /**
- * 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);
- }
- }
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement