--- miscJava/minecraft-plugins/setposplugin/src/Setpos.java 2010/10/16 13:54:50 1167 +++ miscJava/minecraft-plugins/hoeruputils/src/HoerupUtils.java 2010/10/19 17:16:40 1174 @@ -1,9 +1,9 @@ import java.util.logging.*; -public class Setpos extends Plugin { +public class HoerupUtils extends Plugin { - final static Logger log = Logger.getLogger("SetposPlugin"); + final static Logger log = Logger.getLogger("HoerupUtils"); @Override @@ -15,12 +15,12 @@ @Override public void initialize() { PluginLoader loader = etc.getLoader(); - loader.addListener( PluginLoader.Hook.COMMAND, new RealSetposPlugin(), this, PluginListener.Priority.MEDIUM ); + loader.addListener( PluginLoader.Hook.COMMAND, new HoerupUtilsPlugin(), this, PluginListener.Priority.MEDIUM ); } - public static class RealSetposPlugin extends PluginListener { + public static class HoerupUtilsPlugin extends PluginListener { final static String USAGE = "Usage: /setpos [height]"; final static int AIRBLOCK = 0; //block id = 0 is air @@ -64,18 +64,65 @@ @Override public boolean onCommand(Player player, java.lang.String[] split) { - if( split[0].equals("/setpos") ) { + if( split[0].equals("/setpos") && player.canUseCommand("/setpos") ) { setPos(player, split); return true; - } else if ( split[0].equals("/whereis" ) ) { + } else if ( split[0].equals("/whereis" ) && player.canUseCommand("/whereis")) { whereIs(player, split); return true; + } else if (split[0].equals("/levelarea") && player.canUseCommand("/levelarea")) { + levelArea(player, split); + return true; } else { return false; } } + private void levelArea(Player player, String[] split) { + if (split.length != 2) { + player.sendMessage("Usage: /levelarea "); + return; + } + + int radius; + try { + radius = Integer.parseInt(split[1]); + } catch (Exception e) { + player.sendMessage("levelarea: radius must be an integer"); + return; + } + + if (radius > 20) { + player.sendMessage("levelarea: radius may not exceed 20"); + return; + } + + + System.out.println("Player " + player.getName() + " used levelarea with radius=" + radius); + + + int playerX = (int) player.getX(); + int playerY = (int) player.getY(); + int playerZ = (int) player.getZ(); + + Server srv = etc.getServer(); + + int count = 0; + for (int x=(playerX-radius); x<=(playerX+radius); x++) { + for (int z=(playerZ-radius); z<=(playerZ+radius); z++) { + + //for (int y=playerY; y<=playerY+radius; y++) { + for (int y=playerY; y<=128; y++) { + count++; + srv.setBlockAt(0, x, y, z); + } + + } + + } + } + double roundToPlaces(double value, int places) {