TF-PlotSquared/PlotSquared/src/main/java/com/intellectualcrafters/plot/object/BlockWrapper.java

117 lines
4 KiB
Java
Raw Normal View History

2014-11-08 20:27:09 +01:00
////////////////////////////////////////////////////////////////////////////////////////////////////
// PlotSquared - A plot manager and world generator for the Bukkit API /
// Copyright (c) 2014 IntellectualSites/IntellectualCrafters /
// /
// This program is free software; you can redistribute it and/or modify /
// it under the terms of the GNU General Public License as published by /
// the Free Software Foundation; either version 3 of the License, or /
// (at your option) any later version. /
// /
// This program is distributed in the hope that it will be useful, /
// but WITHOUT ANY WARRANTY; without even the implied warranty of /
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the /
// GNU General Public License for more details. /
// /
// You should have received a copy of the GNU General Public License /
// along with this program; if not, write to the Free Software Foundation, /
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA /
// /
// You can contact us via: support@intellectualsites.com /
////////////////////////////////////////////////////////////////////////////////////////////////////
2014-11-16 10:48:18 +01:00
package com.intellectualcrafters.plot.object;
2014-10-23 18:09:54 +11:00
import org.bukkit.World;
import org.bukkit.block.Block;
2014-12-16 16:03:20 +11:00
import com.sun.istack.internal.NotNull;
2014-11-16 09:56:42 +01:00
/**
* Wrapper class for blocks, using
* pure data rather than the object.
* <p/>
* Useful for NMS
*
* @author Empire92
* @author Citymonstret
2014-11-16 09:56:42 +01:00
*/
2014-10-23 18:09:54 +11:00
public class BlockWrapper {
2014-11-05 14:42:08 +11:00
/**
* X Coordinate
*/
2014-12-16 16:03:20 +11:00
public final int x;
/**
* Y Coordinate
*/
2014-12-16 16:03:20 +11:00
public final int y;
/**
* Z Coordinate
*/
2014-12-16 16:03:20 +11:00
public final int z;
/**
* Block ID
*/
2014-12-16 16:03:20 +11:00
public final int id;
/**
* Block Data Value
*/
public final byte data;
2014-11-16 09:56:42 +01:00
/**
* Constructor
*
2014-12-16 16:03:20 +11:00
* @param x
* X Loc Value
* @param y
* Y Loc Value
* @param z
* Z Loc Value
* @param id
* Material ID
* @param data
* Data Value
2014-11-16 09:56:42 +01:00
*/
public BlockWrapper(final int x, final int y, final int z, final short id, final byte data) {
2014-10-23 18:09:54 +11:00
this.x = x;
this.y = y;
this.z = z;
this.id = id;
this.data = data;
}
/**
* Alternative Constructor
* Uses block data, rather than typed data
*
2014-12-16 16:03:20 +11:00
* @param block
* Block from which we get the data
*/
2014-12-16 16:03:20 +11:00
@SuppressWarnings({ "deprecation", "unused" })
public BlockWrapper(@NotNull final Block block) {
this.x = block.getX();
this.y = block.getY();
this.z = block.getZ();
this.id = block.getTypeId();
this.data = block.getData();
}
/**
* Get a block based on the block wrapper
*
2014-12-16 16:03:20 +11:00
* @param world
* World in which the block is/will be, located
* @return block created/fetched from settings
*/
2014-12-16 16:03:20 +11:00
@SuppressWarnings({ "unused", "deprecation" })
public Block toBlock(@NotNull final World world) {
2014-12-16 16:03:20 +11:00
final Block block = world.getBlockAt(this.x, this.y, this.z);
block.setTypeIdAndData(this.id, this.data, true);
return block;
}
2014-10-23 18:09:54 +11:00
}