1
0
mirror of https://e.coding.net/circlecloud/JumpPlate.git synced 2025-11-25 19:46:01 +00:00

初始化项目...

Signed-off-by: 502647092 <jtb1@163.com>
This commit is contained in:
502647092
2016-01-26 23:12:30 +08:00
commit 42a299ea4a
7 changed files with 354 additions and 0 deletions

View File

@@ -0,0 +1,152 @@
package cn.citycraft.JumpPlate;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.block.Action;
import org.bukkit.event.block.BlockPlaceEvent;
import org.bukkit.event.entity.EntityDamageEvent;
import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
import org.bukkit.event.entity.EntityDamageEvent.DamageModifier;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.plugin.java.JavaPlugin;
import cn.citycraft.PluginHelper.commands.HandlerCommand;
import cn.citycraft.PluginHelper.commands.HandlerCommands;
import cn.citycraft.PluginHelper.commands.HandlerSubCommand;
import cn.citycraft.PluginHelper.config.FileConfig;
import cn.citycraft.PluginHelper.utils.VersionChecker;
public class JumpPlate extends JavaPlugin implements Listener, HandlerCommands {
Set<String> fall = new HashSet<>();
List<Material> ml = new ArrayList<>();
String pluginname;
FileConfig config;
@EventHandler(ignoreCancelled = true)
public void onCreate(final BlockPlaceEvent e) {
final Player p = e.getPlayer();
if (e.getBlockPlaced().getType() == Material.GOLD_PLATE) {
final Location gb = e.getBlockPlaced().getLocation();
final Block loc = gb.add(0.0D, -1.0D, 0.0D).getBlock();
final Block loc_1 = gb.add(0.0D, -1.0D, 0.0D).getBlock();
final Block loc_2 = gb.add(0.0D, -1.0D, 0.0D).getBlock();
if (loc_1.getType() == Material.GLASS && loc_2.getType() == Material.LAPIS_BLOCK && ml.contains(loc.getType())) {
if (p.hasPermission("JumpPlate.reload")) {
p.sendMessage(pluginname + config.getMessage("create"));
} else {
e.setCancelled(true);
p.sendMessage(pluginname + config.getMessage("no-permission"));
}
}
}
}
@Override
public void onEnable() {
ml.add(Material.IRON_BLOCK);
ml.add(Material.GOLD_BLOCK);
ml.add(Material.DIAMOND_BLOCK);
ml.add(Material.EMERALD_BLOCK);
ml.add(Material.BEDROCK);
new HandlerSubCommand(this, "jp").registerCommands(this);
this.getServer().getPluginManager().registerEvents(this, this);
new VersionChecker(this);
}
@EventHandler
public void onFallDamage(final EntityDamageEvent e) {
if (e.getEntity() instanceof Player) {
final Player p = (Player) e.getEntity();
if (e.getCause() == DamageCause.FALL && (fall.contains(p.getName()))) {
final Location gb = p.getLocation();
final Block loc = gb.add(0.0D, -1.0D, 0.0D).getBlock();
final Block loc_1 = gb.add(0.0D, -1.0D, 0.0D).getBlock();
final Block loc_2 = gb.add(0.0D, -1.0D, 0.0D).getBlock();
if (loc_1.getType() != Material.GLASS || loc_2.getType() != Material.LAPIS_BLOCK || !ml.contains(loc.getType())) {
fall.remove(p);
}
e.setDamage(DamageModifier.BASE, 0);
}
}
}
@EventHandler
public void onJump(final PlayerInteractEvent e) {
final Player p = e.getPlayer();
if (e.getAction() != Action.PHYSICAL) {
return;
}
final Block gb = e.getClickedBlock();
if (gb.getType() != Material.GOLD_PLATE) {
return;
}
final Block loc = gb.getRelative(BlockFace.DOWN);
final Block loc_1 = gb.getRelative(BlockFace.DOWN, 2);
final Block loc_2 = gb.getRelative(BlockFace.DOWN, 3);
if ((loc_1.getType() == Material.GLASS) && (loc_2.getType() == Material.LAPIS_BLOCK)) {
if (!p.hasPermission("JumpPlate.use")) {
p.sendMessage(pluginname + config.getMessage("no-permission"));
return;
}
switch (loc.getType()) {
case IRON_BLOCK:
fall.add(p.getName());
p.setVelocity(p.getVelocity().setY(1));
break;
case GOLD_BLOCK:
fall.add(p.getName());
p.setVelocity(p.getVelocity().setY(1.5));
break;
case DIAMOND_BLOCK:
fall.add(p.getName());
p.setVelocity(p.getVelocity().setY(2));
break;
case EMERALD_BLOCK:
fall.add(p.getName());
p.setVelocity(p.getVelocity().setY(2.5));
break;
case BEDROCK:
fall.add(p.getName());
p.setVelocity(p.getVelocity().setY(config.getDouble("BEDROCK")));
break;
default:
break;
}
}
}
@Override
public void onLoad() {
config = new FileConfig(this);
pluginname = config.getMessage("pluginname");
}
@HandlerCommand(name = "reload", description = "重载插件配置", permission = "JumpPlate.reload")
private void reloadCommand(final CommandSender sender, final Command command, final String label, final String[] args) {
this.onLoad();
sender.sendMessage(pluginname + "§a配置文件已重载!");
}
@HandlerCommand(name = "set", description = "设置基岩跳板高度", minimumArguments = 1, onlyPlayerExecutable = true, permission = "JumpPlate.reload", possibleArguments = "<跳板高度(1-10)>")
private void setCommand(final CommandSender sender, final Command command, final String label, final String[] args) {
try {
final double drb = Double.parseDouble(args[0]);
config.set("BEDROCK", drb);
sender.sendMessage("§a基岩的跳板弹跳倍数已设置为 " + drb + "倍!");
} catch (final NumberFormatException e) {
sender.sendMessage("§c参数非法 请输入数字 1-10");
}
}
}

View File

@@ -0,0 +1,4 @@
pluginname: '&6[&b超级跳板&6]&r '
no-permission: '&c你没有使用跳板的权限!'
create: '&a您成功创建了一个跳板!'
BEDROCK: 10

View File

@@ -0,0 +1,20 @@
name: ${project.artifactId}
description: ${project.description}
main: ${project.groupId}.${project.artifactId}.${project.artifactId}
version: ${project.version}-git-${env.GIT_COMMIT}
author: 喵♂呜
website: ${jenkins.url}/job/${project.artifactId}/
commands:
${project.artifactId}:
description: ${project.artifactId} - ${project.description}
aliases: [jp]
usage: §b使用/${project.artifactId} help 查看帮助!
permission: ${project.artifactId}.reload
permission-message: §c你没有 <permission> 的权限来执行此命令!
permissions:
${project.artifactId}.use:
description: ${project.artifactId} 使用!
default: true
${project.artifactId}.reload:
description: 重新载入插件!
default: op