fixed plot generation for even numbered plot sized and road widths
This commit is contained in:
		| @@ -221,4 +221,11 @@ public class Cuboid implements Comparable<Cuboid> { | ||||
| 		 | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	@Override | ||||
| 	public String toString() { | ||||
| 		return String.format("{Cuboid minX=%d, minY=%d, minZ=%d, maxX=%d, maxY=%d, maxZ=%d}", minX, minY, minZ, maxX, maxY, maxZ); | ||||
| 	} | ||||
| 	 | ||||
| 	 | ||||
| } | ||||
|   | ||||
| @@ -108,22 +108,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 		if(DEBUG){log.info("Checking config");} | ||||
| 		Configuration config = getConfig(); | ||||
| 		if(!config.contains("version")){ | ||||
| 			//new or upgrading from ancient | ||||
| 			if(config.contains("plot.sizeX")){ | ||||
| 				if(DEBUG){log.info("Upgrading from a 0.4.6 config or newer.");} | ||||
| 				//upgrading from ancient | ||||
| 				int oldSizeX = safeGetIntFromConfig(config, "plot.sizeX"); | ||||
| 				int oldSizeZ = safeGetIntFromConfig(config, "plot.sizeZ"); | ||||
| 				int oldRoadWidth = safeGetIntFromConfig(config, "road.width"); | ||||
| 				oldSizeX -= oldRoadWidth; | ||||
| 				oldSizeZ -= oldRoadWidth; | ||||
| 				config.set("plot.sizeX", oldSizeX); | ||||
| 				config.set("plot.sizeZ", oldSizeZ); | ||||
| 				saveConfig(); | ||||
| 				if(DEBUG){log.info("Plot size updated");} | ||||
| 			}else{ | ||||
| 				if(DEBUG){log.info("No config exists.  Assuming new installation.");} | ||||
| 			} | ||||
| 			//new | ||||
| 			if(DEBUG){log.info("No config exists.  Assuming new installation.");} | ||||
| 		}else{ | ||||
| 			int configVersion = safeGetIntFromConfig(config, "version"); | ||||
| 			if(DEBUG){log.info(String.format("Updating config from version v%s to v%s.", configVersion, version));} | ||||
| @@ -135,6 +121,9 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			if(DEBUG){log.info("Config updated");} | ||||
| 		} | ||||
| 		 | ||||
| 		config.set("version", version); | ||||
| 		saveConfig(); | ||||
| 		 | ||||
| 		config.options().copyDefaults(true); | ||||
| 		 | ||||
| 		if(DEBUG){log.info("Reading configuration from file.");} | ||||
| @@ -220,7 +209,7 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 		 | ||||
| 		_spawnRegion = regionManager.getRegion("Spawn"); | ||||
| 		if(_spawnRegion == null){ | ||||
| 			_spawnRegion = new ProtectedCuboidRegion("Spawn", getPlotMin(0, 0), this.getPlotMax(0,  0)); | ||||
| 			_spawnRegion = new ProtectedCuboidRegion("Spawn", getPlotMin(0, 0), getPlotMax(0, 0)); | ||||
| 			_spawnRegion.setPriority(1); | ||||
| 			_spawnRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | ||||
| 			_spawnRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | ||||
| @@ -232,11 +221,27 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			_spawnRegion.setFlag(DefaultFlag.LAVA_FLOW, StateFlag.State.DENY); | ||||
| 			_spawnRegion.setFlag(DefaultFlag.SNOW_FALL, StateFlag.State.DENY); | ||||
| 			regionManager.addRegion(_spawnRegion); | ||||
| 			 | ||||
| 			_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||
| 			 | ||||
| 			setupSpawn(); | ||||
| 		}else{ | ||||
| 			_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||
| 		} | ||||
| 		 | ||||
| 		_spawnCuboid = new Cuboid(_spawnRegion.getMinimumPoint(), _spawnRegion.getMaximumPoint()); | ||||
| 		 | ||||
| 		if(DEBUG){ | ||||
| 			log.info("Metropolis: first 9 plots"); | ||||
| 			 | ||||
| 			for (int ix=-1; ix<=1;ix++){ | ||||
| 				for (int iz=-1; iz<=1; iz++){ | ||||
| 					log.info(getCuboid(iz, ix).toString());				 | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		 | ||||
| 		 | ||||
| 		_occupiedPlots = new ArrayList<Plot>(); | ||||
| 		fillOccupiedPlots(); | ||||
| 		resizeCityRegion(); | ||||
| @@ -266,6 +271,12 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 		RegisterCommandHandler("metropolis-plot-reserve", new MetropolisPlotReserveCommand(this)); | ||||
| 	} | ||||
| 	 | ||||
| 	private Cuboid getCuboid(int row, int col) { | ||||
| 		BlockVector min = getPlotMin(row, col); | ||||
| 		BlockVector max = getPlotMax(row, col); | ||||
| 		return new Cuboid(min, max); | ||||
| 	} | ||||
|  | ||||
| 	private void RegisterCommandHandler(String commandName, CommandExecutor executor){ | ||||
| 		PluginCommand command = getCommand(commandName); | ||||
| 		if(command == null){ | ||||
| @@ -322,16 +333,16 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 	} | ||||
|  | ||||
| 	private void setupSpawn() { | ||||
| 		BlockVector min = getPlotMin(0, 0); | ||||
| 		BlockVector max = getPlotMax(0, 0); | ||||
| 		log.info("Metropolis: Spawn Cuboid is " + _spawnCuboid.toString()); | ||||
| 		 | ||||
| 		if(generateSpawn){ | ||||
| 			int x= 0; | ||||
| 			int y=roadLevel; | ||||
| 			int z=0; | ||||
| 			 | ||||
| 			for(x=min.getBlockX(); x<= max.getBlockX(); x++){ | ||||
| 				for(z=min.getBlockZ(); z<= max.getBlockZ(); z++){ | ||||
| 			//floor | ||||
| 			for(x=_spawnCuboid.getMinX(); x<= _spawnCuboid.getMaxX(); x++){ | ||||
| 				for(z=_spawnCuboid.getMinZ(); z<=_spawnCuboid.getMaxZ(); z++){ | ||||
| 					for(y=roadLevel+1; y<world.getMaxHeight(); y++){ | ||||
| 						Block block = world.getBlockAt(x, y, z); | ||||
| 						block.setType(Material.AIR); | ||||
| @@ -342,11 +353,13 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 					block.setType(spawnFloorMaterial); | ||||
| 				} | ||||
| 			} | ||||
| 			 | ||||
| 			//roads | ||||
| 			createRoads(_spawnCuboid); | ||||
| 		} | ||||
| 		 | ||||
| 		if(setWorldSpawn){ | ||||
| 			Cuboid spawnCuboid = new Cuboid(min, max); | ||||
| 			world.setSpawnLocation(spawnCuboid.getCenterX(), roadLevel+1, spawnCuboid.getCenterZ()); | ||||
| 			world.setSpawnLocation(_spawnCuboid.getCenterX(), roadLevel+1, _spawnCuboid.getCenterZ()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -396,8 +409,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 		int y=roadLevel; | ||||
| 		int z=0; | ||||
| 		 | ||||
| 		for(x = plotCuboid.minX + roadWidth/2; x <= plotCuboid.maxX - roadWidth/2; x++){ | ||||
| 			for(z=plotCuboid.minZ + roadWidth/2; z<=plotCuboid.maxZ - roadWidth/2; z++){ | ||||
| 		for(x = plotCuboid.minX; x <= plotCuboid.maxX; x++){ | ||||
| 			for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||
| 				Block block = world.getBlockAt(x, y, z); | ||||
| 				//Set the floor block | ||||
| 				block.setType(floorMaterial); | ||||
| @@ -442,7 +455,7 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			 | ||||
| 			//North Strip | ||||
| 			if((roadMask & ROAD_NORTH) != 0){ | ||||
| 				for(x=plotCuboid.minX; x<plotCuboid.maxX; x++){ | ||||
| 				for(x=plotCuboid.minX; x<=plotCuboid.maxX; x++){ | ||||
| 					for(z=plotCuboid.minZ - roadWidth; z<plotCuboid.minZ; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| @@ -451,8 +464,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			 | ||||
| 			//North East Corner | ||||
| 			if((roadMask & (ROAD_NORTH | ROAD_EAST)) != 0){ | ||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth;x++){ | ||||
| 					for(z=plotCuboid.minZ-roadWidth; z<plotCuboid.minZ; z++){ | ||||
| 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||
| 					for(z=plotCuboid.minZ - roadWidth; z<plotCuboid.minZ; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -460,8 +473,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			 | ||||
| 			//East Strip | ||||
| 			if((roadMask & ROAD_EAST) != 0){ | ||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth; x++){ | ||||
| 					for(z=plotCuboid.minZ; z<plotCuboid.maxZ; z++){ | ||||
| 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||
| 					for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -469,8 +482,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			 | ||||
| 			//South East Corner | ||||
| 			if((roadMask & (ROAD_SOUTH | ROAD_EAST)) != 0){ | ||||
| 				for(x=plotCuboid.maxX; x<plotCuboid.maxX + roadWidth; x++){ | ||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ + roadWidth; z++){ | ||||
| 				for(x=plotCuboid.maxX+1; x<=plotCuboid.maxX + roadWidth; x++){ | ||||
| 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -478,8 +491,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			 | ||||
| 			//South Strip | ||||
| 			if((roadMask & ROAD_SOUTH) != 0){ | ||||
| 				for(x=plotCuboid.minX; x<plotCuboid.maxX; x++){ | ||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ+roadWidth; z++){ | ||||
| 				for(x=plotCuboid.minX; x<=plotCuboid.maxX; x++){ | ||||
| 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -488,7 +501,7 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			//South West Corner | ||||
| 			if((roadMask & (ROAD_SOUTH | ROAD_WEST)) != 0){ | ||||
| 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | ||||
| 					for(z=plotCuboid.maxZ; z<plotCuboid.maxZ + roadWidth; z++){ | ||||
| 					for(z=plotCuboid.maxZ+1; z<=plotCuboid.maxZ + roadWidth; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -497,7 +510,7 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			//West Strip | ||||
| 			if((roadMask & ROAD_WEST) != 0){ | ||||
| 				for(x=plotCuboid.minX - roadWidth; x<plotCuboid.minX; x++){ | ||||
| 					for(z=plotCuboid.minZ; z<plotCuboid.maxZ; z++){ | ||||
| 					for(z=plotCuboid.minZ; z<=plotCuboid.maxZ; z++){ | ||||
| 						setRoad(x, y, z); | ||||
| 					} | ||||
| 				} | ||||
| @@ -513,6 +526,7 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 		Block block = world.getBlockAt(x, y, z); | ||||
| 		//Set the road block | ||||
| 		block.setType(roadMaterial); | ||||
| 		 | ||||
| 		//Set the support | ||||
| 		if(generateRoadSupports && isPhysicsMaterial(block.getType())){ | ||||
| 			Block blockUnder = world.getBlockAt(x, y-1, z); | ||||
| @@ -670,15 +684,11 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 	} | ||||
|  | ||||
| 	private int getPlotXFromMin(Cuboid cuboid) { | ||||
| 		int minX = cuboid.getMin().getBlockX() - roadWidth/2; | ||||
| 		 | ||||
| 		return minX/gridSizeX; | ||||
| 		return (cuboid.minX - roadWidth/2)/gridSizeX; | ||||
| 	} | ||||
|  | ||||
| 	private int getPlotZFromMin(Cuboid cuboid) { | ||||
| 		int minZ = cuboid.getMin().getBlockZ() - roadWidth/2; | ||||
| 		 | ||||
| 		return minZ/gridSizeZ; | ||||
| 		return (cuboid.minZ - roadWidth/2)/gridSizeZ; | ||||
| 	} | ||||
|  | ||||
| 	private void setHomeOccupied(String owner, BlockVector minimumPoint, BlockVector maximumPoint) { | ||||
| @@ -688,11 +698,9 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			_occupiedPlots.add(home); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
| 	public PlayerHome generateHome(String playerName) { | ||||
| 		if(DEBUG){log.info(String.format("Generating home for %s", playerName));} | ||||
| 		Cuboid plotCuboid = null; | ||||
| 		Cuboid homeCuboid = null; | ||||
| 		ProtectedRegion homeRegion = null; | ||||
| 		String regionName = "h_" + playerName; | ||||
| @@ -701,8 +709,8 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			return PlayerHome.get(homeRegion); | ||||
| 		} | ||||
| 		 | ||||
| 		plotCuboid = findNextUnownedHomeRegion(); | ||||
| 		homeCuboid = plotCuboid.inset(roadWidth/2, roadWidth/2); | ||||
| 		homeCuboid = findNextUnownedHomeRegion(); | ||||
| 		log.info("Metropolis Generating home in " + homeCuboid.toString()); | ||||
| 		homeRegion = new ProtectedCuboidRegion(regionName, homeCuboid.getMin(), homeCuboid.getMax()); | ||||
| 		homeRegion.setFlag(DefaultFlag.PVP, StateFlag.State.DENY); | ||||
| 		homeRegion.setFlag(DefaultFlag.MOB_DAMAGE, StateFlag.State.DENY); | ||||
| @@ -725,15 +733,15 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 	 | ||||
| 		setHomeOccupied(playerName, homeRegion.getMinimumPoint(), homeRegion.getMaximumPoint()); | ||||
| 		 | ||||
| 		createRoads(plotCuboid); | ||||
| 		createRoads(homeCuboid); | ||||
| 		 | ||||
| 		if(generateFloor){ | ||||
| 			generateFloor(plotCuboid); | ||||
| 			generateFloor(homeCuboid); | ||||
| 		} | ||||
| 		 | ||||
| 		if(DEBUG){log.info(String.format("generateSign: %s", String.valueOf(generateSign)));} | ||||
| 		if(generateSign){ | ||||
| 			generateSign(plotCuboid, playerName); | ||||
| 			generateSign(homeCuboid, playerName); | ||||
| 		} | ||||
| 		 | ||||
| 		if(DEBUG){log.info(String.format("Done generating home for %s", playerName));} | ||||
| @@ -753,7 +761,9 @@ public class MetropolisPlugin extends JavaPlugin { | ||||
| 			if(playerName.length() > 45){ | ||||
| 				sign.setLine(3, playerName.substring(31, Math.min(45, playerName.length()))); | ||||
| 			} | ||||
| 		}		 | ||||
| 		} | ||||
| 		 | ||||
| 		sign.update(true); | ||||
| 	} | ||||
|  | ||||
| 	public List<Plot> getCityBlocks() { | ||||
|   | ||||
| @@ -3,6 +3,7 @@ plot: | ||||
|   sizeZ: 24 | ||||
|   floor: | ||||
|     generate: true | ||||
|     clearSpaceAbove: 66 | ||||
|     material: 2 | ||||
|     supports: | ||||
|       generate: true | ||||
|   | ||||
		Reference in New Issue
	
	Block a user