mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-26 15:16:45 +01:00
Trying to make external generators easier to make.
This commit is contained in:
parent
e039bbd56a
commit
b1aa8fdd5e
@ -48,7 +48,7 @@ public class Copy extends SubCommand {
|
|||||||
final Location loc = plr.getLocation();
|
final Location loc = plr.getLocation();
|
||||||
final Plot plot1 = MainUtil.getPlot(loc);
|
final Plot plot1 = MainUtil.getPlot(loc);
|
||||||
if (plot1 == null) {
|
if (plot1 == null) {
|
||||||
return !sendMessage(plr, C.NOT_IN_PLOT);
|
return !MainUtil.sendMessage(plr, C.NOT_IN_PLOT);
|
||||||
}
|
}
|
||||||
if (!plot1.isAdded(plr.getUUID()) && !plr.hasPermission(Permissions.ADMIN)) {
|
if (!plot1.isAdded(plr.getUUID()) && !plr.hasPermission(Permissions.ADMIN)) {
|
||||||
MainUtil.sendMessage(plr, C.NO_PLOT_PERMS);
|
MainUtil.sendMessage(plr, C.NO_PLOT_PERMS);
|
||||||
|
@ -61,12 +61,13 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
final int[] zl = new int[size];
|
final int[] zl = new int[size];
|
||||||
final PlotBlock[] bl = new PlotBlock[size];
|
final PlotBlock[] bl = new PlotBlock[size];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
PseudoRandom random = new PseudoRandom();
|
||||||
for (x = bottom.getX(); x <= (top.getX() - 1); x++) {
|
for (x = bottom.getX(); x <= (top.getX() - 1); x++) {
|
||||||
for (int y = 1; y <= dpw.WALL_HEIGHT; y++) {
|
for (int y = 1; y <= dpw.WALL_HEIGHT; y++) {
|
||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -76,7 +77,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -86,7 +87,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -96,7 +97,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -121,12 +122,13 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
int x, z;
|
int x, z;
|
||||||
z = bottom.getZ();
|
z = bottom.getZ();
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
PseudoRandom random = new PseudoRandom();
|
||||||
final int y = dpw.WALL_HEIGHT + 1;
|
final int y = dpw.WALL_HEIGHT + 1;
|
||||||
for (x = bottom.getX(); x <= (top.getX() - 1); x++) {
|
for (x = bottom.getX(); x <= (top.getX() - 1); x++) {
|
||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
x = top.getX();
|
x = top.getX();
|
||||||
@ -134,7 +136,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
z = top.getZ();
|
z = top.getZ();
|
||||||
@ -142,7 +144,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
x = bottom.getX();
|
x = bottom.getX();
|
||||||
@ -150,7 +152,7 @@ public abstract class ClassicPlotManager extends SquarePlotManager {
|
|||||||
xl[i] = x;
|
xl[i] = x;
|
||||||
zl[i] = z;
|
zl[i] = z;
|
||||||
yl[i] = y;
|
yl[i] = y;
|
||||||
bl[i] = blocks[PseudoRandom.random(blocks.length)];
|
bl[i] = blocks[random.random(blocks.length)];
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
BlockManager.setBlocks(plotworld.worldname, xl, yl, zl, bl);
|
BlockManager.setBlocks(plotworld.worldname, xl, yl, zl, bl);
|
||||||
|
@ -31,11 +31,13 @@ import org.bukkit.Location;
|
|||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.block.Biome;
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.generator.BlockPopulator;
|
import org.bukkit.generator.BlockPopulator;
|
||||||
|
import org.bukkit.generator.ChunkGenerator.BiomeGrid;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.object.PlotGenerator;
|
import com.intellectualcrafters.plot.object.PlotGenerator;
|
||||||
import com.intellectualcrafters.plot.object.PlotLoc;
|
import com.intellectualcrafters.plot.object.PlotLoc;
|
||||||
import com.intellectualcrafters.plot.object.PlotManager;
|
import com.intellectualcrafters.plot.object.PlotManager;
|
||||||
import com.intellectualcrafters.plot.object.PlotWorld;
|
import com.intellectualcrafters.plot.object.PlotWorld;
|
||||||
|
import com.intellectualcrafters.plot.object.PseudoRandom;
|
||||||
import com.intellectualcrafters.plot.object.RegionWrapper;
|
import com.intellectualcrafters.plot.object.RegionWrapper;
|
||||||
import com.intellectualcrafters.plot.util.ChunkManager;
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
|
||||||
@ -217,7 +219,7 @@ public class HybridGen extends PlotGenerator {
|
|||||||
* generator
|
* generator
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public short[][] generateExtBlockSections(final World world, final Random random, final int cx, final int cz, final BiomeGrid biomes) {
|
public short[][] generateChunk(final World world, RegionWrapper plot, final PseudoRandom random, final int cx, final int cz, final BiomeGrid biomes, final short[][] result) {
|
||||||
if (this.doState) {
|
if (this.doState) {
|
||||||
final int prime = 13;
|
final int prime = 13;
|
||||||
int h = 1;
|
int h = 1;
|
||||||
@ -225,7 +227,6 @@ public class HybridGen extends PlotGenerator {
|
|||||||
h = (prime * h) + cz;
|
h = (prime * h) + cz;
|
||||||
this.state = h;
|
this.state = h;
|
||||||
}
|
}
|
||||||
this.result = new short[this.maxY / 16][];
|
|
||||||
if (this.plotworld.PLOT_BEDROCK) {
|
if (this.plotworld.PLOT_BEDROCK) {
|
||||||
for (short x = 0; x < 16; x++) {
|
for (short x = 0; x < 16; x++) {
|
||||||
for (short z = 0; z < 16; z++) {
|
for (short z = 0; z < 16; z++) {
|
||||||
@ -233,7 +234,6 @@ public class HybridGen extends PlotGenerator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final RegionWrapper plot = ChunkManager.CURRENT_PLOT_CLEAR;
|
|
||||||
if (plot != null) {
|
if (plot != null) {
|
||||||
final int X = cx << 4;
|
final int X = cx << 4;
|
||||||
final int Z = cz << 4;
|
final int Z = cz << 4;
|
||||||
|
@ -20,16 +20,26 @@
|
|||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
package com.intellectualcrafters.plot.object;
|
package com.intellectualcrafters.plot.object;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.generator.BlockPopulator;
|
import org.bukkit.generator.BlockPopulator;
|
||||||
import org.bukkit.generator.ChunkGenerator;
|
import org.bukkit.generator.ChunkGenerator;
|
||||||
|
|
||||||
import com.intellectualcrafters.plot.PlotSquared;
|
import com.intellectualcrafters.plot.PlotSquared;
|
||||||
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
|
||||||
public abstract class PlotGenerator extends ChunkGenerator {
|
public abstract class PlotGenerator extends ChunkGenerator {
|
||||||
|
|
||||||
|
private short[][] result;
|
||||||
|
private int X;
|
||||||
|
private int Z;
|
||||||
|
private PseudoRandom random = new PseudoRandom();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<BlockPopulator> getDefaultPopulators(World world) {
|
public List<BlockPopulator> getDefaultPopulators(World world) {
|
||||||
PlotSquared.loadWorld(world.getName(), this);
|
PlotSquared.loadWorld(world.getName(), this);
|
||||||
@ -54,6 +64,80 @@ public abstract class PlotGenerator extends ChunkGenerator {
|
|||||||
return getPopulators(world.getName());
|
return getPopulators(world.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public short[][] generateExtBlockSections(final World world, final Random r, final int cx, final int cz, final BiomeGrid biomes) {
|
||||||
|
final int prime = 13;
|
||||||
|
int h = 1;
|
||||||
|
h = (prime * h) + cx;
|
||||||
|
h = (prime * h) + cz;
|
||||||
|
this.random.state = h;
|
||||||
|
this.result = new short[256 / 16][];
|
||||||
|
PlotWorld plotworld = PlotSquared.getPlotWorld(world.getName());
|
||||||
|
Biome biome = Biome.valueOf(plotworld.PLOT_BIOME);
|
||||||
|
if (ChunkManager.FORCE_PASTE) {
|
||||||
|
X = cx << 4;
|
||||||
|
Z = cz << 4;
|
||||||
|
for (short x = 0; x < 16; x++) {
|
||||||
|
for (short z = 0; z < 16; z++) {
|
||||||
|
if (biomes != null) {
|
||||||
|
biomes.setBiome(x, z, biome);
|
||||||
|
}
|
||||||
|
final PlotLoc loc = new PlotLoc((short) (X + x), (short) (Z + z));
|
||||||
|
final HashMap<Short, Short> blocks = ChunkManager.GENERATE_BLOCKS.get(loc);
|
||||||
|
for (final Entry<Short, Short> entry : blocks.entrySet()) {
|
||||||
|
setBlock(x, entry.getKey(), z, entry.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this.result;
|
||||||
|
}
|
||||||
|
this.result = generateChunk(world, ChunkManager.CURRENT_PLOT_CLEAR, random, cx, cz, biomes, result);
|
||||||
|
if (ChunkManager.CURRENT_PLOT_CLEAR != null) {
|
||||||
|
PlotLoc loc;
|
||||||
|
for (Entry<PlotLoc, HashMap<Short, Short>> entry : ChunkManager.GENERATE_BLOCKS.entrySet()) {
|
||||||
|
for (Entry<Short, Short> entry2 : entry.getValue().entrySet()) {
|
||||||
|
loc = entry.getKey();
|
||||||
|
setBlock(loc.x, entry2.getKey(), loc.z, entry2.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setBlock(final int x, final int y, final int z, final short blkid) {
|
||||||
|
if (result[y >> 4] == null) {
|
||||||
|
result[y >> 4] = new short[4096];
|
||||||
|
}
|
||||||
|
result[y >> 4][((y & 0xF) << 8) | (z << 4) | x] = blkid;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean contains(final RegionWrapper plot, final int x, final int z) {
|
||||||
|
int xx = X + x;
|
||||||
|
int zz = Z + z;
|
||||||
|
return ((xx >= plot.minX) && (xx <= plot.maxX) && (zz >= plot.minZ) && (zz <= plot.maxZ));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <b>random</b> is a optimized random number generator.<br>
|
||||||
|
* - Change the state to have the same chunk random each time it generates<br>
|
||||||
|
* <b>requiredRegion</b> If a plot is being regenerated, you are only required to generate content in this area<br>
|
||||||
|
* - use the contains(RegionWrapper, x, z) method to check if the region contains a location<br>
|
||||||
|
* - You can ignore this if you do not want to further optimize your generator<br>
|
||||||
|
* - will be null if no restrictions are set<br>
|
||||||
|
* <b>result</b> is the standard 2D block data array used for generation<br>
|
||||||
|
* <b>biomes</b> is the standard BiomeGrid used for generation
|
||||||
|
*
|
||||||
|
* @param world
|
||||||
|
* @param random
|
||||||
|
* @param cx
|
||||||
|
* @param cz
|
||||||
|
* @param requiredRegion
|
||||||
|
* @param biomes
|
||||||
|
* @param result
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public abstract short[][] generateChunk(final World world, RegionWrapper requiredRegion, final PseudoRandom random, final int cx, final int cz, final BiomeGrid biomes, final short[][] result);
|
||||||
|
|
||||||
public abstract List<BlockPopulator> getPopulators(String world);
|
public abstract List<BlockPopulator> getPopulators(String world);
|
||||||
|
|
||||||
public abstract void init(PlotWorld plotworld);
|
public abstract void init(PlotWorld plotworld);
|
||||||
@ -62,5 +146,4 @@ public abstract class PlotGenerator extends ChunkGenerator {
|
|||||||
|
|
||||||
public abstract PlotManager getPlotManager();
|
public abstract PlotManager getPlotManager();
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,72 @@
|
|||||||
|
package com.intellectualcrafters.plot.object;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
|
||||||
|
import org.bukkit.Chunk;
|
||||||
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.generator.BlockPopulator;
|
||||||
|
|
||||||
|
import com.intellectualcrafters.plot.util.ChunkManager;
|
||||||
|
import com.intellectualcrafters.plot.util.bukkit.BukkitUtil;
|
||||||
|
|
||||||
|
public abstract class PlotPopulator extends BlockPopulator{
|
||||||
|
|
||||||
|
private int X;
|
||||||
|
private int Z;
|
||||||
|
private World world;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void populate(World world, Random rand, Chunk chunk) {
|
||||||
|
this.world = world;
|
||||||
|
this.X = chunk.getX() << 4;
|
||||||
|
this.Z = chunk.getZ() << 4;
|
||||||
|
|
||||||
|
if (ChunkManager.FORCE_PASTE) {
|
||||||
|
for (short x = 0; x < 16; x++) {
|
||||||
|
for (short z = 0; z < 16; z++) {
|
||||||
|
final PlotLoc loc = new PlotLoc((short) (X + x), (short) (Z + z));
|
||||||
|
final HashMap<Short, Byte> blocks = ChunkManager.GENERATE_DATA.get(loc);
|
||||||
|
for (final Entry<Short, Byte> entry : blocks.entrySet()) {
|
||||||
|
setBlock(x, entry.getKey(), z, entry.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract void populate(World world, RegionWrapper requiredRegion, PseudoRandom random, int cx, int cz);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the id and data at a location (x, y, z) must be between [0,15], [0,255], [0,15]
|
||||||
|
* @param x
|
||||||
|
* @param y
|
||||||
|
* @param z
|
||||||
|
* @param id
|
||||||
|
* @param data
|
||||||
|
*/
|
||||||
|
public void setBlock(int x, int y, int z, short id, byte data) {
|
||||||
|
BukkitUtil.setBlock(world, X + x, y, Z + z, id, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the data at a location (x, y, z) must be between [0,15], [0,255], [0,15]
|
||||||
|
* @param x
|
||||||
|
* @param y
|
||||||
|
* @param z
|
||||||
|
* @param data
|
||||||
|
*/
|
||||||
|
public void setBlock(int x, int y, int z, byte data) {
|
||||||
|
world.getBlockAt(X + x, y, Z + z).setTypeId(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean contains(final RegionWrapper plot, final int x, final int z) {
|
||||||
|
int xx = X + x;
|
||||||
|
int zz = Z + z;
|
||||||
|
return ((xx >= plot.minX) && (xx <= plot.maxX) && (zz >= plot.minZ) && (zz <= plot.maxZ));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,22 +1,22 @@
|
|||||||
package com.intellectualcrafters.plot.object;
|
package com.intellectualcrafters.plot.object;
|
||||||
|
|
||||||
public class PseudoRandom {
|
public class PseudoRandom {
|
||||||
private static long state = 1;
|
public long state = 1;
|
||||||
|
|
||||||
public static long nextLong() {
|
public long nextLong() {
|
||||||
final long a = state;
|
final long a = state;
|
||||||
state = xorShift64(a);
|
state = xorShift64(a);
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static long xorShift64(long a) {
|
public long xorShift64(long a) {
|
||||||
a ^= (a << 21);
|
a ^= (a << 21);
|
||||||
a ^= (a >>> 35);
|
a ^= (a >>> 35);
|
||||||
a ^= (a << 4);
|
a ^= (a << 4);
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int random(final int n) {
|
public int random(final int n) {
|
||||||
if (n == 1) {
|
if (n == 1) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -11,8 +11,11 @@ import com.intellectualcrafters.plot.object.PlotLoc;
|
|||||||
import com.intellectualcrafters.plot.object.RegionWrapper;
|
import com.intellectualcrafters.plot.object.RegionWrapper;
|
||||||
|
|
||||||
public abstract class ChunkManager {
|
public abstract class ChunkManager {
|
||||||
|
|
||||||
public static ChunkManager manager = null;
|
public static ChunkManager manager = null;
|
||||||
public static RegionWrapper CURRENT_PLOT_CLEAR = null;
|
public static RegionWrapper CURRENT_PLOT_CLEAR = null;
|
||||||
|
public static boolean FORCE_PASTE = false;
|
||||||
|
|
||||||
public static HashMap<PlotLoc, HashMap<Short, Short>> GENERATE_BLOCKS = new HashMap<>();
|
public static HashMap<PlotLoc, HashMap<Short, Short>> GENERATE_BLOCKS = new HashMap<>();
|
||||||
public static HashMap<PlotLoc, HashMap<Short, Byte>> GENERATE_DATA = new HashMap<>();
|
public static HashMap<PlotLoc, HashMap<Short, Byte>> GENERATE_DATA = new HashMap<>();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user