优化功能
This commit is contained in:
parent
d29bcaff49
commit
c9265ab612
3
.idea/compiler.xml
generated
3
.idea/compiler.xml
generated
@ -10,8 +10,5 @@
|
|||||||
<module name="SrAppraise" />
|
<module name="SrAppraise" />
|
||||||
</profile>
|
</profile>
|
||||||
</annotationProcessing>
|
</annotationProcessing>
|
||||||
<bytecodeTargetLevel>
|
|
||||||
<module name="SrAppraise" target="1.8" />
|
|
||||||
</bytecodeTargetLevel>
|
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
5
.idea/jarRepositories.xml
generated
5
.idea/jarRepositories.xml
generated
@ -26,6 +26,11 @@
|
|||||||
<option name="name" value="Maven Central repository" />
|
<option name="name" value="Maven Central repository" />
|
||||||
<option name="url" value="https://repo1.maven.org/maven2" />
|
<option name="url" value="https://repo1.maven.org/maven2" />
|
||||||
</remote-repository>
|
</remote-repository>
|
||||||
|
<remote-repository>
|
||||||
|
<option name="id" value="central" />
|
||||||
|
<option name="name" value="Central Repository" />
|
||||||
|
<option name="url" value="http://maven.aliyun.com/nexus/content/groups/public" />
|
||||||
|
</remote-repository>
|
||||||
<remote-repository>
|
<remote-repository>
|
||||||
<option name="id" value="jboss.community" />
|
<option name="id" value="jboss.community" />
|
||||||
<option name="name" value="JBoss Community repository" />
|
<option name="name" value="JBoss Community repository" />
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: com.google.code.gson:gson:2.8.0">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/code/gson/gson/2.8.0/gson-2.8.0.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/code/gson/gson/2.8.0/gson-2.8.0-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/code/gson/gson/2.8.0/gson-2.8.0-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: com.google.guava:guava:21.0">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/guava/guava/21.0/guava-21.0.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/guava/guava/21.0/guava-21.0-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/google/guava/guava/21.0/guava-21.0-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: com.googlecode.json-simple:json-simple:1.1.1">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/googlecode/json-simple/json-simple/1.1.1/json-simple-1.1.1.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/googlecode/json-simple/json-simple/1.1.1/json-simple-1.1.1-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/com/googlecode/json-simple/json-simple/1.1.1/json-simple-1.1.1-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: commons-lang:commons-lang:2.6">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/commons-lang/commons-lang/2.6/commons-lang-2.6.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/commons-lang/commons-lang/2.6/commons-lang-2.6-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/commons-lang/commons-lang/2.6/commons-lang-2.6-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
13
.idea/libraries/Maven__junit_junit_4_10.xml
generated
13
.idea/libraries/Maven__junit_junit_4_10.xml
generated
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: junit:junit:4.10">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/junit/junit/4.10/junit-4.10.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/junit/junit/4.10/junit-4.10-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/junit/junit/4.10/junit-4.10-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: net.md-5:bungeecord-chat:1.12-SNAPSHOT">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/net/md-5/bungeecord-chat/1.12-SNAPSHOT/bungeecord-chat-1.12-20180712.114550-97.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/net/md-5/bungeecord-chat/1.12-SNAPSHOT/bungeecord-chat-1.12-20180712.114550-97-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/net/md-5/bungeecord-chat/1.12-SNAPSHOT/bungeecord-chat-1.12-20180712.114550-97-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: org.hamcrest:hamcrest-core:1.1">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/hamcrest/hamcrest-core/1.1/hamcrest-core-1.1.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/hamcrest/hamcrest-core/1.1/hamcrest-core-1.1-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/hamcrest/hamcrest-core/1.1/hamcrest-core-1.1-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: org.projectlombok:lombok:1.18.22">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/projectlombok/lombok/1.18.22/lombok-1.18.22.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/projectlombok/lombok/1.18.22/lombok-1.18.22-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/projectlombok/lombok/1.18.22/lombok-1.18.22-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: org.spigotmc:spigot-api:1.12.2-R0.1-SNAPSHOT">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/spigotmc/spigot-api/1.12.2-R0.1-SNAPSHOT/spigot-api-1.12.2-R0.1-20180712.012057-156.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/spigotmc/spigot-api/1.12.2-R0.1-SNAPSHOT/spigot-api-1.12.2-R0.1-20180712.012057-156-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/spigotmc/spigot-api/1.12.2-R0.1-SNAPSHOT/spigot-api-1.12.2-R0.1-20180712.012057-156-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
13
.idea/libraries/Maven__org_yaml_snakeyaml_1_19.xml
generated
13
.idea/libraries/Maven__org_yaml_snakeyaml_1_19.xml
generated
@ -1,13 +0,0 @@
|
|||||||
<component name="libraryTable">
|
|
||||||
<library name="Maven: org.yaml:snakeyaml:1.19">
|
|
||||||
<CLASSES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/yaml/snakeyaml/1.19/snakeyaml-1.19.jar!/" />
|
|
||||||
</CLASSES>
|
|
||||||
<JAVADOC>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/yaml/snakeyaml/1.19/snakeyaml-1.19-javadoc.jar!/" />
|
|
||||||
</JAVADOC>
|
|
||||||
<SOURCES>
|
|
||||||
<root url="jar://$MAVEN_REPOSITORY$/org/yaml/snakeyaml/1.19/snakeyaml-1.19-sources.jar!/" />
|
|
||||||
</SOURCES>
|
|
||||||
</library>
|
|
||||||
</component>
|
|
10
.idea/libraries/lib.xml
generated
Normal file
10
.idea/libraries/lib.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<component name="libraryTable">
|
||||||
|
<library name="lib">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/lib" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
<jarDirectory url="file://$PROJECT_DIR$/lib" recursive="false" />
|
||||||
|
</library>
|
||||||
|
</component>
|
10
.idea/libraries/lib__3_.xml
generated
Normal file
10
.idea/libraries/lib__3_.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<component name="libraryTable">
|
||||||
|
<library name="lib (3)">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/lib" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
<jarDirectory url="file://$PROJECT_DIR$/lib" recursive="false" />
|
||||||
|
</library>
|
||||||
|
</component>
|
10
.idea/libraries/lib__4_.xml
generated
Normal file
10
.idea/libraries/lib__4_.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<component name="libraryTable">
|
||||||
|
<library name="lib (4)">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/lib" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
<jarDirectory url="file://$PROJECT_DIR$/lib" recursive="false" />
|
||||||
|
</library>
|
||||||
|
</component>
|
10
.idea/libraries/lib__5_.xml
generated
Normal file
10
.idea/libraries/lib__5_.xml
generated
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<component name="libraryTable">
|
||||||
|
<library name="lib (5)">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/lib" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
<jarDirectory url="file://$PROJECT_DIR$/lib" recursive="false" />
|
||||||
|
</library>
|
||||||
|
</component>
|
1
.idea/misc.xml
generated
1
.idea/misc.xml
generated
@ -5,6 +5,7 @@
|
|||||||
<item index="0" class="java.lang.String" itemvalue="org.bukkit.event.EventHandler" />
|
<item index="0" class="java.lang.String" itemvalue="org.bukkit.event.EventHandler" />
|
||||||
</list>
|
</list>
|
||||||
</component>
|
</component>
|
||||||
|
<component name="ExternalStorageConfigurationManager" enabled="true" />
|
||||||
<component name="MavenProjectsManager">
|
<component name="MavenProjectsManager">
|
||||||
<option name="originalFiles">
|
<option name="originalFiles">
|
||||||
<list>
|
<list>
|
||||||
|
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
@ -1,5 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<module org.jetbrains.idea.maven.project.MavenProjectsManager.isMavenModule="true" type="JAVA_MODULE" version="4">
|
<module version="4">
|
||||||
<component name="FacetManager">
|
<component name="FacetManager">
|
||||||
<facet type="minecraft" name="Minecraft">
|
<facet type="minecraft" name="Minecraft">
|
||||||
<configuration>
|
<configuration>
|
||||||
@ -9,26 +9,4 @@
|
|||||||
</configuration>
|
</configuration>
|
||||||
</facet>
|
</facet>
|
||||||
</component>
|
</component>
|
||||||
<component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_8">
|
|
||||||
<output url="file://$MODULE_DIR$/target/classes" />
|
|
||||||
<output-test url="file://$MODULE_DIR$/target/test-classes" />
|
|
||||||
<content url="file://$MODULE_DIR$">
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/target" />
|
|
||||||
</content>
|
|
||||||
<orderEntry type="inheritedJdk" />
|
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
|
||||||
<orderEntry type="library" name="lib (2)" level="project" />
|
|
||||||
<orderEntry type="library" name="Maven: org.projectlombok:lombok:1.18.22" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: org.spigotmc:spigot-api:1.12.2-R0.1-SNAPSHOT" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: commons-lang:commons-lang:2.6" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: com.googlecode.json-simple:json-simple:1.1.1" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: junit:junit:4.10" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: org.hamcrest:hamcrest-core:1.1" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: com.google.guava:guava:21.0" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: com.google.code.gson:gson:2.8.0" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: org.yaml:snakeyaml:1.19" level="project" />
|
|
||||||
<orderEntry type="library" scope="PROVIDED" name="Maven: net.md-5:bungeecord-chat:1.12-SNAPSHOT" level="project" />
|
|
||||||
</component>
|
|
||||||
</module>
|
</module>
|
@ -1,5 +1,6 @@
|
|||||||
package com.yuyu.srappraise;
|
package com.yuyu.srappraise;
|
||||||
|
|
||||||
|
|
||||||
import com.sakurarealm.sritem.bukkit.command.CommandBase;
|
import com.sakurarealm.sritem.bukkit.command.CommandBase;
|
||||||
import com.yuyu.srappraise.command.OpenCommand;
|
import com.yuyu.srappraise.command.OpenCommand;
|
||||||
import com.yuyu.srappraise.config.ConfigManager;
|
import com.yuyu.srappraise.config.ConfigManager;
|
||||||
|
@ -0,0 +1,353 @@
|
|||||||
|
package com.yuyu.srappraise.appraise;
|
||||||
|
|
||||||
|
import com.germ.germplugin.api.dynamic.DynamicBase;
|
||||||
|
import com.germ.germplugin.api.dynamic.gui.*;
|
||||||
|
import com.sakurarealm.sritem.api.ItemStackHelper;
|
||||||
|
import com.sakurarealm.sritem.api.SrItemAPI;
|
||||||
|
import com.sakurarealm.sritem.api.builder.SrItemHandler;
|
||||||
|
import com.yuyu.srappraise.SrAppraise;
|
||||||
|
import com.yuyu.srappraise.pojo.AppraiseProduct;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.PlayerInventory;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @BelongsProject: SrAppraise
|
||||||
|
* @BelongsPackage: com.yuyu.srappraise.appraise
|
||||||
|
* @FileName: AppraiseScreen
|
||||||
|
* @Author: 峰。
|
||||||
|
* @Date: 2024/4/19-21:32
|
||||||
|
* @Version: 1.0
|
||||||
|
* @Description: 用于鉴定界面相关
|
||||||
|
*/
|
||||||
|
public class AppraiseGuiService extends GermGuiScreen {
|
||||||
|
|
||||||
|
private GermGuiScreen gifScreen;
|
||||||
|
private HashMap<String,GermGuiSlot> germGuiSlotHashMap;
|
||||||
|
private List<ItemStack> itemStackHashMap;
|
||||||
|
private int index;
|
||||||
|
|
||||||
|
public AppraiseGuiService(ConfigurationSection configurationSection, String guiName) {
|
||||||
|
super(guiName, configurationSection);
|
||||||
|
this.index = 0;
|
||||||
|
this.germGuiSlotHashMap = new HashMap<>();
|
||||||
|
this.itemStackHashMap = new ArrayList<>();
|
||||||
|
// //TODO(此处绑定给 √ 按钮绑定一个监听事件,在监听事件中获取放入了物品槽位的物品,然后鉴定)
|
||||||
|
this.getSoltGui();
|
||||||
|
this.soltRegister();
|
||||||
|
this.btnRegister();
|
||||||
|
this.registerLeft();
|
||||||
|
this.registerRight();
|
||||||
|
this.gifScreen = GermGuiScreen.getGermGuiScreen("player_inventory-appraise", AppraiseManager.getAppraiseGif());
|
||||||
|
this.setClosedHandler(((player, germGuiScreen) -> {
|
||||||
|
//窗口关闭事件
|
||||||
|
this.returnItemStacks(player);
|
||||||
|
this.close();
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回鉴定槽位内的物品给玩家
|
||||||
|
*
|
||||||
|
* @param player player
|
||||||
|
*/
|
||||||
|
synchronized public void returnItemStacks(Player player) {
|
||||||
|
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
||||||
|
|
||||||
|
List<GermGuiSlot> allGuiParts = canvas.getAllGuiParts(GermGuiSlot.class);
|
||||||
|
|
||||||
|
for (GermGuiSlot guiPart : allGuiParts) {
|
||||||
|
|
||||||
|
if (guiPart.getItemStack().getType() == Material.AIR || (boolean)guiPart.getInteract() == false) {
|
||||||
|
continue;
|
||||||
|
}else {
|
||||||
|
//不是空气就把东西放进玩家背包中去
|
||||||
|
player.getInventory().addItem(guiPart.getItemStack());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public void getSoltGui(){
|
||||||
|
//先获取canvas,再获取canvas中的槽位
|
||||||
|
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
||||||
|
|
||||||
|
GermGuiSlot slot_biomass = (GermGuiSlot) canvas.getGuiPart("slot_consume");
|
||||||
|
GermGuiSlot slot_product_1 = (GermGuiSlot) canvas.getGuiPart("slot_product_1");
|
||||||
|
GermGuiSlot slot_product_2 = (GermGuiSlot) canvas.getGuiPart("slot_product_2");
|
||||||
|
GermGuiSlot slot_product_3 = (GermGuiSlot) canvas.getGuiPart("slot_product_3");
|
||||||
|
GermGuiSlot slot_product_4 = (GermGuiSlot) canvas.getGuiPart("slot_product_4");
|
||||||
|
GermGuiSlot slot_product_5 = (GermGuiSlot) canvas.getGuiPart("slot_product_5");
|
||||||
|
|
||||||
|
this.germGuiSlotHashMap.put("slot_consume",slot_biomass);
|
||||||
|
this.germGuiSlotHashMap.put("slot_product_1",slot_product_1);
|
||||||
|
this.germGuiSlotHashMap.put("slot_product_2",slot_product_2);
|
||||||
|
this.germGuiSlotHashMap.put("slot_product_3",slot_product_3);
|
||||||
|
this.germGuiSlotHashMap.put("slot_product_4",slot_product_4);
|
||||||
|
this.germGuiSlotHashMap.put("slot_product_5",slot_product_5);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 监听物品槽
|
||||||
|
*/
|
||||||
|
synchronized public void soltRegister() {
|
||||||
|
GermGuiSlot slot_biomass = this.germGuiSlotHashMap.get("slot_consume");
|
||||||
|
|
||||||
|
slot_biomass.registerCallbackHandler((player, germGuiSlot) -> {
|
||||||
|
|
||||||
|
ItemStack itemStack = slot_biomass.getItemStack();
|
||||||
|
|
||||||
|
//如果放上去空气直接返回不管
|
||||||
|
if(itemStack == null || itemStack.getType() == Material.AIR) {
|
||||||
|
return;
|
||||||
|
}else if (ItemStackHelper.getSrItemHandler(itemStack) == null){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//获取名字判断是否在可鉴定的物品中]
|
||||||
|
SrItemHandler srItemHandler = ItemStackHelper.getSrItemHandler(itemStack);
|
||||||
|
String title = srItemHandler.getTitle();
|
||||||
|
//这个是item的名字
|
||||||
|
String itemName = title.substring(title.indexOf('l') + 1);
|
||||||
|
|
||||||
|
if (SrAppraise.getConfigManager().getAppraiseItemMap().containsKey(itemName)){
|
||||||
|
|
||||||
|
itemStackHashMap.clear();
|
||||||
|
|
||||||
|
HashMap<String, AppraiseProduct> appraiseProductHashMap =
|
||||||
|
SrAppraise.getConfigManager().getAppraiseItemMap().get(itemName);
|
||||||
|
for (String key : appraiseProductHashMap.keySet()){
|
||||||
|
//获取ItemStack
|
||||||
|
ItemStack product = appraiseProductHashMap.get(key).getItemStack();
|
||||||
|
if (product != null) {
|
||||||
|
product.setAmount(1);
|
||||||
|
this.itemStackHashMap.add(product);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//把可能的产物放上槽位中
|
||||||
|
for (int i = 1;i<= this.itemStackHashMap.size() && i <= 5;i++){
|
||||||
|
//物品槽位
|
||||||
|
String slot = "slot_product_"+ i;
|
||||||
|
//获取产物
|
||||||
|
ItemStack product = this.itemStackHashMap.get(i - 1);
|
||||||
|
GermGuiSlot productSlot = this.germGuiSlotHashMap.get(slot);
|
||||||
|
productSlot.setItemStack(product);
|
||||||
|
//把展示槽锁住
|
||||||
|
productSlot.setInteract(false);
|
||||||
|
}
|
||||||
|
this.index = 1;
|
||||||
|
}else {
|
||||||
|
//不包含就返回
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
},GermGuiSlot.EventType.LEFT_CLICK); //左键点击时触发,注意可能会放空气进去
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 左侧按键监听
|
||||||
|
*/
|
||||||
|
public void registerLeft(){
|
||||||
|
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
||||||
|
GermGuiButton leftButton = (GermGuiButton) canvas.getGuiPart("left_button");
|
||||||
|
|
||||||
|
leftButton.registerCallbackHandler((player, germGuiSlot) -> {
|
||||||
|
|
||||||
|
if (this.itemStackHashMap.size() <= 5){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
GermGuiSlot slotConsume = this.germGuiSlotHashMap.get("slot_consume");
|
||||||
|
|
||||||
|
if (slotConsume.getItemStack().getType() == Material.AIR) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//先确定一号槽位的值
|
||||||
|
if(this.index == this.itemStackHashMap.size()){
|
||||||
|
this.index = 1;
|
||||||
|
//放东西进去
|
||||||
|
this.setItemToSlot();
|
||||||
|
}else {
|
||||||
|
this.index++;
|
||||||
|
this.setItemToSlot();
|
||||||
|
}
|
||||||
|
},GermGuiButton.EventType.LEFT_CLICK);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 右侧按键监听
|
||||||
|
*/
|
||||||
|
public void registerRight(){
|
||||||
|
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
||||||
|
GermGuiButton rightButton = (GermGuiButton) canvas.getGuiPart("right_button");
|
||||||
|
|
||||||
|
rightButton.registerCallbackHandler((player, germGuiSlot) -> {
|
||||||
|
|
||||||
|
if (this.itemStackHashMap.size() <= 5){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
GermGuiSlot slotConsume = this.germGuiSlotHashMap.get("slot_consume");
|
||||||
|
|
||||||
|
if (slotConsume.getItemStack().getType() == Material.AIR) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.index == 1){
|
||||||
|
this.index = this.itemStackHashMap.size();
|
||||||
|
setItemToSlot();
|
||||||
|
}else {
|
||||||
|
this.index--;
|
||||||
|
this.setItemToSlot();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
},GermGuiButton.EventType.LEFT_CLICK);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用于在槽位中放置物品
|
||||||
|
*/
|
||||||
|
public void setItemToSlot() {
|
||||||
|
//用于获取ItemStackHashMap中的产物,因为List索引从0开始,所以此处-1
|
||||||
|
int indexCopy = index - 1;
|
||||||
|
|
||||||
|
for (int i = 1;i <= this.itemStackHashMap.size() && i <= 5;i++){
|
||||||
|
//物品槽位
|
||||||
|
String slot = "slot_product_"+ i;
|
||||||
|
//获取产物
|
||||||
|
ItemStack product = this.itemStackHashMap.get(indexCopy);
|
||||||
|
GermGuiSlot productSlot = this.germGuiSlotHashMap.get(slot);
|
||||||
|
productSlot.setItemStack(product);
|
||||||
|
|
||||||
|
indexCopy += 1;
|
||||||
|
|
||||||
|
if (indexCopy == this.itemStackHashMap.size()){
|
||||||
|
indexCopy = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 此方法用于绑定鉴定事件的发生
|
||||||
|
*/
|
||||||
|
public void btnRegister() {
|
||||||
|
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
||||||
|
|
||||||
|
GermGuiButton confrimBtn = (GermGuiButton) canvas.getGuiPart("b_confirm");
|
||||||
|
confrimBtn.registerCallbackHandler((clickPlayer, btn) -> {
|
||||||
|
|
||||||
|
Random random = new Random();
|
||||||
|
HashMap<String,ItemStack> itemStacks= new HashMap<>();
|
||||||
|
//获取物品槽
|
||||||
|
GermGuiSlot slot_biomass = this.germGuiSlotHashMap.get("slot_consume");
|
||||||
|
|
||||||
|
//开始鉴定后把槽位锁住
|
||||||
|
slot_biomass.setInteract(true);
|
||||||
|
//获取鉴定的物品
|
||||||
|
ItemStack itemStack = slot_biomass.getItemStack();
|
||||||
|
|
||||||
|
if(itemStack == null || itemStack.getType() == Material.AIR) {
|
||||||
|
clickPlayer.sendMessage(ChatColor.RED + "你必须在鉴定槽中放一个东西!");
|
||||||
|
return;
|
||||||
|
}else if (ItemStackHelper.getSrItemHandler(itemStack) == null){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
gifScreen.openChildGui(clickPlayer);
|
||||||
|
|
||||||
|
SrItemHandler srItemHandler = ItemStackHelper.getSrItemHandler(itemStack);
|
||||||
|
String title = srItemHandler.getTitle();
|
||||||
|
//这个是item的名字
|
||||||
|
String itemName = title.substring(title.indexOf('l') + 1);
|
||||||
|
// String s = srItemHandler.getLore().get(0);
|
||||||
|
|
||||||
|
//先判断物品是否在可以鉴定的列表里面
|
||||||
|
if (SrAppraise.getConfigManager().getAppraiseItemMap().containsKey(itemName)){
|
||||||
|
|
||||||
|
//清空物品槽
|
||||||
|
for (int i = 1 ;i <= 5;i++){
|
||||||
|
String slot = "slot_product_" + i;
|
||||||
|
GermGuiSlot germGuiSlot = this.germGuiSlotHashMap.get(slot);
|
||||||
|
germGuiSlot.setItemStack(new ItemStack(Material.AIR));
|
||||||
|
germGuiSlot.setInteract(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
HashMap<String, AppraiseProduct> stringAppraiseProductHashMap =
|
||||||
|
SrAppraise.getConfigManager().getAppraiseItemMap().get(itemName);
|
||||||
|
|
||||||
|
int amount = itemStack.getAmount();
|
||||||
|
//如果同时鉴定多个
|
||||||
|
for (int i = 0;i < amount;i++) {
|
||||||
|
//利用Random生成一个随机数来确定产物
|
||||||
|
float probility = random.nextFloat();
|
||||||
|
for (String product : stringAppraiseProductHashMap.keySet()) {
|
||||||
|
AppraiseProduct appraiseProduct = stringAppraiseProductHashMap.get(product);
|
||||||
|
if (probility >= appraiseProduct.getProMin() && probility < appraiseProduct.getProMax()) {
|
||||||
|
//概率通过,获取该产物
|
||||||
|
ItemStack item =
|
||||||
|
appraiseProduct.getItemStack();
|
||||||
|
//获取产物后,将产物String,ItemStack K-V 的形式存到map中
|
||||||
|
if (itemStacks.containsKey(product)) {
|
||||||
|
ItemStack itemStack1 = itemStacks.get(product);
|
||||||
|
itemStack1.setAmount(itemStack1.getAmount() + 1);
|
||||||
|
break;
|
||||||
|
}else {
|
||||||
|
itemStacks.put(product, item);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//所有物品全部结束循环的时候
|
||||||
|
int j = 1;
|
||||||
|
int timeRun = 8000 / itemStacks.size();
|
||||||
|
for (ItemStack srItem : itemStacks.values()){
|
||||||
|
try {
|
||||||
|
Thread.sleep(timeRun);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
//拼接物品槽的名字
|
||||||
|
String slot = "slot_product_" + j;
|
||||||
|
GermGuiSlot product = this.germGuiSlotHashMap.get(slot);
|
||||||
|
ItemStack itemStack1 = product.getItemStack();
|
||||||
|
//有五个物品槽
|
||||||
|
if (j <= 5 && itemStack1.getType() == Material.AIR){
|
||||||
|
product.setItemStack(srItem);
|
||||||
|
itemStack.setAmount(itemStack.getAmount() - srItem.getAmount());
|
||||||
|
slot_biomass.setItemStack(itemStack);
|
||||||
|
|
||||||
|
}else {
|
||||||
|
//多出来的放进玩家背包
|
||||||
|
PlayerInventory inventory = clickPlayer.getInventory();
|
||||||
|
inventory.addItem(srItem);
|
||||||
|
itemStack.setAmount(itemStack.getAmount() - srItem.getAmount());
|
||||||
|
slot_biomass.setItemStack(itemStack);
|
||||||
|
}
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
int amount = itemStack.getAmount();
|
||||||
|
clickPlayer.sendMessage(ChatColor.AQUA+"这是"+amount+"个"+itemName);
|
||||||
|
}
|
||||||
|
|
||||||
|
slot_biomass.setInteract(false);
|
||||||
|
gifScreen.close();
|
||||||
|
|
||||||
|
}, GermGuiButton.EventType.LEFT_CLICK);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -24,12 +24,17 @@ public class AppraiseManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ConfigurationSection getForgePlayerInventory() {
|
public static ConfigurationSection getForgePlayerInventory() {
|
||||||
return GermGuiService.getGermGui("forge", "player_inventory-forge");
|
return GermGuiService.getGermGui("appraise", "player_inventory-appraise");
|
||||||
}
|
}
|
||||||
public static ConfigurationSection getAppraiseInventory() {
|
public static ConfigurationSection getAppraiseInventory() {
|
||||||
return GermGuiService.getGermGui("appraise", "appraise");
|
return GermGuiService.getGermGui("appraise", "appraise");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static ConfigurationSection getAppraiseGif(){
|
||||||
|
return GermGuiService.getGermGui("appraise", "appraise_gif");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void open(Player player,String guiName){
|
public void open(Player player,String guiName){
|
||||||
|
@ -1,111 +0,0 @@
|
|||||||
package com.yuyu.srappraise.appraise;
|
|
||||||
|
|
||||||
import com.germ.germplugin.api.dynamic.DynamicBase;
|
|
||||||
import com.germ.germplugin.api.dynamic.gui.*;
|
|
||||||
import com.sakurarealm.sritem.api.ItemStackHelper;
|
|
||||||
import com.sakurarealm.sritem.api.SrItemAPI;
|
|
||||||
import com.sakurarealm.sritem.api.SrItemManager;
|
|
||||||
import com.sakurarealm.sritem.api.builder.SrItemHandler;
|
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.ChatColor;
|
|
||||||
import org.bukkit.Material;
|
|
||||||
import org.bukkit.configuration.ConfigurationSection;
|
|
||||||
import org.bukkit.entity.Item;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.bukkit.inventory.ItemStack;
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @BelongsProject: SrAppraise
|
|
||||||
* @BelongsPackage: com.yuyu.srappraise.appraise
|
|
||||||
* @FileName: AppraiseScreen
|
|
||||||
* @Author: 峰。
|
|
||||||
* @Date: 2024/4/19-21:32
|
|
||||||
* @Version: 1.0
|
|
||||||
* @Description: 用于鉴定界面相关
|
|
||||||
*/
|
|
||||||
public class AppraiseScreen extends GermGuiScreen {
|
|
||||||
|
|
||||||
public AppraiseScreen(ConfigurationSection configurationSection,String guiName) {
|
|
||||||
super(guiName,configurationSection);
|
|
||||||
//TODO(此处绑定给 √ 按钮绑定一个监听事件,在监听事件中获取放入了物品槽位的物品,然后鉴定)
|
|
||||||
this.btnRegister();
|
|
||||||
this.setClosedHandler(((player, germGuiScreen) -> {
|
|
||||||
//窗口关闭事件
|
|
||||||
this.returnItemStacks(player);
|
|
||||||
this.close();
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 返回鉴定槽位内的物品给玩家
|
|
||||||
*
|
|
||||||
* @param player player
|
|
||||||
*/
|
|
||||||
synchronized public void returnItemStacks(Player player) {
|
|
||||||
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
|
||||||
|
|
||||||
GermGuiSlot slot_biomass = (GermGuiSlot) canvas.getGuiPart("slot_biomass");
|
|
||||||
|
|
||||||
|
|
||||||
ItemStack biomass_itemStack = slot_biomass.getItemStack();
|
|
||||||
|
|
||||||
if (biomass_itemStack != null && biomass_itemStack.getType() != Material.AIR) {
|
|
||||||
player.getInventory().addItem(biomass_itemStack);
|
|
||||||
}
|
|
||||||
slot_biomass.setItemStack(Material.AIR);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// public ItemStack getSrItem(){
|
|
||||||
// ItemStack item = SrItemAPI.getItem();
|
|
||||||
// }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 此方法用于绑定鉴定事件的发生
|
|
||||||
*/
|
|
||||||
public void btnRegister(){
|
|
||||||
//先获取canvas,再获取canvas中的按键
|
|
||||||
GermGuiCanvas canvas = (GermGuiCanvas) getGuiPart("utility");
|
|
||||||
|
|
||||||
GermGuiButton confrimBtn = (GermGuiButton) canvas.getGuiPart("b_confirm");
|
|
||||||
confrimBtn.registerCallbackHandler((clickPlayer, btn) -> {
|
|
||||||
|
|
||||||
GermGuiSlot slot_biomass = (GermGuiSlot) canvas.getGuiPart("slot_biomass");
|
|
||||||
|
|
||||||
ItemStack itemStack = slot_biomass.getItemStack();
|
|
||||||
|
|
||||||
SrItemHandler srItemHandler = ItemStackHelper.getSrItemHandler(itemStack);
|
|
||||||
String title = srItemHandler.getTitle();
|
|
||||||
String index = title.substring(title.indexOf('l') + 1);
|
|
||||||
String s = srItemHandler.getLore().get(0);
|
|
||||||
|
|
||||||
if (SrItemAPI.hasItem(index)) {
|
|
||||||
//TODO(此处hasItem的索引能通过,可以试试getItem能不能通过获取rpg物品)
|
|
||||||
// SrItemManager.getInstance().getItem(index)
|
|
||||||
index = s.substring(s.indexOf('-') + 1);
|
|
||||||
itemStack = SrItemAPI.getItem(index,new HashMap<>(), Bukkit.getPlayer(clickPlayer.getName()),true,true);
|
|
||||||
if (itemStack == null){
|
|
||||||
clickPlayer.sendMessage(ChatColor.RED+title+"不存在");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (itemStack.getAmount() != 1) {
|
|
||||||
clickPlayer.sendMessage(ChatColor.RED + "每次只能鉴定一个物品!");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (itemStack != null && itemStack.getType() != Material.AIR) {
|
|
||||||
itemStack.setAmount(2);
|
|
||||||
clickPlayer.sendMessage(ChatColor.RED + "这是" + itemStack.getType().name());
|
|
||||||
SrItemAPI instance = SrItemAPI.INSTANCE;
|
|
||||||
slot_biomass.setItemStack(itemStack);
|
|
||||||
}
|
|
||||||
}else {
|
|
||||||
clickPlayer.sendMessage(ChatColor.GREEN+"这是一个"+itemStack.getType().name());
|
|
||||||
}
|
|
||||||
}, GermGuiButton.EventType.LEFT_CLICK);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -7,4 +7,4 @@ commands:
|
|||||||
srappraise:
|
srappraise:
|
||||||
description: Appraise command
|
description: Appraise command
|
||||||
aliases: [ sra ]
|
aliases: [ sra ]
|
||||||
permission: sritem.command
|
permission: srappraose.command
|
||||||
|
Loading…
x
Reference in New Issue
Block a user