mirror of
https://github.com/PolyhedralDev/Terra.git
synced 2025-07-18 02:22:32 +00:00
Fix slope palette interaction with Elevation
This commit is contained in:
parent
171581c224
commit
dd33998cf8
@ -41,7 +41,6 @@ public class BiomeConfig extends TerraConfig {
|
||||
private final Palette<BlockData> slant;
|
||||
private final double ySlantOffsetTop;
|
||||
private final double ySlantOffsetBottom;
|
||||
private final double xzSlantOffset;
|
||||
|
||||
private String eq;
|
||||
|
||||
@ -136,7 +135,6 @@ public class BiomeConfig extends TerraConfig {
|
||||
} else slant = null;
|
||||
ySlantOffsetTop = getDouble("slant.y-offset.top", 0.25);
|
||||
ySlantOffsetBottom = getDouble("slant.y-offset.bottom", 0.25);
|
||||
xzSlantOffset = getDouble("slant.x-z-offset", 1);
|
||||
|
||||
//Make sure equation is non-null
|
||||
if(eq == null || eq.equals(""))
|
||||
@ -208,10 +206,6 @@ public class BiomeConfig extends TerraConfig {
|
||||
return ySlantOffsetBottom;
|
||||
}
|
||||
|
||||
public double getXZSlantOffset() {
|
||||
return xzSlantOffset;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Biome with ID " + getID() + " and noise equation " + eq;
|
||||
|
@ -83,16 +83,15 @@ public class TerraChunkGenerator extends GaeaChunkGenerator {
|
||||
private static Palette<BlockData> getPalette(int x, int y, int z, BiomeConfig c, ChunkInterpolator interpolator, ElevationInterpolator elevationInterpolator) {
|
||||
Palette<BlockData> slant = c.getSlant();
|
||||
if(slant != null) {
|
||||
double xzOffset = c.getXZSlantOffset();
|
||||
boolean north = interpolator.getNoise(x, y + elevationInterpolator.getElevation(x, (int) (z + xzOffset)), z + xzOffset) > 0;
|
||||
boolean south = interpolator.getNoise(x, y + elevationInterpolator.getElevation(x, (int) (z - xzOffset)), z - xzOffset) > 0;
|
||||
boolean east = interpolator.getNoise(x + xzOffset, y + elevationInterpolator.getElevation((int) (x + xzOffset), z), z) > 0;
|
||||
boolean west = interpolator.getNoise(x - xzOffset, y + elevationInterpolator.getElevation((int) (x - xzOffset), z), z) > 0;
|
||||
boolean north = interpolator.getNoise(x, y - elevationInterpolator.getElevation(x, z + 1), z + 1) > 0;
|
||||
boolean south = interpolator.getNoise(x, y - elevationInterpolator.getElevation(x, z - 1), z - 1) > 0;
|
||||
boolean east = interpolator.getNoise(x + 1, y - elevationInterpolator.getElevation(x + 1, z), z) > 0;
|
||||
boolean west = interpolator.getNoise(x - 1, y - elevationInterpolator.getElevation(x - 1, z), z) > 0;
|
||||
|
||||
double ySlantOffsetTop = c.getYSlantOffsetTop();
|
||||
double ySlantOffsetBottom = c.getYSlantOffsetBottom();
|
||||
boolean top = interpolator.getNoise(x, y + ySlantOffsetTop + elevationInterpolator.getElevation(x, z), z) > 0;
|
||||
boolean bottom = interpolator.getNoise(x, y - ySlantOffsetBottom + elevationInterpolator.getElevation(x, z), z) > 0;
|
||||
boolean top = interpolator.getNoise(x, y + ySlantOffsetTop - elevationInterpolator.getElevation(x, z), z) > 0;
|
||||
boolean bottom = interpolator.getNoise(x, y - ySlantOffsetBottom - elevationInterpolator.getElevation(x, z), z) > 0;
|
||||
|
||||
if((top && bottom) && (north || south || east || west) && (!(north && south && east && west))) return slant;
|
||||
}
|
||||
|
@ -18,9 +18,8 @@ prevent-smooth: true
|
||||
slant:
|
||||
palette: STONE
|
||||
y-offset:
|
||||
top: 1
|
||||
top: 0.25
|
||||
bottom: 0.25
|
||||
x-z-offset: 1
|
||||
|
||||
flora:
|
||||
chance: 40
|
||||
|
Loading…
x
Reference in New Issue
Block a user