aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics
diff options
context:
space:
mode:
authorsyeyoung <cyong06@naver.com>2021-04-17 21:19:44 +0900
committersyeyoung <cyong06@naver.com>2021-04-17 21:19:44 +0900
commitfbcfc4a5f43a93db3afd0bc0a6b308c653e21a32 (patch)
tree648a78a90c484338aebcef98bd749d976c36625a /src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics
parent6113dd0a33fbf230044588020ef1b09ba397c96a (diff)
downloadSkyblock-Dungeons-Guide-fbcfc4a5f43a93db3afd0bc0a6b308c653e21a32.tar.gz
Skyblock-Dungeons-Guide-fbcfc4a5f43a93db3afd0bc0a6b308c653e21a32.tar.bz2
Skyblock-Dungeons-Guide-fbcfc4a5f43a93db3afd0bc0a6b308c653e21a32.zip
saving events, better secret detection (itemdrop)
Diffstat (limited to 'src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics')
-rwxr-xr-xsrc/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java36
1 files changed, 36 insertions, 0 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
index a88d0333..b7a3eee9 100755
--- a/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java
+++ b/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java
@@ -30,10 +30,46 @@ public class DungeonSecret implements DungeonMechanic {
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(), true);
+ }
+ }
+ } 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.toString(), 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 SecretStatus.FOUND;
+
if (blockState.getBlock() == Blocks.air) {
return SecretStatus.DEFINITELY_NOT;
} else if (blockState.getBlock() != Blocks.chest && blockState.getBlock() != Blocks.trapped_chest) {