diff options
Diffstat (limited to 'src/main/java/kr/syeyoung/dungeonsguide/dungeon')
| -rwxr-xr-x | src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonJournal.java | 81 | ||||
| -rwxr-xr-x | src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java | 4 | 
2 files changed, 83 insertions, 2 deletions
| diff --git a/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonJournal.java b/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonJournal.java new file mode 100755 index 00000000..3993d0d7 --- /dev/null +++ b/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonJournal.java @@ -0,0 +1,81 @@ +package kr.syeyoung.dungeonsguide.dungeon.mechanics; + +import com.google.common.collect.Sets; +import kr.syeyoung.dungeonsguide.dungeon.actions.Action; +import kr.syeyoung.dungeonsguide.dungeon.actions.ActionChangeState; +import kr.syeyoung.dungeonsguide.dungeon.actions.ActionInteract; +import kr.syeyoung.dungeonsguide.dungeon.actions.ActionMove; +import kr.syeyoung.dungeonsguide.dungeon.data.OffsetPoint; +import kr.syeyoung.dungeonsguide.dungeon.mechanics.predicates.PredicateArmorStand; +import kr.syeyoung.dungeonsguide.dungeon.roomfinder.DungeonRoom; +import kr.syeyoung.dungeonsguide.utils.RenderUtils; +import lombok.Data; +import net.minecraft.util.BlockPos; + +import java.awt.*; +import java.util.ArrayList; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +@Data +public class DungeonJournal implements DungeonMechanic { +    private OffsetPoint secretPoint = new OffsetPoint(0,0,0); +    private List<String> preRequisite = new ArrayList<String>(); + + +    @Override +    public Set<Action> getAction(String state, DungeonRoom dungeonRoom) { +        if (!"navigate".equalsIgnoreCase(state)) throw new IllegalArgumentException(state+" is not valid state for secret"); +        Set<Action> base; +        Set<Action> preRequisites = base = new HashSet<Action>(); +        { +            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("J-"+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 DungeonJournal clone() throws CloneNotSupportedException { +        DungeonJournal dungeonSecret = new DungeonJournal(); +        dungeonSecret.secretPoint = (OffsetPoint) secretPoint.clone(); +        dungeonSecret.preRequisite = new ArrayList<String>(preRequisite); +        return dungeonSecret; +    } + + +    @Override +    public String getCurrentState(DungeonRoom dungeonRoom) { +        return "no-state"; +    } + +    @Override +    public Set<String> getPossibleStates(DungeonRoom dungeonRoom) { +        return Sets.newHashSet("navigate"); +    } +    @Override +    public Set<String> getTotalPossibleStates(DungeonRoom dungeonRoom) { +        return Sets.newHashSet("no-state","navigate"); +    } +    @Override +    public OffsetPoint getRepresentingPoint() { +        return secretPoint; +    } +} 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 958cd286..182e0201 100755 --- a/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java +++ b/src/main/java/kr/syeyoung/dungeonsguide/dungeon/mechanics/DungeonSecret.java @@ -63,7 +63,7 @@ public class DungeonSecret implements DungeonMechanic {          if (!"found".equalsIgnoreCase(state)) throw new IllegalArgumentException(state+" is not valid state for secret");          Set<Action> base;          Set<Action> preRequisites = base = new HashSet<Action>(); -        if (secretType == SecretType.CHEST) { +        if (secretType == SecretType.CHEST || secretType == SecretType.ESSENCE) {              ActionClick actionClick;              preRequisites.add(actionClick = new ActionClick(secretPoint));              preRequisites = actionClick.getPreRequisite(); @@ -99,7 +99,7 @@ public class DungeonSecret implements DungeonMechanic {      }      public static enum SecretType { -        BAT, CHEST, ITEM_DROP +        BAT, CHEST, ITEM_DROP, ESSENCE      }      @AllArgsConstructor | 
