Rain & Snow toggle
This commit is contained in:
parent
9c87f8de6c
commit
4d6c64ade6
66846
javascript/classes.js
66846
javascript/classes.js
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -146,6 +146,18 @@ public class Config {
|
|||
return Minecraft.getMinecraft().gameSettings.ofClouds != 0 ? Minecraft.getMinecraft().gameSettings.ofClouds == 3 : false;
|
||||
}
|
||||
|
||||
public static boolean isRainFancy() {
|
||||
return Minecraft.getMinecraft().gameSettings.ofRain == 0 ? Minecraft.getMinecraft().gameSettings.fancyGraphics : Minecraft.getMinecraft().gameSettings.ofRain == 2;
|
||||
}
|
||||
|
||||
public static boolean isRainOff() {
|
||||
return Minecraft.getMinecraft().gameSettings.ofRain == 3;
|
||||
}
|
||||
|
||||
public static boolean isRainSplash() {
|
||||
return Minecraft.getMinecraft().gameSettings.ofRainSplash;
|
||||
}
|
||||
|
||||
public static int limit(int p_limit_0_, int p_limit_1_, int p_limit_2_) {
|
||||
return p_limit_0_ < p_limit_1_ ? p_limit_1_ : (p_limit_0_ > p_limit_2_ ? p_limit_2_ : p_limit_0_);
|
||||
}
|
||||
|
|
|
@ -24,7 +24,7 @@ public class GuiAnimations extends GuiScreen {
|
|||
GameSettings.Options.ANIMATED_SMOKE,
|
||||
GameSettings.Options.VOID_PARTICLES,
|
||||
GameSettings.Options.WATER_PARTICLES,
|
||||
//GameSettings.Options.RAIN_SPLASH,
|
||||
GameSettings.Options.RAIN_SPLASH,
|
||||
GameSettings.Options.PORTAL_PARTICLES,
|
||||
GameSettings.Options.POTION_PARTICLES,
|
||||
GameSettings.Options.DRIPPING_WATER_LAVA,
|
||||
|
|
|
@ -13,7 +13,7 @@ public class GuiDetails extends GuiScreen {
|
|||
protected String title;
|
||||
private GameSettings settings;
|
||||
//private static GameSettings.Options[] enumOptions = new GameSettings.Options[] {GameSettings.Options.CLOUDS, GameSettings.Options.CLOUD_HEIGHT, GameSettings.Options.TREES, GameSettings.Options.RAIN, GameSettings.Options.SKY, GameSettings.Options.STARS, GameSettings.Options.SUN_MOON, GameSettings.Options.SHOW_CAPES, GameSettings.Options.TRANSLUCENT_BLOCKS, GameSettings.Options.HELD_ITEM_TOOLTIPS, GameSettings.Options.DROPPED_ITEMS, GameSettings.Options.ENTITY_SHADOWS, GameSettings.Options.VIGNETTE, GameSettings.Options.DYNAMIC_FOV};
|
||||
private static GameSettings.Options[] enumOptions = new GameSettings.Options[] { GameSettings.Options.CLOUDS, GameSettings.Options.CLOUD_HEIGHT};
|
||||
private static GameSettings.Options[] enumOptions = new GameSettings.Options[] { GameSettings.Options.CLOUDS, GameSettings.Options.CLOUD_HEIGHT, GameSettings.Options.RAIN};
|
||||
|
||||
public GuiDetails(GuiScreen p_i47_1_) {
|
||||
this.prevScreen = p_i47_1_;
|
||||
|
|
|
@ -11,12 +11,6 @@ import net.lax1dude.eaglercraft.v1_8.opengl.VertexFormat;
|
|||
import net.lax1dude.eaglercraft.v1_8.opengl.WorldRenderer;
|
||||
|
||||
public class VertexBuffer {
|
||||
//private IBufferGL vbo = null;
|
||||
|
||||
public void bindBuffer(IBufferGL vbo) {
|
||||
OpenGLManager.glBindBuffer(RealOpenGLEnums.GL_ARRAY_BUFFER, vbo);
|
||||
}
|
||||
|
||||
public void func_181722_a(WorldRenderer p_181722_1_, int parInt1) {
|
||||
if(p_181722_1_.getVertexCount() > 0) {
|
||||
EaglercraftGPU.glNewList(parInt1, GL_COMPILE);
|
||||
|
@ -26,8 +20,4 @@ public class VertexBuffer {
|
|||
EaglercraftGPU.glEndList();
|
||||
}
|
||||
}
|
||||
|
||||
public void unbindBuffer(IBufferGL vbo) {
|
||||
OpenGLManager.glBindBuffer(RealOpenGLEnums.GL_ARRAY_BUFFER, vbo);
|
||||
}
|
||||
}
|
|
@ -386,7 +386,7 @@ public class EaglercraftGPU {
|
|||
FixedFunctionPipeline.optimize();
|
||||
}
|
||||
|
||||
private static FixedFunctionPipeline lastRender = null;
|
||||
public static FixedFunctionPipeline lastRender = null;
|
||||
private static int lastMode = 0;
|
||||
private static int lastCount = 0;
|
||||
|
||||
|
|
|
@ -1321,74 +1321,72 @@ public class EntityRenderer implements IResourceManagerReloadListener {
|
|||
}
|
||||
|
||||
private void addRainParticles() {
|
||||
if (DeferredStateManager.isDeferredRenderer())
|
||||
if (DeferredStateManager.isDeferredRenderer()) {
|
||||
return;
|
||||
float f = this.mc.theWorld.getRainStrength(1.0F);
|
||||
if (!this.mc.gameSettings.fancyGraphics) {
|
||||
f /= 2.0F;
|
||||
}
|
||||
|
||||
if (f != 0.0F) {
|
||||
this.random.setSeed((long) this.rendererUpdateCount * 312987231L);
|
||||
Entity entity = this.mc.getRenderViewEntity();
|
||||
WorldClient worldclient = this.mc.theWorld;
|
||||
BlockPos blockpos = new BlockPos(entity);
|
||||
byte b0 = 10;
|
||||
double d0 = 0.0D;
|
||||
double d1 = 0.0D;
|
||||
double d2 = 0.0D;
|
||||
int i = 0;
|
||||
int j = (int) (100.0F * f * f);
|
||||
if (this.mc.gameSettings.particleSetting == 1) {
|
||||
j >>= 1;
|
||||
} else if (this.mc.gameSettings.particleSetting == 2) {
|
||||
j = 0;
|
||||
}
|
||||
float f = this.mc.theWorld.getRainStrength(1.0F);
|
||||
|
||||
for (int k = 0; k < j; ++k) {
|
||||
BlockPos blockpos1 = worldclient
|
||||
.getPrecipitationHeight(blockpos.add(this.random.nextInt(b0) - this.random.nextInt(b0), 0,
|
||||
this.random.nextInt(b0) - this.random.nextInt(b0)));
|
||||
BiomeGenBase biomegenbase = worldclient.getBiomeGenForCoords(blockpos1);
|
||||
BlockPos blockpos2 = blockpos1.down();
|
||||
Block block = worldclient.getBlockState(blockpos2).getBlock();
|
||||
if (blockpos1.getY() <= blockpos.getY() + b0 && blockpos1.getY() >= blockpos.getY() - b0
|
||||
&& biomegenbase.canSpawnLightningBolt()
|
||||
&& biomegenbase.getFloatTemperature(blockpos1) >= 0.15F) {
|
||||
double d3 = this.random.nextDouble();
|
||||
double d4 = this.random.nextDouble();
|
||||
if (block.getMaterial() == Material.lava) {
|
||||
this.mc.theWorld.spawnParticle(EnumParticleTypes.SMOKE_NORMAL, (double) blockpos1.getX() + d3,
|
||||
(double) ((float) blockpos1.getY() + 0.1F) - block.getBlockBoundsMinY(),
|
||||
(double) blockpos1.getZ() + d4, 0.0D, 0.0D, 0.0D, new int[0]);
|
||||
} else if (block.getMaterial() != Material.air) {
|
||||
block.setBlockBoundsBasedOnState(worldclient, blockpos2);
|
||||
++i;
|
||||
if (this.random.nextInt(i) == 0) {
|
||||
d0 = (double) blockpos2.getX() + d3;
|
||||
d1 = (double) ((float) blockpos2.getY() + 0.1F) + block.getBlockBoundsMaxY() - 1.0D;
|
||||
d2 = (double) blockpos2.getZ() + d4;
|
||||
}
|
||||
if (!Config.isRainFancy()) {
|
||||
f /= 2.0F;
|
||||
}
|
||||
|
||||
this.mc.theWorld.spawnParticle(EnumParticleTypes.WATER_DROP, (double) blockpos2.getX() + d3,
|
||||
(double) ((float) blockpos2.getY() + 0.1F) + block.getBlockBoundsMaxY(),
|
||||
(double) blockpos2.getZ() + d4, 0.0D, 0.0D, 0.0D, new int[0]);
|
||||
}
|
||||
}
|
||||
}
|
||||
if (f != 0.0F && Config.isRainSplash()) {
|
||||
this.random.setSeed((long)this.rendererUpdateCount * 312987231L);
|
||||
Entity entity = this.mc.getRenderViewEntity();
|
||||
WorldClient worldclient = this.mc.theWorld;
|
||||
BlockPos blockpos = new BlockPos(entity);
|
||||
byte b0 = 10;
|
||||
double d0 = 0.0D;
|
||||
double d1 = 0.0D;
|
||||
double d2 = 0.0D;
|
||||
int i = 0;
|
||||
int j = (int)(100.0F * f * f);
|
||||
|
||||
if (i > 0 && this.random.nextInt(3) < this.rainSoundCounter++) {
|
||||
this.rainSoundCounter = 0;
|
||||
if (d1 > (double) (blockpos.getY() + 1) && worldclient.getPrecipitationHeight(blockpos)
|
||||
.getY() > MathHelper.floor_float((float) blockpos.getY())) {
|
||||
this.mc.theWorld.playSound(d0, d1, d2, "ambient.weather.rain", 0.1F, 0.5F, false);
|
||||
} else {
|
||||
this.mc.theWorld.playSound(d0, d1, d2, "ambient.weather.rain", 0.2F, 1.0F, false);
|
||||
}
|
||||
}
|
||||
if (this.mc.gameSettings.particleSetting == 1) {
|
||||
j >>= 1;
|
||||
} else if (this.mc.gameSettings.particleSetting == 2) {
|
||||
j = 0;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
for (int k = 0; k < j; ++k) {
|
||||
BlockPos blockpos1 = worldclient.getPrecipitationHeight(blockpos.add(this.random.nextInt(b0) - this.random.nextInt(b0), 0, this.random.nextInt(b0) - this.random.nextInt(b0)));
|
||||
BiomeGenBase biomegenbase = worldclient.getBiomeGenForCoords(blockpos1);
|
||||
BlockPos blockpos2 = blockpos1.down();
|
||||
Block block = worldclient.getBlockState(blockpos2).getBlock();
|
||||
|
||||
if (blockpos1.getY() <= blockpos.getY() + b0 && blockpos1.getY() >= blockpos.getY() - b0 && biomegenbase.canSpawnLightningBolt() && biomegenbase.getFloatTemperature(blockpos1) >= 0.15F) {
|
||||
double d3 = this.random.nextDouble();
|
||||
double d4 = this.random.nextDouble();
|
||||
|
||||
if (block.getMaterial() == Material.lava) {
|
||||
this.mc.theWorld.spawnParticle(EnumParticleTypes.SMOKE_NORMAL, (double)blockpos1.getX() + d3, (double)((float)blockpos1.getY() + 0.1F) - block.getBlockBoundsMinY(), (double)blockpos1.getZ() + d4, 0.0D, 0.0D, 0.0D, new int[0]);
|
||||
} else if (block.getMaterial() != Material.air) {
|
||||
block.setBlockBoundsBasedOnState(worldclient, blockpos2);
|
||||
++i;
|
||||
|
||||
if (this.random.nextInt(i) == 0) {
|
||||
d0 = (double)blockpos2.getX() + d3;
|
||||
d1 = (double)((float)blockpos2.getY() + 0.1F) + block.getBlockBoundsMaxY() - 1.0D;
|
||||
d2 = (double)blockpos2.getZ() + d4;
|
||||
}
|
||||
|
||||
this.mc.theWorld.spawnParticle(EnumParticleTypes.WATER_DROP, (double)blockpos2.getX() + d3, (double)((float)blockpos2.getY() + 0.1F) + block.getBlockBoundsMaxY(), (double)blockpos2.getZ() + d4, 0.0D, 0.0D, 0.0D, new int[0]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (i > 0 && this.random.nextInt(3) < this.rainSoundCounter++) {
|
||||
this.rainSoundCounter = 0;
|
||||
|
||||
if (d1 > (double)(blockpos.getY() + 1) && worldclient.getPrecipitationHeight(blockpos).getY() > MathHelper.floor_float((float)blockpos.getY())) {
|
||||
this.mc.theWorld.playSound(d0, d1, d2, "ambient.weather.rain", 0.1F, 0.5F, false);
|
||||
} else {
|
||||
this.mc.theWorld.playSound(d0, d1, d2, "ambient.weather.rain", 0.2F, 1.0F, false);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**+
|
||||
* Render rain and snow
|
||||
|
@ -1396,6 +1394,10 @@ public class EntityRenderer implements IResourceManagerReloadListener {
|
|||
protected void renderRainSnow(float partialTicks) {
|
||||
float f = this.mc.theWorld.getRainStrength(partialTicks);
|
||||
if (f > 0.0F) {
|
||||
if (Config.isRainOff()){
|
||||
return;
|
||||
}
|
||||
|
||||
boolean df = DeferredStateManager.isInDeferredPass();
|
||||
this.enableLightmap();
|
||||
Entity entity = this.mc.getRenderViewEntity();
|
||||
|
@ -1426,15 +1428,23 @@ public class EntityRenderer implements IResourceManagerReloadListener {
|
|||
double d2 = entity.lastTickPosZ + (entity.posZ - entity.lastTickPosZ) * (double) partialTicks;
|
||||
int l = MathHelper.floor_double(d1);
|
||||
byte b0 = 5;
|
||||
|
||||
if (df) {
|
||||
b0 = 8;
|
||||
} else if (this.mc.gameSettings.fancyGraphics) {
|
||||
b0 = 10;
|
||||
}
|
||||
} else if (Config.isRainFancy()) {
|
||||
b0 = 10;
|
||||
}
|
||||
|
||||
byte b1 = -1;
|
||||
float f1 = (float) this.rendererUpdateCount + partialTicks;
|
||||
worldrenderer.setTranslation(-d0, -d1, -d2);
|
||||
|
||||
if (df) {
|
||||
b0 = 8;
|
||||
} else if (Config.isRainFancy()) {
|
||||
b0 = 10;
|
||||
}
|
||||
|
||||
GlStateManager.color(1.0F, 1.0F, 1.0F, 1.0F);
|
||||
BlockPos.MutableBlockPos blockpos$mutableblockpos = new BlockPos.MutableBlockPos();
|
||||
|
||||
|
|
|
@ -202,6 +202,7 @@ public class GameSettings {
|
|||
public int clouds = 2;
|
||||
public int ofClouds = 0;
|
||||
public float ofCloudsHeight = 0.0F;
|
||||
public int ofRain = 0;
|
||||
|
||||
//Optifine Animations
|
||||
public int ofAnimatedWater = 0;
|
||||
|
@ -220,6 +221,7 @@ public class GameSettings {
|
|||
public boolean ofDrippingWaterLava = true;
|
||||
public boolean ofAnimatedTerrain = true;
|
||||
public boolean ofAnimatedTextures = true;
|
||||
public boolean ofRainSplash = true;
|
||||
|
||||
//Performance Settings
|
||||
public boolean ofSmoothFps = false;
|
||||
|
@ -663,6 +665,18 @@ public class GameSettings {
|
|||
MathHelper.fastMath = ofFastMath;
|
||||
}
|
||||
|
||||
if (parOptions == GameSettings.Options.RAIN) {
|
||||
++this.ofRain;
|
||||
|
||||
if (this.ofRain > 3) {
|
||||
this.ofRain = 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (parOptions == GameSettings.Options.RAIN_SPLASH) {
|
||||
this.ofRainSplash = !this.ofRainSplash;
|
||||
}
|
||||
|
||||
this.saveOptions();
|
||||
}
|
||||
|
||||
|
@ -928,6 +942,22 @@ public class GameSettings {
|
|||
return s + getTranslation(KEYS_DYNAMIC_LIGHTS, k);
|
||||
} else if (parOptions == GameSettings.Options.FAST_MATH) {
|
||||
return ofFastMath ? s + "ON" : s + "OFF";
|
||||
} else if (parOptions == GameSettings.Options.RAIN) {
|
||||
switch (this.ofRain) {
|
||||
case 1:
|
||||
return s + "Fast";
|
||||
|
||||
case 2:
|
||||
return s + "Fancy";
|
||||
|
||||
case 3:
|
||||
return s + "OFF";
|
||||
|
||||
default:
|
||||
return s + "Default";
|
||||
}
|
||||
} else if (parOptions == GameSettings.Options.RAIN_SPLASH) {
|
||||
return this.ofRainSplash ? s + "ON" : s + "OFF";
|
||||
} else {
|
||||
return s;
|
||||
}
|
||||
|
@ -1347,6 +1377,15 @@ public class GameSettings {
|
|||
MathHelper.fastMath = ofFastMath;
|
||||
}
|
||||
|
||||
if (astring[0].equals("ofRain") && astring.length >= 2) {
|
||||
this.ofRain = Integer.valueOf(astring[1]).intValue();
|
||||
this.ofRain = Config.limit(this.ofRain, 0, 3);
|
||||
}
|
||||
|
||||
if (astring[0].equals("ofRainSplash") && astring.length >= 2) {
|
||||
this.ofRainSplash = Boolean.valueOf(astring[1]).booleanValue();
|
||||
}
|
||||
|
||||
Keyboard.setFunctionKeyModifier(keyBindFunction.getKeyCode());
|
||||
|
||||
for (SoundCategory soundcategory : SoundCategory.values()) {
|
||||
|
@ -1484,6 +1523,8 @@ public class GameSettings {
|
|||
printwriter.println("ofCloudsHeight:" + this.ofCloudsHeight);
|
||||
printwriter.println("ofDynamicLights:" + this.ofDynamicLights);
|
||||
printwriter.println("ofFastMath:" + ofFastMath);
|
||||
printwriter.println("ofRain:" + this.ofRain);
|
||||
printwriter.println("ofRainSplash:" + this.ofRainSplash);
|
||||
|
||||
for (KeyBinding keybinding : this.keyBindings) {
|
||||
printwriter.println("key_" + keybinding.getKeyDescription() + ":" + keybinding.getKeyCode());
|
||||
|
@ -1645,6 +1686,7 @@ public class GameSettings {
|
|||
DRIPPING_WATER_LAVA("Dripping Water/Lava", false, false),
|
||||
ANIMATED_TERRAIN("Terrain Animated", false, false),
|
||||
ANIMATED_TEXTURES("Textures Animated", false, false),
|
||||
RAIN_SPLASH("Rain Splash", false, false),
|
||||
AO_LEVEL("Smooth Lighting Level", true, false),
|
||||
USE_VBO("Use VBOs", false, false),
|
||||
CUSTOM_SKY("Custom Sky", false, false),
|
||||
|
@ -1657,7 +1699,8 @@ public class GameSettings {
|
|||
CHUNK_UPDATES("Chunk Updates", false, false),
|
||||
CLOUDS("Clouds", false, false),
|
||||
CLOUD_HEIGHT("Cloud Height", true, false),
|
||||
DYNAMIC_LIGHTS("Dynamic Lights", false, false);
|
||||
DYNAMIC_LIGHTS("Dynamic Lights", false, false),
|
||||
RAIN("Rain & Snow", false, false);
|
||||
|
||||
private final boolean enumFloat;
|
||||
private final boolean enumBoolean;
|
||||
|
@ -1788,6 +1831,7 @@ public class GameSettings {
|
|||
this.ofDrippingWaterLava = p_setAllAnimations_1_;
|
||||
this.ofAnimatedTerrain = p_setAllAnimations_1_;
|
||||
this.ofAnimatedTextures = p_setAllAnimations_1_;
|
||||
this.ofRainSplash = p_setAllAnimations_1_;
|
||||
}
|
||||
|
||||
private void updateWaterOpacity() {
|
||||
|
|
Loading…
Reference in New Issue
Block a user