Add definitions for Minecraft 1.9 gameplay elements

Includes an API for AreaEffectCloud and rework of Sound enum to include new sound values.

By: md_5 <git@md-5.net>
This commit is contained in:
Bukkit/Spigot 2016-03-01 08:30:03 +11:00
parent bbb7d2b8a8
commit de63cae2d7
19 changed files with 1062 additions and 242 deletions

View File

@ -261,6 +261,21 @@ public enum Material {
JUNGLE_DOOR(195, Door.class), JUNGLE_DOOR(195, Door.class),
ACACIA_DOOR(196, Door.class), ACACIA_DOOR(196, Door.class),
DARK_OAK_DOOR(197, Door.class), DARK_OAK_DOOR(197, Door.class),
END_ROD(198),
CHORUS_PLANT(199),
CHORUS_FLOWER(200),
PURPUR_BLOCK(201),
PURPUR_PILLAR(202),
PURPUR_STAIRS(203, Stairs.class),
PURPUR_DOUBLE_SLAB(204),
PURPUR_SLAB(205),
END_BRICKS(206),
BEETROOT_BLOCK(207, Crops.class),
GRASS_PATH(208),
END_GATEWAY(209),
COMMAND_REPEATING(210),
COMMAND_CHAIN(211),
STRUCTURE_BLOCK(255),
// ----- Item Separator ----- // ----- Item Separator -----
IRON_SPADE(256, 1, 250), IRON_SPADE(256, 1, 250),
IRON_PICKAXE(257, 1, 250), IRON_PICKAXE(257, 1, 250),
@ -438,11 +453,32 @@ public enum Material {
MUTTON(423), MUTTON(423),
COOKED_MUTTON(424), COOKED_MUTTON(424),
BANNER(425, 16), BANNER(425, 16),
END_CRYSTAL(426),
SPRUCE_DOOR_ITEM(427), SPRUCE_DOOR_ITEM(427),
BIRCH_DOOR_ITEM(428), BIRCH_DOOR_ITEM(428),
JUNGLE_DOOR_ITEM(429), JUNGLE_DOOR_ITEM(429),
ACACIA_DOOR_ITEM(430), ACACIA_DOOR_ITEM(430),
DARK_OAK_DOOR_ITEM(431), DARK_OAK_DOOR_ITEM(431),
CHORUS_FRUIT(432),
CHORUS_FRUIT_POPPED(433),
BEETROOT(434),
BEETROOT_SEEDS(435),
BEETROOT_SOUP(436, 1),
DRAGONS_BREATH(437),
SPLASH_POTION(438, 1),
SPECTRAL_ARROW(439),
TIPPED_ARROW(440),
/**
* @see Potion
*/
LINGERING_POTION(441, 1, MaterialData.class),
SHIELD(442, 1),
ELYTRA(443, 1),
BOAT_SPRUCE(444, 1),
BOAT_BIRCH(445, 1),
BOAT_JUNGLE(446, 1),
BOAT_ACACIA(447, 1),
BOAT_DARK_OAK(448, 1),
GOLD_RECORD(2256, 1), GOLD_RECORD(2256, 1),
GREEN_RECORD(2257, 1), GREEN_RECORD(2257, 1),
RECORD_3(2258, 1), RECORD_3(2258, 1),
@ -605,6 +641,9 @@ public enum Material {
case RABBIT_STEW: case RABBIT_STEW:
case MUTTON: case MUTTON:
case COOKED_MUTTON: case COOKED_MUTTON:
case BEETROOT:
case CHORUS_FRUIT:
case BEETROOT_SOUP:
return true; return true;
default: default:
return false; return false;
@ -850,6 +889,16 @@ public enum Material {
case JUNGLE_DOOR: case JUNGLE_DOOR:
case ACACIA_DOOR: case ACACIA_DOOR:
case DARK_OAK_DOOR: case DARK_OAK_DOOR:
case PURPUR_BLOCK:
case PURPUR_PILLAR:
case PURPUR_STAIRS:
case PURPUR_DOUBLE_SLAB:
case PURPUR_SLAB:
case END_BRICKS:
case GRASS_PATH:
case STRUCTURE_BLOCK:
case COMMAND_REPEATING:
case COMMAND_CHAIN:
return true; return true;
default: default:
return false; return false;
@ -910,6 +959,11 @@ public enum Material {
case ACTIVATOR_RAIL: case ACTIVATOR_RAIL:
case CARPET: case CARPET:
case DOUBLE_PLANT: case DOUBLE_PLANT:
case END_ROD:
case CHORUS_PLANT:
case CHORUS_FLOWER:
case BEETROOT_BLOCK:
case END_GATEWAY:
return true; return true;
default: default:
return false; return false;
@ -1032,6 +1086,8 @@ public enum Material {
case JUNGLE_FENCE: case JUNGLE_FENCE:
case DARK_OAK_FENCE: case DARK_OAK_FENCE:
case ACACIA_FENCE: case ACACIA_FENCE:
case ACACIA_STAIRS:
case DARK_OAK_STAIRS:
return true; return true;
default: default:
return false; return false;
@ -1096,7 +1152,6 @@ public enum Material {
case MELON_BLOCK: case MELON_BLOCK:
case MYCEL: case MYCEL:
case NETHER_BRICK: case NETHER_BRICK:
case ENDER_PORTAL_FRAME:
case ENDER_STONE: case ENDER_STONE:
case REDSTONE_LAMP_OFF: case REDSTONE_LAMP_OFF:
case REDSTONE_LAMP_ON: case REDSTONE_LAMP_ON:
@ -1118,6 +1173,13 @@ public enum Material {
case PRISMARINE: case PRISMARINE:
case RED_SANDSTONE: case RED_SANDSTONE:
case DOUBLE_STONE_SLAB2: case DOUBLE_STONE_SLAB2:
case PURPUR_BLOCK:
case PURPUR_PILLAR:
case PURPUR_DOUBLE_SLAB:
case END_BRICKS:
case STRUCTURE_BLOCK:
case COMMAND_REPEATING:
case COMMAND_CHAIN:
return true; return true;
default: default:
return false; return false;

View File

@ -13,6 +13,10 @@ import java.util.UUID;
import java.util.logging.Logger; import java.util.logging.Logger;
import org.bukkit.Warning.WarningState; import org.bukkit.Warning.WarningState;
import org.bukkit.boss.BarColor;
import org.bukkit.boss.BarFlag;
import org.bukkit.boss.BarStyle;
import org.bukkit.boss.BossBar;
import org.bukkit.command.CommandException; import org.bukkit.command.CommandException;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.command.ConsoleCommandSender; import org.bukkit.command.ConsoleCommandSender;
@ -926,6 +930,18 @@ public interface Server extends PluginMessageRecipient {
*/ */
public ChunkGenerator.ChunkData createChunkData(World world); public ChunkGenerator.ChunkData createChunkData(World world);
/**
* Creates a boss bar instance to display to players. The progress
* defaults to 1.0
*
* @param title the title of the boss bar
* @param color the color of the boss bar
* @param style the style of the boss bar
* @param flags an optional list of flags to set on the boss bar
* @return the created boss bar
*/
BossBar createBossBar(String title, BarColor color, BarStyle style, BarFlag ...flags);
/** /**
* @see UnsafeValues * @see UnsafeValues
* @return the unsafe values instance * @return the unsafe values instance

View File

@ -9,203 +9,447 @@ package org.bukkit;
* not depend on the ordinal values of this class. * not depend on the ordinal values of this class.
*/ */
public enum Sound { public enum Sound {
AMBIENCE_CAVE, AMBIENT_CAVE,
AMBIENCE_RAIN, BLOCK_ANVIL_BREAK,
AMBIENCE_THUNDER, BLOCK_ANVIL_DESTROY,
ANVIL_BREAK, BLOCK_ANVIL_FALL,
ANVIL_LAND, BLOCK_ANVIL_HIT,
ANVIL_USE, BLOCK_ANVIL_LAND,
ARROW_HIT, BLOCK_ANVIL_PLACE,
BURP, BLOCK_ANVIL_STEP,
CHEST_CLOSE, BLOCK_ANVIL_USE,
CHEST_OPEN, BLOCK_BREWING_STAND_BREW,
CLICK, BLOCK_CHEST_CLOSE,
DOOR_CLOSE, BLOCK_CHEST_LOCKED,
DOOR_OPEN, BLOCK_CHEST_OPEN,
DRINK, BLOCK_CHORUS_FLOWER_DEATH,
EAT, BLOCK_CHORUS_FLOWER_GROW,
EXPLODE, BLOCK_CLOTH_BREAK,
FALL_BIG, BLOCK_CLOTH_FALL,
FALL_SMALL, BLOCK_CLOTH_HIT,
FIRE, BLOCK_CLOTH_PLACE,
FIRE_IGNITE, BLOCK_CLOTH_STEP,
FIZZ, BLOCK_COMPARATOR_CLICK,
FUSE, BLOCK_DISPENSER_DISPENSE,
GLASS, BLOCK_DISPENSER_FAIL,
HURT_FLESH, BLOCK_DISPENSER_LAUNCH,
ITEM_BREAK, BLOCK_ENDERCHEST_CLOSE,
ITEM_PICKUP, BLOCK_ENDERCHEST_OPEN,
LAVA, BLOCK_END_GATEWAY_SPAWN,
LAVA_POP, BLOCK_FENCE_GATE_CLOSE,
LEVEL_UP, BLOCK_FENCE_GATE_OPEN,
MINECART_BASE, BLOCK_FIRE_AMBIENT,
MINECART_INSIDE, BLOCK_FIRE_EXTINGUISH,
NOTE_BASS, BLOCK_FURNACE_FIRE_CRACKLE,
NOTE_PIANO, BLOCK_GLASS_BREAK,
NOTE_BASS_DRUM, BLOCK_GLASS_FALL,
NOTE_STICKS, BLOCK_GLASS_HIT,
NOTE_BASS_GUITAR, BLOCK_GLASS_PLACE,
NOTE_SNARE_DRUM, BLOCK_GLASS_STEP,
NOTE_PLING, BLOCK_GRASS_BREAK,
ORB_PICKUP, BLOCK_GRASS_FALL,
PISTON_EXTEND, BLOCK_GRASS_HIT,
PISTON_RETRACT, BLOCK_GRASS_PLACE,
PORTAL, BLOCK_GRASS_STEP,
PORTAL_TRAVEL, BLOCK_GRAVEL_BREAK,
PORTAL_TRIGGER, BLOCK_GRAVEL_FALL,
SHOOT_ARROW, BLOCK_GRAVEL_HIT,
SPLASH, BLOCK_GRAVEL_PLACE,
SPLASH2, BLOCK_GRAVEL_STEP,
STEP_GRASS, BLOCK_IRON_DOOR_CLOSE,
STEP_GRAVEL, BLOCK_IRON_DOOR_OPEN,
STEP_LADDER, BLOCK_IRON_TRAPDOOR_CLOSE,
STEP_SAND, BLOCK_IRON_TRAPDOOR_OPEN,
STEP_SNOW, BLOCK_LADDER_BREAK,
STEP_STONE, BLOCK_LADDER_FALL,
STEP_WOOD, BLOCK_LADDER_HIT,
STEP_WOOL, BLOCK_LADDER_PLACE,
SWIM, BLOCK_LADDER_STEP,
WATER, BLOCK_LAVA_AMBIENT,
WOOD_CLICK, BLOCK_LAVA_EXTINGUISH,
// Mob sounds BLOCK_LAVA_POP,
BAT_DEATH, BLOCK_LEVER_CLICK,
BAT_HURT, BLOCK_METAL_BREAK,
BAT_IDLE, BLOCK_METAL_FALL,
BAT_LOOP, BLOCK_METAL_HIT,
BAT_TAKEOFF, BLOCK_METAL_PLACE,
BLAZE_BREATH, BLOCK_METAL_PRESSUREPLATE_CLICK_OFF,
BLAZE_DEATH, BLOCK_METAL_PRESSUREPLATE_CLICK_ON,
BLAZE_HIT, BLOCK_METAL_STEP,
CAT_HISS, BLOCK_NOTE_BASEDRUM,
CAT_HIT, BLOCK_NOTE_BASS,
CAT_MEOW, BLOCK_NOTE_HARP,
CAT_PURR, BLOCK_NOTE_HAT,
CAT_PURREOW, BLOCK_NOTE_PLING,
CHICKEN_IDLE, BLOCK_NOTE_SNARE,
CHICKEN_HURT, BLOCK_PISTON_CONTRACT,
CHICKEN_EGG_POP, BLOCK_PISTON_EXTEND,
CHICKEN_WALK, BLOCK_PORTAL_AMBIENT,
COW_IDLE, BLOCK_PORTAL_TRAVEL,
COW_HURT, BLOCK_PORTAL_TRIGGER,
COW_WALK, BLOCK_REDSTONE_TORCH_BURNOUT,
CREEPER_HISS, BLOCK_SAND_BREAK,
CREEPER_DEATH, BLOCK_SAND_FALL,
ENDERDRAGON_DEATH, BLOCK_SAND_HIT,
ENDERDRAGON_GROWL, BLOCK_SAND_PLACE,
ENDERDRAGON_HIT, BLOCK_SAND_STEP,
ENDERDRAGON_WINGS, BLOCK_SLIME_BREAK,
ENDERMAN_DEATH, BLOCK_SLIME_FALL,
ENDERMAN_HIT, BLOCK_SLIME_HIT,
ENDERMAN_IDLE, BLOCK_SLIME_PLACE,
ENDERMAN_TELEPORT, BLOCK_SLIME_STEP,
ENDERMAN_SCREAM, BLOCK_SNOW_BREAK,
ENDERMAN_STARE, BLOCK_SNOW_FALL,
GHAST_SCREAM, BLOCK_SNOW_HIT,
GHAST_SCREAM2, BLOCK_SNOW_PLACE,
GHAST_CHARGE, BLOCK_SNOW_STEP,
GHAST_DEATH, BLOCK_STONE_BREAK,
GHAST_FIREBALL, BLOCK_STONE_BUTTON_CLICK_OFF,
GHAST_MOAN, BLOCK_STONE_BUTTON_CLICK_ON,
IRONGOLEM_DEATH, BLOCK_STONE_FALL,
IRONGOLEM_HIT, BLOCK_STONE_HIT,
IRONGOLEM_THROW, BLOCK_STONE_PLACE,
IRONGOLEM_WALK, BLOCK_STONE_PRESSUREPLATE_CLICK_OFF,
MAGMACUBE_WALK, BLOCK_STONE_PRESSUREPLATE_CLICK_ON,
MAGMACUBE_WALK2, BLOCK_STONE_STEP,
MAGMACUBE_JUMP, BLOCK_TRIPWIRE_ATTACH,
PIG_IDLE, BLOCK_TRIPWIRE_CLICK_OFF,
PIG_DEATH, BLOCK_TRIPWIRE_CLICK_ON,
PIG_WALK, BLOCK_TRIPWIRE_DETACH,
SHEEP_IDLE, BLOCK_WATERLILY_PLACE,
SHEEP_SHEAR, BLOCK_WATER_AMBIENT,
SHEEP_WALK, BLOCK_WOODEN_DOOR_CLOSE,
SILVERFISH_HIT, BLOCK_WOODEN_DOOR_OPEN,
SILVERFISH_KILL, BLOCK_WOODEN_TRAPDOOR_CLOSE,
SILVERFISH_IDLE, BLOCK_WOODEN_TRAPDOOR_OPEN,
SILVERFISH_WALK, BLOCK_WOOD_BREAK,
SKELETON_IDLE, BLOCK_WOOD_BUTTON_CLICK_OFF,
SKELETON_DEATH, BLOCK_WOOD_BUTTON_CLICK_ON,
SKELETON_HURT, BLOCK_WOOD_FALL,
SKELETON_WALK, BLOCK_WOOD_HIT,
SLIME_ATTACK, BLOCK_WOOD_PLACE,
SLIME_WALK, BLOCK_WOOD_PRESSUREPLATE_CLICK_OFF,
SLIME_WALK2, BLOCK_WOOD_PRESSUREPLATE_CLICK_ON,
SPIDER_IDLE, BLOCK_WOOD_STEP,
SPIDER_DEATH, ENCHANT_THORNS_HIT,
SPIDER_WALK, ENTITY_ARMORSTAND_BREAK,
WITHER_DEATH, ENTITY_ARMORSTAND_FALL,
WITHER_HURT, ENTITY_ARMORSTAND_HIT,
WITHER_IDLE, ENTITY_ARMORSTAND_PLACE,
WITHER_SHOOT, ENTITY_ARROW_HIT,
WITHER_SPAWN, ENTITY_ARROW_HIT_PLAYER,
WOLF_BARK, ENTITY_ARROW_SHOOT,
WOLF_DEATH, ENTITY_BAT_AMBIENT,
WOLF_GROWL, ENTITY_BAT_DEATH,
WOLF_HOWL, ENTITY_BAT_HURT,
WOLF_HURT, ENTITY_BAT_LOOP,
WOLF_PANT, ENTITY_BAT_TAKEOFF,
WOLF_SHAKE, ENTITY_BLAZE_AMBIENT,
WOLF_WALK, ENTITY_BLAZE_BURN,
WOLF_WHINE, ENTITY_BLAZE_DEATH,
ZOMBIE_METAL, ENTITY_BLAZE_HURT,
ZOMBIE_WOOD, ENTITY_BLAZE_SHOOT,
ZOMBIE_WOODBREAK, ENTITY_BOBBER_SPLASH,
ZOMBIE_IDLE, ENTITY_BOBBER_THROW,
ZOMBIE_DEATH, ENTITY_CAT_AMBIENT,
ZOMBIE_HURT, ENTITY_CAT_DEATH,
ZOMBIE_INFECT, ENTITY_CAT_HISS,
ZOMBIE_UNFECT, ENTITY_CAT_HURT,
ZOMBIE_REMEDY, ENTITY_CAT_PURR,
ZOMBIE_WALK, ENTITY_CAT_PURREOW,
ZOMBIE_PIG_IDLE, ENTITY_CHICKEN_AMBIENT,
ZOMBIE_PIG_ANGRY, ENTITY_CHICKEN_DEATH,
ZOMBIE_PIG_DEATH, ENTITY_CHICKEN_EGG,
ZOMBIE_PIG_HURT, ENTITY_CHICKEN_HURT,
// Dig Sounds ENTITY_CHICKEN_STEP,
DIG_WOOL, ENTITY_COW_AMBIENT,
DIG_GRASS, ENTITY_COW_DEATH,
DIG_GRAVEL, ENTITY_COW_HURT,
DIG_SAND, ENTITY_COW_MILK,
DIG_SNOW, ENTITY_COW_STEP,
DIG_STONE, ENTITY_CREEPER_DEATH,
DIG_WOOD, ENTITY_CREEPER_HURT,
// Fireworks ENTITY_CREEPER_PRIMED,
FIREWORK_BLAST, ENTITY_DONKEY_AMBIENT,
FIREWORK_BLAST2, ENTITY_DONKEY_ANGRY,
FIREWORK_LARGE_BLAST, ENTITY_DONKEY_CHEST,
FIREWORK_LARGE_BLAST2, ENTITY_DONKEY_DEATH,
FIREWORK_TWINKLE, ENTITY_DONKEY_HURT,
FIREWORK_TWINKLE2, ENTITY_EGG_THROW,
FIREWORK_LAUNCH, ENTITY_ELDER_GUARDIAN_AMBIENT,
SUCCESSFUL_HIT, ENTITY_ELDER_GUARDIAN_AMBIENT_LAND,
// Horses ENTITY_ELDER_GUARDIAN_CURSE,
HORSE_ANGRY, ENTITY_ELDER_GUARDIAN_DEATH,
HORSE_ARMOR, ENTITY_ELDER_GUARDIAN_DEATH_LAND,
HORSE_BREATHE, ENTITY_ELDER_GUARDIAN_HURT,
HORSE_DEATH, ENTITY_ELDER_GUARDIAN_HURT_LAND,
HORSE_GALLOP, ENTITY_ENDERDRAGON_AMBIENT,
HORSE_HIT, ENTITY_ENDERDRAGON_DEATH,
HORSE_IDLE, ENTITY_ENDERDRAGON_FIREBALL_EXPLODE,
HORSE_JUMP, ENTITY_ENDERDRAGON_FLAP,
HORSE_LAND, ENTITY_ENDERDRAGON_GROWL,
HORSE_SADDLE, ENTITY_ENDERDRAGON_HURT,
HORSE_SOFT, ENTITY_ENDERDRAGON_SHOOT,
HORSE_WOOD, ENTITY_ENDEREYE_LAUNCH,
DONKEY_ANGRY, ENTITY_ENDERMEN_AMBIENT,
DONKEY_DEATH, ENTITY_ENDERMEN_DEATH,
DONKEY_HIT, ENTITY_ENDERMEN_HURT,
DONKEY_IDLE, ENTITY_ENDERMEN_SCREAM,
HORSE_SKELETON_DEATH, ENTITY_ENDERMEN_STARE,
HORSE_SKELETON_HIT, ENTITY_ENDERMEN_TELEPORT,
HORSE_SKELETON_IDLE, ENTITY_ENDERMITE_AMBIENT,
HORSE_ZOMBIE_DEATH, ENTITY_ENDERMITE_DEATH,
HORSE_ZOMBIE_HIT, ENTITY_ENDERMITE_HURT,
HORSE_ZOMBIE_IDLE, ENTITY_ENDERMITE_STEP,
// Villager ENTITY_ENDERPEARL_THROW,
VILLAGER_DEATH, ENTITY_EXPERIENCE_BOTTLE_THROW,
VILLAGER_HAGGLE, ENTITY_EXPERIENCE_ORB_PICKUP,
VILLAGER_HIT, ENTITY_EXPERIENCE_ORB_TOUCH,
VILLAGER_IDLE, ENTITY_FIREWORK_BLAST,
VILLAGER_NO, ENTITY_FIREWORK_BLAST_FAR,
VILLAGER_YES, ENTITY_FIREWORK_LARGE_BLAST,
ENTITY_FIREWORK_LARGE_BLAST_FAR,
ENTITY_FIREWORK_LAUNCH,
ENTITY_FIREWORK_SHOOT,
ENTITY_FIREWORK_TWINKLE,
ENTITY_FIREWORK_TWINKLE_FAR,
ENTITY_GENERIC_BIG_FALL,
ENTITY_GENERIC_BURN,
ENTITY_GENERIC_DEATH,
ENTITY_GENERIC_DRINK,
ENTITY_GENERIC_EAT,
ENTITY_GENERIC_EXPLODE,
ENTITY_GENERIC_EXTINGUISH_FIRE,
ENTITY_GENERIC_HURT,
ENTITY_GENERIC_SMALL_FALL,
ENTITY_GENERIC_SPLASH,
ENTITY_GENERIC_SWIM,
ENTITY_GHAST_AMBIENT,
ENTITY_GHAST_DEATH,
ENTITY_GHAST_HURT,
ENTITY_GHAST_SCREAM,
ENTITY_GHAST_SHOOT,
ENTITY_GHAST_WARN,
ENTITY_GUARDIAN_AMBIENT,
ENTITY_GUARDIAN_AMBIENT_LAND,
ENTITY_GUARDIAN_ATTACK,
ENTITY_GUARDIAN_DEATH,
ENTITY_GUARDIAN_DEATH_LAND,
ENTITY_GUARDIAN_FLOP,
ENTITY_GUARDIAN_HURT,
ENTITY_GUARDIAN_HURT_LAND,
ENTITY_HORSE_AMBIENT,
ENTITY_HORSE_ANGRY,
ENTITY_HORSE_ARMOR,
ENTITY_HORSE_BREATHE,
ENTITY_HORSE_DEATH,
ENTITY_HORSE_EAT,
ENTITY_HORSE_GALLOP,
ENTITY_HORSE_HURT,
ENTITY_HORSE_JUMP,
ENTITY_HORSE_LAND,
ENTITY_HORSE_SADDLE,
ENTITY_HORSE_STEP,
ENTITY_HORSE_STEP_WOOD,
ENTITY_HOSTILE_BIG_FALL,
ENTITY_HOSTILE_DEATH,
ENTITY_HOSTILE_HURT,
ENTITY_HOSTILE_SMALL_FALL,
ENTITY_HOSTILE_SPLASH,
ENTITY_HOSTILE_SWIM,
ENTITY_IRONGOLEM_ATTACK,
ENTITY_IRONGOLEM_DEATH,
ENTITY_IRONGOLEM_HURT,
ENTITY_IRONGOLEM_STEP,
ENTITY_ITEMFRAME_ADD_ITEM,
ENTITY_ITEMFRAME_BREAK,
ENTITY_ITEMFRAME_PLACE,
ENTITY_ITEMFRAME_REMOVE_ITEM,
ENTITY_ITEMFRAME_ROTATE_ITEM,
ENTITY_ITEM_BREAK,
ENTITY_ITEM_PICKUP,
ENTITY_LEASHKNOT_BREAK,
ENTITY_LEASHKNOT_PLACE,
ENTITY_LIGHTNING_IMPACT,
ENTITY_LIGHTNING_THUNDER,
ENTITY_LINGERINGPOTION_THROW,
ENTITY_MAGMACUBE_DEATH,
ENTITY_MAGMACUBE_HURT,
ENTITY_MAGMACUBE_JUMP,
ENTITY_MAGMACUBE_SQUISH,
ENTITY_MINECART_INSIDE,
ENTITY_MINECART_RIDING,
ENTITY_MOOSHROOM_SHEAR,
ENTITY_MULE_AMBIENT,
ENTITY_MULE_DEATH,
ENTITY_MULE_HURT,
ENTITY_PAINTING_BREAK,
ENTITY_PAINTING_PLACE,
ENTITY_PIG_AMBIENT,
ENTITY_PIG_DEATH,
ENTITY_PIG_HURT,
ENTITY_PIG_SADDLE,
ENTITY_PIG_STEP,
ENTITY_PLAYER_ATTACK_CRIT,
ENTITY_PLAYER_ATTACK_KNOCKBACK,
ENTITY_PLAYER_ATTACK_NODAMAGE,
ENTITY_PLAYER_ATTACK_STRONG,
ENTITY_PLAYER_ATTACK_SWEEP,
ENTITY_PLAYER_ATTACK_WEAK,
ENTITY_PLAYER_BIG_FALL,
ENTITY_PLAYER_BREATH,
ENTITY_PLAYER_BURP,
ENTITY_PLAYER_DEATH,
ENTITY_PLAYER_HURT,
ENTITY_PLAYER_LEVELUP,
ENTITY_PLAYER_SMALL_FALL,
ENTITY_PLAYER_SPLASH,
ENTITY_PLAYER_SWIM,
ENTITY_RABBIT_AMBIENT,
ENTITY_RABBIT_ATTACK,
ENTITY_RABBIT_DEATH,
ENTITY_RABBIT_HURT,
ENTITY_RABBIT_JUMP,
ENTITY_SHEEP_AMBIENT,
ENTITY_SHEEP_DEATH,
ENTITY_SHEEP_HURT,
ENTITY_SHEEP_SHEAR,
ENTITY_SHEEP_STEP,
ENTITY_SHULKER_AMBIENT,
ENTITY_SHULKER_BULLET_HIT,
ENTITY_SHULKER_BULLET_HURT,
ENTITY_SHULKER_CLOSE,
ENTITY_SHULKER_DEATH,
ENTITY_SHULKER_HURT,
ENTITY_SHULKER_HURT_CLOSED,
ENTITY_SHULKER_OPEN,
ENTITY_SHULKER_SHOOT,
ENTITY_SHULKER_TELEPORT,
ENTITY_SILVERFISH_AMBIENT,
ENTITY_SILVERFISH_DEATH,
ENTITY_SILVERFISH_HURT,
ENTITY_SILVERFISH_STEP,
ENTITY_SKELETON_AMBIENT,
ENTITY_SKELETON_DEATH,
ENTITY_SKELETON_HORSE_AMBIENT,
ENTITY_SKELETON_HORSE_DEATH,
ENTITY_SKELETON_HORSE_HURT,
ENTITY_SKELETON_HURT,
ENTITY_SKELETON_SHOOT,
ENTITY_SKELETON_STEP,
ENTITY_SLIME_ATTACK,
ENTITY_SLIME_DEATH,
ENTITY_SLIME_HURT,
ENTITY_SLIME_JUMP,
ENTITY_SLIME_SQUISH,
ENTITY_SMALL_MAGMACUBE_DEATH,
ENTITY_SMALL_MAGMACUBE_HURT,
ENTITY_SMALL_MAGMACUBE_SQUISH,
ENTITY_SMALL_SLIME_DEATH,
ENTITY_SMALL_SLIME_HURT,
ENTITY_SMALL_SLIME_JUMP,
ENTITY_SMALL_SLIME_SQUISH,
ENTITY_SNOWBALL_THROW,
ENTITY_SNOWMAN_AMBIENT,
ENTITY_SNOWMAN_DEATH,
ENTITY_SNOWMAN_HURT,
ENTITY_SNOWMAN_SHOOT,
ENTITY_SPIDER_AMBIENT,
ENTITY_SPIDER_DEATH,
ENTITY_SPIDER_HURT,
ENTITY_SPIDER_STEP,
ENTITY_SPLASH_POTION_BREAK,
ENTITY_SPLASH_POTION_THROW,
ENTITY_SQUID_AMBIENT,
ENTITY_SQUID_DEATH,
ENTITY_SQUID_HURT,
ENTITY_TNT_PRIMED,
ENTITY_VILLAGER_AMBIENT,
ENTITY_VILLAGER_DEATH,
ENTITY_VILLAGER_HURT,
ENTITY_VILLAGER_NO,
ENTITY_VILLAGER_TRADING,
ENTITY_VILLAGER_YES,
ENTITY_WITCH_AMBIENT,
ENTITY_WITCH_DEATH,
ENTITY_WITCH_DRINK,
ENTITY_WITCH_HURT,
ENTITY_WITCH_THROW,
ENTITY_WITHER_AMBIENT,
ENTITY_WITHER_BREAK_BLOCK,
ENTITY_WITHER_DEATH,
ENTITY_WITHER_HURT,
ENTITY_WITHER_SHOOT,
ENTITY_WITHER_SPAWN,
ENTITY_WOLF_AMBIENT,
ENTITY_WOLF_DEATH,
ENTITY_WOLF_GROWL,
ENTITY_WOLF_HOWL,
ENTITY_WOLF_HURT,
ENTITY_WOLF_PANT,
ENTITY_WOLF_SHAKE,
ENTITY_WOLF_STEP,
ENTITY_WOLF_WHINE,
ENTITY_ZOMBIE_AMBIENT,
ENTITY_ZOMBIE_ATTACK_DOOR_WOOD,
ENTITY_ZOMBIE_ATTACK_IRON_DOOR,
ENTITY_ZOMBIE_BREAK_DOOR_WOOD,
ENTITY_ZOMBIE_DEATH,
ENTITY_ZOMBIE_HORSE_AMBIENT,
ENTITY_ZOMBIE_HORSE_DEATH,
ENTITY_ZOMBIE_HORSE_HURT,
ENTITY_ZOMBIE_HURT,
ENTITY_ZOMBIE_INFECT,
ENTITY_ZOMBIE_PIG_AMBIENT,
ENTITY_ZOMBIE_PIG_ANGRY,
ENTITY_ZOMBIE_PIG_DEATH,
ENTITY_ZOMBIE_PIG_HURT,
ENTITY_ZOMBIE_STEP,
ENTITY_ZOMBIE_VILLAGER_AMBIENT,
ENTITY_ZOMBIE_VILLAGER_CONVERTED,
ENTITY_ZOMBIE_VILLAGER_CURE,
ENTITY_ZOMBIE_VILLAGER_DEATH,
ENTITY_ZOMBIE_VILLAGER_HURT,
ENTITY_ZOMBIE_VILLAGER_STEP,
ITEM_ARMOR_EQUIP_CHAIN,
ITEM_ARMOR_EQUIP_DIAMOND,
ITEM_ARMOR_EQUIP_GENERIC,
ITEM_ARMOR_EQUIP_GOLD,
ITEM_ARMOR_EQUIP_IRON,
ITEM_ARMOR_EQUIP_LEATHER,
ITEM_BOTTLE_FILL,
ITEM_BOTTLE_FILL_DRAGONBREATH,
ITEM_BUCKET_EMPTY,
ITEM_BUCKET_EMPTY_LAVA,
ITEM_BUCKET_FILL,
ITEM_BUCKET_FILL_LAVA,
ITEM_CHORUS_FRUIT_TELEPORT,
ITEM_FIRECHARGE_USE,
ITEM_FLINTANDSTEEL_USE,
ITEM_HOE_TILL,
ITEM_SHIELD_BLOCK,
ITEM_SHIELD_BREAK,
ITEM_SHOVEL_FLATTEN,
MUSIC_CREATIVE,
MUSIC_CREDITS,
MUSIC_DRAGON,
MUSIC_END,
MUSIC_GAME,
MUSIC_MENU,
MUSIC_NETHER,
RECORD_11,
RECORD_13,
RECORD_BLOCKS,
RECORD_CAT,
RECORD_CHIRP,
RECORD_FAR,
RECORD_MALL,
RECORD_MELLOHI,
RECORD_STAL,
RECORD_STRAD,
RECORD_WAIT,
RECORD_WARD,
UI_BUTTON_CLICK,
WEATHER_RAIN,
WEATHER_RAIN_ABOVE,
} }

View File

@ -15,11 +15,13 @@ public enum Statistic {
JUNK_FISHED, JUNK_FISHED,
LEAVE_GAME, LEAVE_GAME,
JUMP, JUMP,
DROP, DROP(Type.ITEM),
PICKUP(Type.ITEM),
PLAY_ONE_TICK, PLAY_ONE_TICK,
WALK_ONE_CM, WALK_ONE_CM,
SWIM_ONE_CM, SWIM_ONE_CM,
FALL_ONE_CM, FALL_ONE_CM,
SNEAK_TIME,
CLIMB_ONE_CM, CLIMB_ONE_CM,
FLY_ONE_CM, FLY_ONE_CM,
DIVE_ONE_CM, DIVE_ONE_CM,
@ -29,6 +31,7 @@ public enum Statistic {
HORSE_ONE_CM, HORSE_ONE_CM,
SPRINT_ONE_CM, SPRINT_ONE_CM,
CROUCH_ONE_CM, CROUCH_ONE_CM,
AVIATE_ONE_CM,
MINE_BLOCK(Type.BLOCK), MINE_BLOCK(Type.BLOCK),
USE_ITEM(Type.ITEM), USE_ITEM(Type.ITEM),
BREAK_ITEM(Type.ITEM), BREAK_ITEM(Type.ITEM),
@ -57,7 +60,8 @@ public enum Statistic {
RECORD_PLAYED, RECORD_PLAYED,
FURNACE_INTERACTION, FURNACE_INTERACTION,
CRAFTING_TABLE_INTERACTION, CRAFTING_TABLE_INTERACTION,
CHEST_OPENED; CHEST_OPENED,
SLEEP_IN_BED;
private final Type type; private final Type type;

View File

@ -1166,6 +1166,200 @@ public interface World extends PluginMessageRecipient, Metadatable {
*/ */
public WorldBorder getWorldBorder(); public WorldBorder getWorldBorder();
/**
* Spawns the particle (the number of times specified by count)
* at the target location.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
*/
public void spawnParticle(Particle particle, Location location, int count);
/**
* Spawns the particle (the number of times specified by count)
* at the target location.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
*/
public void spawnParticle(Particle particle, double x, double y, double z, int count);
/**
* Spawns the particle (the number of times specified by count)
* at the target location.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, Location location, int count, T data);
/**
* Spawns the particle (the number of times specified by count)
* at the target location.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, double x, double y, double z, int count, T data);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
*/
public void spawnParticle(Particle particle, Location location, int count, double offsetX, double offsetY, double offsetZ);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
*/
public void spawnParticle(Particle particle, double x, double y, double z, int count, double offsetX, double offsetY, double offsetZ);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, Location location, int count, double offsetX, double offsetY, double offsetZ, T data);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, double x, double y, double z, int count, double offsetX, double offsetY, double offsetZ, T data);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param extra the extra data for this particle, depends on the
* particle used (normally speed)
*/
public void spawnParticle(Particle particle, Location location, int count, double offsetX, double offsetY, double offsetZ, double extra);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param extra the extra data for this particle, depends on the
* particle used (normally speed)
*/
public void spawnParticle(Particle particle, double x, double y, double z, int count, double offsetX, double offsetY, double offsetZ, double extra);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param location the location to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param extra the extra data for this particle, depends on the
* particle used (normally speed)
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, Location location, int count, double offsetX, double offsetY, double offsetZ, double extra, T data);
/**
* Spawns the particle (the number of times specified by count)
* at the target location. The position of each particle will be
* randomized positively and negatively by the offset parameters
* on each axis.
*
* @param particle the particle to spawn
* @param x the position on the x axis to spawn at
* @param y the position on the y axis to spawn at
* @param z the position on the z axis to spawn at
* @param count the number of particles
* @param offsetX the maximum random offset on the X axis
* @param offsetY the maximum random offset on the Y axis
* @param offsetZ the maximum random offset on the Z axis
* @param extra the extra data for this particle, depends on the
* particle used (normally speed)
* @param data the data to use for the particle or null,
* the type of this depends on {@link Particle#getDataType()}
*/
public <T> void spawnParticle(Particle particle, double x, double y, double z, int count, double offsetX, double offsetY, double offsetZ, double extra, T data);
/** /**
* Represents various map environment types that a world may be * Represents various map environment types that a world may be
*/ */

View File

@ -4,27 +4,27 @@ package org.bukkit.block;
* Holds all accepted Biomes in the default server * Holds all accepted Biomes in the default server
*/ */
public enum Biome { public enum Biome {
SWAMPLAND, OCEAN,
PLAINS,
DESERT,
EXTREME_HILLS,
FOREST, FOREST,
TAIGA, TAIGA,
DESERT, SWAMPLAND,
PLAINS, RIVER,
HELL, HELL,
SKY, SKY,
OCEAN,
RIVER,
EXTREME_HILLS,
FROZEN_OCEAN, FROZEN_OCEAN,
FROZEN_RIVER, FROZEN_RIVER,
ICE_PLAINS, ICE_FLATS,
ICE_MOUNTAINS, ICE_MOUNTAINS,
MUSHROOM_ISLAND, MUSHROOM_ISLAND,
MUSHROOM_SHORE, MUSHROOM_ISLAND_SHORE,
BEACH, BEACHES,
DESERT_HILLS, DESERT_HILLS,
FOREST_HILLS, FOREST_HILLS,
TAIGA_HILLS, TAIGA_HILLS,
SMALL_MOUNTAINS, SMALLER_EXTREME_HILLS,
JUNGLE, JUNGLE,
JUNGLE_HILLS, JUNGLE_HILLS,
JUNGLE_EDGE, JUNGLE_EDGE,
@ -34,35 +34,36 @@ public enum Biome {
BIRCH_FOREST, BIRCH_FOREST,
BIRCH_FOREST_HILLS, BIRCH_FOREST_HILLS,
ROOFED_FOREST, ROOFED_FOREST,
COLD_TAIGA, TAIGA_COLD,
COLD_TAIGA_HILLS, TAIGA_COLD_HILLS,
MEGA_TAIGA, REDWOOD_TAIGA,
MEGA_TAIGA_HILLS, REDWOOD_TAIGA_HILLS,
EXTREME_HILLS_PLUS, EXTREME_HILLS_WITH_TREES,
SAVANNA, SAVANNA,
SAVANNA_PLATEAU, SAVANNA_ROCK,
MESA, MESA,
MESA_PLATEAU_FOREST, MESA_ROCK,
MESA_PLATEAU, MESA_CLEAR_ROCK,
SUNFLOWER_PLAINS, VOID,
DESERT_MOUNTAINS, MUTATED_PLAINS,
FLOWER_FOREST, MUTATED_DESERT,
TAIGA_MOUNTAINS, MUTATED_EXTREME_HILLS,
SWAMPLAND_MOUNTAINS, MUTATED_FOREST,
ICE_PLAINS_SPIKES, MUTATED_TAIGA,
JUNGLE_MOUNTAINS, MUTATED_SWAMPLAND,
JUNGLE_EDGE_MOUNTAINS, MUTATED_ICE_FLATS,
COLD_TAIGA_MOUNTAINS, MUTATED_JUNGLE,
SAVANNA_MOUNTAINS, MUTATED_JUNGLE_EDGE,
SAVANNA_PLATEAU_MOUNTAINS, MUTATED_BIRCH_FOREST,
MESA_BRYCE, MUTATED_BIRCH_FOREST_HILLS,
MESA_PLATEAU_FOREST_MOUNTAINS, MUTATED_ROOFED_FOREST,
MESA_PLATEAU_MOUNTAINS, MUTATED_TAIGA_COLD,
BIRCH_FOREST_MOUNTAINS, MUTATED_REDWOOD_TAIGA,
BIRCH_FOREST_HILLS_MOUNTAINS, MUTATED_REDWOOD_TAIGA_HILLS,
ROOFED_FOREST_MOUNTAINS, MUTATED_EXTREME_HILLS_WITH_TREES,
MEGA_SPRUCE_TAIGA, MUTATED_SAVANNA,
EXTREME_HILLS_MOUNTAINS, MUTATED_SAVANNA_ROCK,
EXTREME_HILLS_PLUS_MOUNTAINS, MUTATED_MESA,
MEGA_SPRUCE_TAIGA_HILLS, MUTATED_MESA_ROCK,
MUTATED_MESA_CLEAR_ROCK
} }

View File

@ -0,0 +1,3 @@
package org.bukkit.block;
public interface EndGateway extends BlockState {}

View File

@ -0,0 +1,3 @@
package org.bukkit.block;
public interface Structure extends BlockState {}

View File

@ -0,0 +1,174 @@
package org.bukkit.entity;
import java.util.List;
import org.bukkit.Color;
import org.bukkit.Effect;
import org.bukkit.Particle;
import org.bukkit.potion.PotionEffect;
/**
* Represents an area effect cloud which will imbue a potion effect onto
* entities which enter it.
*/
public interface AreaEffectCloud extends Entity {
/**
* Gets the duration which this cloud will exist for (in ticks).
*
* @return cloud duration
*/
int getDuration();
/**
* Sets the duration which this cloud will exist for (in ticks).
*
* @param duration cloud duration
*/
void setDuration(int duration);
/**
* Gets the time which an entity has to be exposed to the cloud before the
* effect is applied.
*
* @return wait time
*/
int getWaitTime();
/**
* Sets the time which an entity has to be exposed to the cloud before the
* effect is applied.
*
* @param waitTime wait time
*/
void setWaitTime(int waitTime);
/**
* Gets the time that an entity will be immune from subsequent exposure.
*
* @return reapplication delay
*/
int getReapplicationDelay();
/**
* Sets the time that an entity will be immune from subsequent exposure.
*
* @param delay reapplication delay
*/
void setReapplicationDelay(int delay);
/**
* Gets the amount that the duration of this cloud will decrease by when it
* applies an effect to an entity.
*
* @return duration on use delta
*/
int getDurationOnUse();
/**
* Sets the amount that the duration of this cloud will decrease by when it
* applies an effect to an entity.
*
* @param duration duration on use delta
*/
void setDurationOnUse(int duration);
/**
* Gets the initial radius of the cloud.
*
* @return radius
*/
float getRadius();
/**
* Sets the initial radius of the cloud.
*
* @param radius radius
*/
void setRadius(float radius);
/**
* Gets the amount that the radius of this cloud will decrease by when it
* applies an effect to an entity.
*
* @return radius on use delta
*/
float getRadiusOnUse();
/**
* Sets the amount that the radius of this cloud will decrease by when it
* applies an effect to an entity.
*
* @param radius radius on use delta
*/
void setRadiusOnUse(float radius);
/**
* Gets the amount that the radius of this cloud will decrease by each tick.
*
* @return radius per tick delta
*/
float getRadiusPerTick();
/**
* Gets the amount that the radius of this cloud will decrease by each tick.
*
* @param radius per tick delta
*/
void setRadiusPerTick(float radius);
/**
* Gets the particle which this cloud will be composed of
*
* @return particle the set particle type
*/
Particle getParticle();
/**
* Sets the particle which this cloud will be composed of
*
* @param particle the new particle type
*/
void setParticle(Particle particle);
/**
* Get a copy of all effects which can be applied by this cloud. No
* guarantees are made about the nature of the returned list.
*
* @return the list of all effects
*/
List<PotionEffect> getEffects();
/**
* Add an effect which can be applied by this cloud.
*
* @param effect the effect to add
*/
void addEffect(PotionEffect effect);
/**
* Remove an effect from this cloud.
*
* @param effect the effect to remove
*/
void removeEffect(PotionEffect effect);
/**
* Set the effects of this cloud. Will remove all existing effects.
*
* @param effects the new effects to set
*/
void setEffects(List<PotionEffect> effects);
/**
* Gets the color of this cloud. Will be applied as a tint to its particles.
*
* @return cloud color
*/
Color getColor();
/**
* Sets the color of this cloud. Will be applied as a tint to its particles.
*
* @param color cloud color
*/
void setColor(Color color);
}

View File

@ -0,0 +1,3 @@
package org.bukkit.entity;
public interface DragonFireball extends Fireball {}

View File

@ -13,6 +13,7 @@ import org.bukkit.entity.minecart.StorageMinecart;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.potion.PotionEffectType;
public enum EntityType { public enum EntityType {
@ -80,7 +81,29 @@ public enum EntityType {
* A block that is going to or is about to fall. * A block that is going to or is about to fall.
*/ */
FALLING_BLOCK("FallingSand", FallingBlock.class, 21, false), FALLING_BLOCK("FallingSand", FallingBlock.class, 21, false),
/**
* Internal representation of a Firework once it has been launched.
*/
FIREWORK("FireworksRocketEntity", Firework.class, 22, false), FIREWORK("FireworksRocketEntity", Firework.class, 22, false),
/**
* Like {@link #ARROW} but tipped with a specific potion which is applied on contact.
*/
TIPPED_ARROW("TippedArrow", TippedArrow.class, 23),
/**
* Like {@link #TIPPED_ARROW} but causes the {@link PotionEffectType#GLOWING} effect on all team members.
*/
SPECTRAL_ARROW("SpectralArrow", SpectralArrow.class, 24),
/**
* Bullet fired by {@link #SHULKER}.
*/
SHULKER_BULLET("ShulkerBullet", ShulkerBullet.class, 25),
/**
* Like {@link #FIREBALL} but with added effects.
*/
DRAGON_FIREBALL("DragonFireball", DragonFireball.class, 26),
/**
* Mechanical entity with an inventory for placing weapons / armor into.
*/
ARMOR_STAND("ArmorStand", ArmorStand.class, 30, false), ARMOR_STAND("ArmorStand", ArmorStand.class, 30, false),
/** /**
* @see CommandMinecart * @see CommandMinecart
@ -133,6 +156,7 @@ public enum EntityType {
WITCH("Witch", Witch.class, 66), WITCH("Witch", Witch.class, 66),
ENDERMITE("Endermite", Endermite.class, 67), ENDERMITE("Endermite", Endermite.class, 67),
GUARDIAN("Guardian", Guardian.class, 68), GUARDIAN("Guardian", Guardian.class, 68),
SHULKER("Shulker", Shulker.class, 69),
PIG("Pig", Pig.class, 90), PIG("Pig", Pig.class, 90),
SHEEP("Sheep", Sheep.class, 91), SHEEP("Sheep", Sheep.class, 91),
COW("Cow", Cow.class, 92), COW("Cow", Cow.class, 92),
@ -152,6 +176,7 @@ public enum EntityType {
* A flying splash potion. * A flying splash potion.
*/ */
SPLASH_POTION(null, ThrownPotion.class, -1, false), SPLASH_POTION(null, ThrownPotion.class, -1, false),
AREA_EFFECT_CLOUD(null, AreaEffectCloud.class, -1),
/** /**
* A flying chicken egg. * A flying chicken egg.
*/ */

View File

@ -0,0 +1,3 @@
package org.bukkit.entity;
public interface Shulker extends Golem {}

View File

@ -0,0 +1,34 @@
package org.bukkit.entity;
import org.bukkit.projectiles.ProjectileSource;
public interface ShulkerBullet extends Entity {
/**
* Retrieve the shooter of this bullet.
*
* @return the {@link ProjectileSource} that shot this bullet
*/
ProjectileSource getShooter();
/**
* Set the shooter of this bullet.
*
* @param source the {@link ProjectileSource} that shot this bullet
*/
void setShooter(ProjectileSource source);
/**
* Retrieve the target of this bullet.
*
* @return the targeted entity
*/
Entity getTarget();
/**
* Sets the target of this bullet
*
* @param target the entity to target
*/
void setTarget(Entity target);
}

View File

@ -0,0 +1,3 @@
package org.bukkit.entity;
public interface SpectralArrow extends Arrow {}

View File

@ -0,0 +1,3 @@
package org.bukkit.entity;
public interface TippedArrow extends Arrow {}

View File

@ -30,6 +30,23 @@ public interface Zombie extends Monster {
* Sets whether the zombie is a villager * Sets whether the zombie is a villager
* *
* @param flag Whether the zombie is a villager * @param flag Whether the zombie is a villager
* @deprecated Defaults to a basic villager
*/ */
@Deprecated
public void setVillager(boolean flag); public void setVillager(boolean flag);
/**
* Sets whether the zombie is a villager
*
* @param profession the profession of the villager or null to clear
*/
public void setVillagerProfession(Villager.Profession profession);
/**
* Returns the villager profession of the zombie if the
* zombie is a villager
*
* @return the profession or null
*/
public Villager.Profession getVillagerProfession();
} }

View File

@ -407,6 +407,12 @@ public class EntityDamageEvent extends EntityEvent implements Cancellable {
* Damage: 1-4 (Thorns) * Damage: 1-4 (Thorns)
*/ */
THORNS, THORNS,
/**
* Damage caused by a dragon breathing fire.
* <p>
* Damage: variable
*/
DRAGON_BREATH,
/** /**
* Custom damage. * Custom damage.
* <p> * <p>

View File

@ -126,6 +126,26 @@ public abstract class PotionEffectType {
*/ */
public static final PotionEffectType SATURATION = new PotionEffectTypeWrapper(23); public static final PotionEffectType SATURATION = new PotionEffectTypeWrapper(23);
/**
* Outlines the entity so that it can be seen from afar.
*/
public static final PotionEffectType GLOWING = new PotionEffectTypeWrapper(24);
/**
* Causes the entity to float into the air.
*/
public static final PotionEffectType LEVITATION = new PotionEffectTypeWrapper(25);
/**
* Loot table luck.
*/
public static final PotionEffectType LUCK = new PotionEffectTypeWrapper(26);
/**
* Loot table unluck.
*/
public static final PotionEffectType UNLUCK = new PotionEffectTypeWrapper(27);
private final int id; private final int id;
protected PotionEffectType(int id) { protected PotionEffectType(int id) {
@ -202,7 +222,7 @@ public abstract class PotionEffectType {
return "PotionEffectType[" + id + ", " + getName() + "]"; return "PotionEffectType[" + id + ", " + getName() + "]";
} }
private static final PotionEffectType[] byId = new PotionEffectType[24]; private static final PotionEffectType[] byId = new PotionEffectType[28];
private static final Map<String, PotionEffectType> byName = new HashMap<String, PotionEffectType>(); private static final Map<String, PotionEffectType> byName = new HashMap<String, PotionEffectType>();
// will break on updates. // will break on updates.
private static boolean acceptingNew = true; private static boolean acceptingNew = true;

View File

@ -15,6 +15,11 @@ public enum PotionType {
INSTANT_DAMAGE(12, PotionEffectType.HARM, 2), INSTANT_DAMAGE(12, PotionEffectType.HARM, 2),
WATER_BREATHING(13, PotionEffectType.WATER_BREATHING, 1), WATER_BREATHING(13, PotionEffectType.WATER_BREATHING, 1),
INVISIBILITY(14, PotionEffectType.INVISIBILITY, 1), INVISIBILITY(14, PotionEffectType.INVISIBILITY, 1),
/**
* @deprecated not representable with a damage value!
*/
@Deprecated
LUCK(-1, PotionEffectType.LUCK, 1),
; ;
private final int damageValue, maxLevel; private final int damageValue, maxLevel;