Compare commits

..

No commits in common. "a3b8554240c54e079a90246f638a608651ccf559" and "de602396728172cb21e4f82ca4b9672b8f65c995" have entirely different histories.

11 changed files with 23 additions and 420 deletions

56
.gitignore vendored
View File

@ -1,40 +1,26 @@
target/ # ---> Java
!.mvn/wrapper/maven-wrapper.jar # Compiled class file
!**/src/main/**/target/ *.class
!**/src/test/**/target/
### IntelliJ IDEA ### # Log file
.idea/modules.xml *.log
.idea/jarRepositories.xml
.idea/compiler.xml
.idea/libraries/
*.iws
*.iml
*.ipr
### Eclipse ### # BlueJ files
.apt_generated *.ctxt
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ### # Mobile Tools for Java (J2ME)
/nbproject/private/ .mtj.tmp/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ### # Package Files #
.vscode/ *.jar
*.war
*.nar
*.ear
*.zip
*.tar.gz
*.rar
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*
replay_pid*
### Mac OS ###
.DS_Store
/.idea/
/out/

2
README.md Normal file
View File

@ -0,0 +1,2 @@
# DemonBank

42
pom.xml
View File

@ -1,42 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>DemonBank</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<repositories>
<repository>
<id>public-rpg</id>
<url>https://repo.aurora-pixels.com/repository/public-rpg/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId>
<version>1.12.2</version>
</dependency>
<dependency>
<groupId>me.clip.placeholderapi</groupId>
<artifactId>PlaceholderAPI</artifactId>
<version>2.9.2</version>
</dependency>
<dependency>
<groupId>me.Demon.DemonPlugin</groupId>
<artifactId>DemonAPI</artifactId>
<version>1.2.0</version>
</dependency>
</dependencies>
</project>

View File

@ -1,69 +0,0 @@
package me.demon.bank;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.entity.Player;
public abstract class BankAPI {
public static void addVault(Player p,int money){
if(Main.dataMap.get(p) == null){
Main.dataMap.put(p,new BankData(p));
}
long currentTime = System.currentTimeMillis();
Main.lastCommandTime.put(p,currentTime);
BankData bankData = Main.dataMap.get(p);
bankData.addMoney(money);
}
public static int getMoney(String playName){
FileConfiguration yml = Main.plugin.getConfig();
return yml.getInt("BankStats."+playName+".Money");
}
public static void addMoney(String playName,int amount){
int money = getMoney(playName);
setMoney(playName,(money+amount));
}
public static void takeMoney(String playName,int amount){
int money = getMoney(playName);
setMoney(playName,(money-amount));
}
public static void setMoney(String playName,int amount){
FileConfiguration yml = Main.plugin.getConfig();
yml.set("BankStats."+playName+".Money",amount);
}
public static int getMoneyUUID(String uuid){
FileConfiguration yml = Main.plugin.getConfig();
return yml.getInt("BankStats."+uuid+".Money");
}
public static void addMoneyUUID(String uuid,int amount){
int money = getMoneyUUID(uuid);
setMoneyUUID(uuid,(money+amount));
}
public static void takeMoneyUUID(String uuid,int amount){
int money = getMoneyUUID(uuid);
setMoneyUUID(uuid,(money-amount));
}
public static void setMoneyUUID(String uuid,int amount){
FileConfiguration yml = Main.plugin.getConfig();
yml.set("BankStats."+uuid+".Money",amount);
}
public static int getPoints(String playName){
FileConfiguration yml = Main.plugin.getConfig();
return yml.getInt("BankStats."+playName+".Points");
}
public static void addPoints(String playName,int amount){
int money = getPoints(playName);
setPoints(playName,(money+amount));
}
public static void takePoints(String playName,int amount){
int money = getPoints(playName);
setPoints(playName,(money-amount));
}
public static void setPoints(String playName,int amount){
FileConfiguration yml = Main.plugin.getConfig();
yml.set("BankStats."+playName+".Points",amount);
}
}

View File

@ -1,37 +0,0 @@
package me.demon.bank;
import org.bukkit.entity.Player;
public class BankData {
private final Player player;
private int money;
private int points;
public BankData(Player p){
this.player = p;
this.money = 0;
this.points = 0;
}
public void SaveData(){
}
public int getMoney() {
return money;
}
public int getPoints() {
return points;
}
public void addMoney(int money) {
this.money += money;
}
public void setPoints(int points) {
this.points = points;
}
}

View File

@ -1,51 +0,0 @@
package me.demon.bank;
import me.demon.bank.command.BankCommand;
import me.demon.bank.listener.JoinEvent;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;
import java.util.HashMap;
import java.util.Map;
public class Main extends JavaPlugin {
public static String pluginName = "魂式银行";
public static Main plugin;
public static Map<Player, Long> lastCommandTime = new HashMap<>();
public static HashMap<Player,BankData> dataMap = new HashMap<>();
public static String prefix = "§7[§6银行§7] §f";
public void onEnable() {
plugin = this;
saveDefaultConfig();
Bukkit.getServer().getPluginManager().registerEvents(new JoinEvent(), plugin);
Bukkit.getPluginCommand("bank").setExecutor(new BankCommand());
Bukkit.getConsoleSender().sendMessage("§6["+ Main.pluginName+"] §f插件加載成功");
Bukkit.getConsoleSender().sendMessage("§6["+ Main.pluginName+"] §f作者QQ:1763917516");
new Placeholders(this).register();
Bukkit.getScheduler().scheduleSyncRepeatingTask(this, new Runnable(){
@Override
public void run() {
long currentTime = System.currentTimeMillis();
for (Player player : Main.lastCommandTime.keySet()){
if((currentTime - Main.lastCommandTime.get(player)) >= (1000 * 10)){
int money = Main.dataMap.get(player).getMoney();
//HamsterAPI.giveMoney(player,money);
player.sendMessage("获得金币 +"+money);
Main.dataMap.remove(player);
player.sendMessage("发送缓存金币数据,并清理");
Main.lastCommandTime.remove(player);
}
}
}
}, 5 * 20L, 5 * 20L);
}
public void onDisable() {
Main.plugin.saveConfig();
Bukkit.getConsoleSender().sendMessage("§6["+ Main.pluginName+"] §f玩家數據已保存。");
Bukkit.getConsoleSender().sendMessage("§6["+ Main.pluginName+"] §f插件已安全卸載");
}
}

View File

@ -1,51 +0,0 @@
package me.demon.bank;
import me.clip.placeholderapi.expansion.PlaceholderExpansion;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
public class Placeholders extends PlaceholderExpansion {
private Plugin plugin;
public Placeholders(Plugin plugin) {
this.plugin = plugin;
}
@Override
public boolean persist() {
return true;
}
@Override
public boolean canRegister() {
return true;
}
@Override
public String getAuthor() {
return plugin.getDescription().getAuthors().toString();
}
@Override
public String getIdentifier() {
return "bank";
}
@Override
public String getVersion() {
return plugin.getDescription().getVersion();
}
public String onPlaceholderRequest(Player p, String indentifier) {
if (p == null) { return ""; }
if (indentifier.equalsIgnoreCase("money")) {
return String.valueOf(BankAPI.getMoney(p.getName()));
}
if (indentifier.equalsIgnoreCase("points")) {
return String.valueOf(BankAPI.getPoints(p.getName()));
}
return "";
}
}

View File

@ -1,79 +0,0 @@
package me.demon.bank.command;
import me.Demon.DemonPlugin.DemonAPI;
import me.demon.bank.BankAPI;
import me.demon.bank.Main;
import org.bukkit.Sound;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
public class BankCommand implements CommandExecutor {
public boolean onCommand(CommandSender sender, Command cmd, String CommandLabel, String[] args) {
if (CommandLabel.equalsIgnoreCase("bank")) {
String prefix = Main.prefix;
if(args.length == 0){
if(sender instanceof Player) {
Player p = (Player) sender;
JieSuanBank(p);
}else{
sender.sendMessage("");
sender.sendMessage("§e------- ======= §6魂式银行 §e======= -------");
sender.sendMessage("§2/bank reset §e[玩家名] §f- §2清理玩家余额");
sender.sendMessage("§e------- ======= §6魂式银行 §e======= -------");
sender.sendMessage("§2作者QQ: §e1763917516");
}
}
// bank [name] amount
if(args.length == 2 && sender.isOp()){
Player player = (Player) sender;
int money = Integer.parseInt(args[0]);
BankAPI.addVault(player,money);
sender.sendMessage(Main.prefix+" "+player.getName()+" += "+money);
}
if(args.length == 2 && sender.isOp()){
if(args[0].equalsIgnoreCase("text")){
BankAPI.setMoney(sender.getName(), Integer.parseInt(args[1]));
BankAPI.setPoints(sender.getName(), Integer.parseInt(args[1]));
sender.sendMessage(prefix+"成功设置玩家银行数据.");
}
if(args[0].equalsIgnoreCase("reset")){
String playName = args[1];
BankAPI.setMoney(playName,0);
BankAPI.setPoints(playName,0);
sender.sendMessage(prefix+"成功重置玩家银行账户数据.");
}
}
}
return true;
}
public void JieSuanBank(Player p){
int money = BankAPI.getMoney(p.getName());
int points = BankAPI.getPoints(p.getName());
int moneyUUID = BankAPI.getMoneyUUID(String.valueOf(p.getUniqueId()));
if(money == 0 && points == 0 && moneyUUID == 0){
p.sendMessage(Main.prefix+"暂无任何银行收益,无法进行结算!");
return;
}
if(money != 0){
DemonAPI.giveMoney(p,money);
BankAPI.setMoney(p.getName(),0);
p.sendMessage(Main.prefix + "已为你自动结算银行收益: §6" + money + "金币");
}
if(points != 0){
DemonAPI.givePoints(p,points);
BankAPI.setPoints(p.getName(),0);
p.sendMessage(Main.prefix + "已为你自动结算银行收益: §d" + points + "点券");
}
if(moneyUUID >= 1){
DemonAPI.giveMoney(p,moneyUUID);
BankAPI.setMoneyUUID(String.valueOf(p.getUniqueId()),0);
p.sendMessage(Main.prefix + "已为你自动结算商店收益: §6" + moneyUUID + "金币");
}
Main.plugin.saveConfig();
p.playSound(p.getLocation(), Sound.ENTITY_EXPERIENCE_ORB_PICKUP,1,2);
}
}

View File

@ -1,45 +0,0 @@
package me.demon.bank.listener;
import me.Demon.DemonPlugin.DemonAPI;
import me.demon.bank.BankAPI;
import me.demon.bank.Main;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerJoinEvent;
public class JoinEvent implements Listener {
@EventHandler
public void onjoin(PlayerJoinEvent e) {
Player p = e.getPlayer();
Bukkit.getScheduler().runTaskLater(Main.plugin, new Runnable() {
@Override
public void run() {
int money = BankAPI.getMoney(p.getName());
int points = BankAPI.getPoints(p.getName());
int moneyUUID = BankAPI.getMoneyUUID(String.valueOf(p.getUniqueId()));
if (money == 0 && points == 0 && moneyUUID == 0) {
return;
}
if (money != 0) {
DemonAPI.giveMoney(p, money);
BankAPI.setMoney(p.getName(), 0);
p.sendMessage(Main.prefix + "已为你自动结算银行收益: §6" + money + "金币");
}
if (points != 0) {
DemonAPI.givePoints(p, points);
BankAPI.setPoints(p.getName(), 0);
p.sendMessage(Main.prefix + "已为你自动结算银行收益: §d" + points + "点券");
}
if (moneyUUID != 0) {
DemonAPI.giveMoney(p, moneyUUID);
BankAPI.setMoneyUUID(String.valueOf(p.getUniqueId()), 0);
p.sendMessage(Main.prefix + "已为你自动结算商店收益: §6" + moneyUUID + "金币");
}
}
}, 40L);
}
}

View File

@ -1,5 +0,0 @@
BankStats:
虎牙妖魂吖99999999:
Money: 1000
Points: 1
Coins: 0

View File

@ -1,6 +0,0 @@
name: DemonBanK
main: me.demon.bank.Main
version: 1.0.1
depend: [DemonAPI]
commands:
bank: