aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java')
-rwxr-xr-xsrc/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java239
1 files changed, 0 insertions, 239 deletions
diff --git a/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java b/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java
deleted file mode 100755
index 5914be15..00000000
--- a/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java
+++ /dev/null
@@ -1,239 +0,0 @@
-/*
- * Dungeons Guide - The most intelligent Hypixel Skyblock Dungeons Mod
- * Copyright (C) 2021 cyoung06
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
-
-package kr.syeyoung.dungeonsguide.dungeon.mechanics;
-
-import com.google.common.collect.Sets;
-import kr.syeyoung.dungeonsguide.dungeon.DungeonActionManager;
-import kr.syeyoung.dungeonsguide.dungeon.actions.*;
-import kr.syeyoung.dungeonsguide.dungeon.data.OffsetPoint;
-import kr.syeyoung.dungeonsguide.dungeon.mechanics.predicates.PredicateBat;
-import kr.syeyoung.dungeonsguide.dungeon.roomfinder.DungeonRoom;
-import kr.syeyoung.dungeonsguide.pathfinding.NodeProcessorDungeonRoom;
-import kr.syeyoung.dungeonsguide.utils.RenderUtils;
-import lombok.AllArgsConstructor;
-import lombok.Data;
-import lombok.Getter;
-import net.minecraft.block.state.IBlockState;
-import net.minecraft.client.Minecraft;
-import net.minecraft.init.Blocks;
-import net.minecraft.tileentity.TileEntityChest;
-import net.minecraft.util.BlockPos;
-import net.minecraft.util.Vec3;
-
-import java.awt.*;
-import java.util.*;
-import java.util.List;
-
-@Data
-public class DungeonSecret implements DungeonMechanic {
- private static final long serialVersionUID = 8784808599222706537L;
-
- private OffsetPoint secretPoint = new OffsetPoint(0,0,0);
- private SecretType secretType = SecretType.CHEST;
- private List<String> preRequisite = new ArrayList<String>();
-
- public void tick(DungeonRoom dungeonRoom) {
- if (secretType == SecretType.CHEST) {
- BlockPos pos = secretPoint.getBlockPos(dungeonRoom);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(pos);
- if (blockState.getBlock() == Blocks.chest || blockState.getBlock() == Blocks.trapped_chest) {
- TileEntityChest chest = (TileEntityChest) dungeonRoom.getContext().getWorld().getTileEntity(pos);
- if (chest.numPlayersUsing > 0) {
- dungeonRoom.getRoomContext().put("c-"+pos.toString(), 2);
- } else {
- dungeonRoom.getRoomContext().put("c-"+pos.toString(), 1);
- }
- }
- } else if (secretType == SecretType.ESSENCE) {
- BlockPos pos = secretPoint.getBlockPos(dungeonRoom);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(pos);
- if (blockState.getBlock() == Blocks.skull) {
- dungeonRoom.getRoomContext().put("e-"+pos.toString(), true);
- }
- } else if (secretType == SecretType.ITEM_DROP) {
- Vec3 pos = new Vec3(secretPoint.getBlockPos(dungeonRoom));
- Vec3 player = Minecraft.getMinecraft().thePlayer.getPositionVector();
- if (player.squareDistanceTo(pos) < 16) {
- Vec3 vec3 = pos.subtract(player).normalize();
- for (int i = 0; i < player.distanceTo(pos); i++) {
- Vec3 vec = player.addVector(vec3.xCoord * i, vec3.yCoord * i, vec3.zCoord * i);
- BlockPos bpos = new BlockPos(vec);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(bpos);
- if (!NodeProcessorDungeonRoom.isValidBlock(blockState))
- return;
- }
- dungeonRoom.getRoomContext().put("i-" + pos, true);
- }
- }
- }
-
- public SecretStatus getSecretStatus(DungeonRoom dungeonRoom) {
- if (secretType == SecretType.CHEST) {
- BlockPos pos = secretPoint.getBlockPos(dungeonRoom);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(pos);
- if (dungeonRoom.getRoomContext().containsKey("c-"+pos.toString()))
- return ((int)dungeonRoom.getRoomContext().get("c-"+pos.toString()) == 2 || blockState.getBlock() == Blocks.air) ? SecretStatus.FOUND : SecretStatus.CREATED;
-
- if (blockState.getBlock() == Blocks.air) {
- return SecretStatus.DEFINITELY_NOT;
- } else if (blockState.getBlock() != Blocks.chest && blockState.getBlock() != Blocks.trapped_chest) {
- return SecretStatus.ERROR;
- } else {
- TileEntityChest chest = (TileEntityChest) dungeonRoom.getContext().getWorld().getTileEntity(pos);
- if (chest.numPlayersUsing > 0) {
- return SecretStatus.FOUND;
- } else{
- return SecretStatus.CREATED;
- }
- }
- } else if (secretType == SecretType.ESSENCE) {
- BlockPos pos = secretPoint.getBlockPos(dungeonRoom);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(pos);
- if (blockState.getBlock() == Blocks.skull) {
- dungeonRoom.getRoomContext().put("e-"+pos.toString(), true);
- return SecretStatus.DEFINITELY_NOT;
- } else {
- if (dungeonRoom.getRoomContext().containsKey("e-"+pos.toString()))
- return SecretStatus.FOUND;
- return SecretStatus.NOT_SURE;
- }
- } else if (secretType == SecretType.BAT) {
- Vec3 spawn = new Vec3(secretPoint.getBlockPos(dungeonRoom));
- for (Integer killed : DungeonActionManager.getKilleds()) {
- if (DungeonActionManager.getSpawnLocation().get(killed) == null) continue;
- if (DungeonActionManager.getSpawnLocation().get(killed).squareDistanceTo(spawn) < 100) {
- return SecretStatus.FOUND;
- }
- }
- return SecretStatus.NOT_SURE;
- } else {
- Vec3 pos = new Vec3(secretPoint.getBlockPos(dungeonRoom));
- if (dungeonRoom.getRoomContext().containsKey("i-"+ pos))
- return SecretStatus.FOUND;
- Vec3 player = Minecraft.getMinecraft().thePlayer.getPositionVector();
- if (player.squareDistanceTo(pos) < 16) {
- Vec3 vec3 = pos.subtract(player).normalize();
- for (int i = 0; i < player.distanceTo(pos); i++) {
- Vec3 vec = player.addVector(vec3.xCoord * i, vec3.yCoord * i, vec3.zCoord * i);
- BlockPos bpos = new BlockPos(vec);
- IBlockState blockState = dungeonRoom.getContext().getWorld().getBlockState(bpos);
- if (!NodeProcessorDungeonRoom.isValidBlock(blockState))
- return SecretStatus.NOT_SURE;
- }
- dungeonRoom.getRoomContext().put("i-" + pos, true);
- }
- return SecretStatus.NOT_SURE;
- }
- }
-
- @Override
- public Set<Action> getAction(String state, DungeonRoom dungeonRoom) {
- if (state.equalsIgnoreCase("navigate")) {
- Set<Action> base;
- Set<Action> preRequisites = base = new HashSet<Action>();
- ActionMoveNearestAir actionMove = new ActionMoveNearestAir(getRepresentingPoint(dungeonRoom));
- preRequisites.add(actionMove);
- preRequisites = actionMove.getPreRequisite();
- for (String str : preRequisite) {
- if (str.isEmpty()) continue;
- ActionChangeState actionChangeState = new ActionChangeState(str.split(":")[0], str.split(":")[1]);
- preRequisites.add(actionChangeState);
- }
- return base;
- }
- if (!"found".equalsIgnoreCase(state)) throw new IllegalArgumentException(state+" is not valid state for secret");
- if (state.equals("found") && getSecretStatus(dungeonRoom) == SecretStatus.FOUND) return new HashSet<>();
- Set<Action> base;
- Set<Action> preRequisites = base = new HashSet<Action>();
- if (secretType == SecretType.CHEST || secretType == SecretType.ESSENCE) {
- ActionClick actionClick;
- preRequisites.add(actionClick = new ActionClick(secretPoint));
- preRequisites = actionClick.getPreRequisite();
- } else if (secretType == SecretType.BAT) {
- ActionKill actionKill;
- preRequisites.add(actionKill = new ActionKill(secretPoint));
- actionKill.setPredicate(PredicateBat.INSTANCE);
- actionKill.setRadius(10);
- preRequisites = actionKill.getPreRequisite();
- }
- {
- ActionMove actionMove = new ActionMove(secretPoint);
- preRequisites.add(actionMove);
- preRequisites = actionMove.getPreRequisite();
- }
- {
- for (String str : preRequisite) {
- if (str.isEmpty()) continue;
- ActionChangeState actionChangeState = new ActionChangeState(str.split(":")[0], str.split(":")[1]);
- preRequisites.add(actionChangeState);
- }
- }
- return base;
- }
-
- @Override
- public void highlight(Color color, String name, DungeonRoom dungeonRoom, float partialTicks) {
- BlockPos pos = getSecretPoint().getBlockPos(dungeonRoom);
- RenderUtils.highlightBlock(pos, color,partialTicks);
- RenderUtils.drawTextAtWorld(getSecretType().name(), pos.getX() +0.5f, pos.getY()+0.75f, pos.getZ()+0.5f, 0xFFFFFFFF, 0.03f, false, true, partialTicks);
- RenderUtils.drawTextAtWorld(name, pos.getX() +0.5f, pos.getY()+0.375f, pos.getZ()+0.5f, 0xFFFFFFFF, 0.03f, false, true, partialTicks);
- RenderUtils.drawTextAtWorld(getCurrentState(dungeonRoom), pos.getX() +0.5f, pos.getY()+0f, pos.getZ()+0.5f, 0xFFFFFFFF, 0.03f, false, true, partialTicks);
- }
-
- public enum SecretType {
- BAT, CHEST, ITEM_DROP, ESSENCE
- }
-
- @AllArgsConstructor
- @Getter
- public enum SecretStatus {
- DEFINITELY_NOT("definitely_not"), NOT_SURE("not_sure"), CREATED("created"), FOUND("found"), ERROR("error");
-
- private final String stateName;
- }
-
- public DungeonSecret clone() throws CloneNotSupportedException {
- DungeonSecret dungeonSecret = new DungeonSecret();
- dungeonSecret.secretPoint = (OffsetPoint) secretPoint.clone();
- dungeonSecret.secretType = secretType;
- dungeonSecret.preRequisite = new ArrayList<String>(preRequisite);
- return dungeonSecret;
- }
-
-
- @Override
- public String getCurrentState(DungeonRoom dungeonRoom) {
- return getSecretStatus(dungeonRoom).getStateName();
- }
-
- @Override
- public Set<String> getPossibleStates(DungeonRoom dungeonRoom) {
- SecretStatus status = getSecretStatus(dungeonRoom);
- if (status == SecretStatus.FOUND) return Sets.newHashSet("navigate");
- else return Sets.newHashSet("found", "navigate");
- }
- @Override
- public Set<String> getTotalPossibleStates(DungeonRoom dungeonRoom) {
- return Sets.newHashSet("found"/*, "definitely_not", "not_sure", "created", "error"*/);
- }
- @Override
- public OffsetPoint getRepresentingPoint(DungeonRoom dungeonRoom) {
- return secretPoint;
- }
-}