v2.5.0: expanded the bestiary to include plants and traps
This commit is contained in:
@@ -5,6 +5,8 @@ journal.bestiary.rare.title=rare enemies
|
|||||||
journal.bestiary.quest.title=quest enemies & bosses
|
journal.bestiary.quest.title=quest enemies & bosses
|
||||||
journal.bestiary.neutral.title=neutral characters
|
journal.bestiary.neutral.title=neutral characters
|
||||||
journal.bestiary.ally.title=allies
|
journal.bestiary.ally.title=allies
|
||||||
|
journal.bestiary.trap.title=traps
|
||||||
|
journal.bestiary.plant.title=plants
|
||||||
|
|
||||||
journal.catalog.melee_weapons.title=melee weapons
|
journal.catalog.melee_weapons.title=melee weapons
|
||||||
journal.catalog.armor.title=armor
|
journal.catalog.armor.title=armor
|
||||||
|
|||||||
+1
-1
@@ -61,7 +61,7 @@ public abstract class AllyBuff extends Buff{
|
|||||||
Statistics.enemiesSlain++;
|
Statistics.enemiesSlain++;
|
||||||
Badges.validateMonstersSlain();
|
Badges.validateMonstersSlain();
|
||||||
Statistics.qualifiedForNoKilling = false;
|
Statistics.qualifiedForNoKilling = false;
|
||||||
Bestiary.trackKill(enemy.getClass());
|
Bestiary.trackEncounter(enemy.getClass());
|
||||||
|
|
||||||
AscensionChallenge.processEnemyKill(enemy);
|
AscensionChallenge.processEnemyKill(enemy);
|
||||||
|
|
||||||
|
|||||||
+2
@@ -27,6 +27,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.hero.Hero;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.items.quest.MetalShard;
|
import com.shatteredpixel.shatteredpixeldungeon.items.quest.MetalShard;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfMagicMapping;
|
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfMagicMapping;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfRecharging;
|
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfRecharging;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.Trap;
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.Trap;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.mechanics.Ballistica;
|
import com.shatteredpixel.shatteredpixeldungeon.mechanics.Ballistica;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||||
@@ -81,6 +82,7 @@ public class ReclaimTrap extends TargetedSpell {
|
|||||||
storedTrap = null;
|
storedTrap = null;
|
||||||
|
|
||||||
t.pos = bolt.collisionPos;
|
t.pos = bolt.collisionPos;
|
||||||
|
Bestiary.trackEncounter(t.getClass());
|
||||||
t.activate();
|
t.activate();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+119
-56
@@ -102,8 +102,53 @@ import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfLivingEarth;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfRegrowth;
|
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfRegrowth;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfWarding;
|
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfWarding;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.levels.rooms.special.SentryRoom;
|
import com.shatteredpixel.shatteredpixeldungeon.levels.rooms.special.SentryRoom;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.AlarmTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.BlazingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.BurningTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.ChillingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.ConfusionTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.CorrosionTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.CursingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.DisarmingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.DisintegrationTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.DistortionTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.ExplosiveTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.FlashingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.FlockTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.FrostTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GatewayTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GeyserTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GnollRockfallTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GrimTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GrippingTrap;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GuardianTrap;
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.GuardianTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.OozeTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.PitfallTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.PoisonDartTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.RockfallTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.ShockingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.StormTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.SummoningTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.TeleportationTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.TenguDartTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.ToxicTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.WarpingTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.WeakeningTrap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.WornDartTrap;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.BlandfruitBush;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Blindweed;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Earthroot;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Fadeleaf;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Firebloom;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Icecap;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Mageroyal;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Rotberry;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Sorrowmoss;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Starflower;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Stormvine;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Sungrass;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.plants.Swiftthistle;
|
||||||
import com.watabou.utils.Bundle;
|
import com.watabou.utils.Bundle;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -111,42 +156,44 @@ import java.util.Collection;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
|
||||||
|
//contains all the game's various entities, mostly enemies, NPCS, and allies, but also traps and plants
|
||||||
public enum Bestiary {
|
public enum Bestiary {
|
||||||
|
|
||||||
|
|
||||||
REGIONAL,
|
REGIONAL,
|
||||||
BOSSES,
|
BOSSES,
|
||||||
UNIVERSAL,
|
UNIVERSAL,
|
||||||
RARE,
|
RARE,
|
||||||
QUEST,
|
QUEST,
|
||||||
NEUTRAL,
|
NEUTRAL,
|
||||||
ALLY; //the journal tracks kills with allies, or quest completions, or shop purchases (eventually?)
|
ALLY,
|
||||||
|
TRAP,
|
||||||
|
PLANT;
|
||||||
|
|
||||||
//while this is all internally reported as kills, it's effectively 1 = seen for allies/NPCs
|
//tracks enemy kills, trap activations, plant tramples, or just sets to 1 for seen on allies
|
||||||
private LinkedHashMap<Class<?>, Integer> killCount = new LinkedHashMap<>();
|
private LinkedHashMap<Class<?>, Integer> encounterCount = new LinkedHashMap<>();
|
||||||
|
|
||||||
//should only be used when initializing
|
//should only be used when initializing
|
||||||
private void addMobs( Class<?>... mobs ){
|
private void addEntities(Class<?>... classes ){
|
||||||
for (Class<?> mob : mobs){
|
for (Class<?> cls : classes){
|
||||||
killCount.put(mob, 0);
|
encounterCount.put(cls, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Collection<Class<?>> mobs(){
|
public Collection<Class<?>> entities(){
|
||||||
return killCount.keySet();
|
return encounterCount.keySet();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String title(){
|
public String title(){
|
||||||
return Messages.get(this, name() + ".title");
|
return Messages.get(this, name() + ".title");
|
||||||
}
|
}
|
||||||
|
|
||||||
public int totalMobs(){
|
public int totalEntities(){
|
||||||
return killCount.size();
|
return encounterCount.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public int totalSeen(){
|
public int totalSeen(){
|
||||||
int seenTotal = 0;
|
int seenTotal = 0;
|
||||||
for (int count : killCount.values()){
|
for (int count : encounterCount.values()){
|
||||||
if (count > 0) seenTotal++;
|
if (count > 0) seenTotal++;
|
||||||
}
|
}
|
||||||
return seenTotal;
|
return seenTotal;
|
||||||
@@ -154,78 +201,95 @@ public enum Bestiary {
|
|||||||
|
|
||||||
static {
|
static {
|
||||||
|
|
||||||
REGIONAL.addMobs(Rat.class, Snake.class, Gnoll.class, Swarm.class, Crab.class, Slime.class,
|
REGIONAL.addEntities(Rat.class, Snake.class, Gnoll.class, Swarm.class, Crab.class, Slime.class,
|
||||||
Skeleton.class, Thief.class, DM100.class, Guard.class, Necromancer.class,
|
Skeleton.class, Thief.class, DM100.class, Guard.class, Necromancer.class,
|
||||||
Bat.class, Brute.class, Shaman.RedShaman.class, Shaman.BlueShaman.class, Shaman.PurpleShaman.class, Spinner.class, DM200.class,
|
Bat.class, Brute.class, Shaman.RedShaman.class, Shaman.BlueShaman.class, Shaman.PurpleShaman.class, Spinner.class, DM200.class,
|
||||||
Ghoul.class, Elemental.FireElemental.class, Elemental.FrostElemental.class, Elemental.ShockElemental.class, Warlock.class, Monk.class, Golem.class,
|
Ghoul.class, Elemental.FireElemental.class, Elemental.FrostElemental.class, Elemental.ShockElemental.class, Warlock.class, Monk.class, Golem.class,
|
||||||
RipperDemon.class, DemonSpawner.class, Succubus.class, Eye.class, Scorpio.class);
|
RipperDemon.class, DemonSpawner.class, Succubus.class, Eye.class, Scorpio.class);
|
||||||
|
|
||||||
BOSSES.addMobs(Goo.class,
|
BOSSES.addEntities(Goo.class,
|
||||||
Tengu.class,
|
Tengu.class,
|
||||||
Pylon.class, DM300.class,
|
Pylon.class, DM300.class,
|
||||||
DwarfKing.class,
|
DwarfKing.class,
|
||||||
YogDzewa.Larva.class, YogFist.BurningFist.class, YogFist.SoiledFist.class, YogFist.RottingFist.class, YogFist.RustedFist.class,YogFist.BrightFist.class, YogFist.DarkFist.class, YogDzewa.class);
|
YogDzewa.Larva.class, YogFist.BurningFist.class, YogFist.SoiledFist.class, YogFist.RottingFist.class, YogFist.RustedFist.class,YogFist.BrightFist.class, YogFist.DarkFist.class, YogDzewa.class);
|
||||||
|
|
||||||
UNIVERSAL.addMobs(Wraith.class, Piranha.class, Mimic.class, GoldenMimic.class, Statue.class, GuardianTrap.Guardian.class, SentryRoom.Sentry.class);
|
UNIVERSAL.addEntities(Wraith.class, Piranha.class, Mimic.class, GoldenMimic.class, Statue.class, GuardianTrap.Guardian.class, SentryRoom.Sentry.class);
|
||||||
|
|
||||||
RARE.addMobs(Albino.class, CausticSlime.class,
|
RARE.addEntities(Albino.class, CausticSlime.class,
|
||||||
Bandit.class, SpectralNecromancer.class,
|
Bandit.class, SpectralNecromancer.class,
|
||||||
ArmoredBrute.class, DM201.class,
|
ArmoredBrute.class, DM201.class,
|
||||||
Elemental.ChaosElemental.class, Senior.class,
|
Elemental.ChaosElemental.class, Senior.class,
|
||||||
Acidic.class,
|
Acidic.class,
|
||||||
TormentedSpirit.class, PhantomPiranha.class, CrystalMimic.class, EbonyMimic.class, ArmoredStatue.class);
|
TormentedSpirit.class, PhantomPiranha.class, CrystalMimic.class, EbonyMimic.class, ArmoredStatue.class);
|
||||||
|
|
||||||
QUEST.addMobs(FetidRat.class, GnollTrickster.class, GreatCrab.class,
|
QUEST.addEntities(FetidRat.class, GnollTrickster.class, GreatCrab.class,
|
||||||
Elemental.NewbornFireElemental.class, RotLasher.class, RotHeart.class,
|
Elemental.NewbornFireElemental.class, RotLasher.class, RotHeart.class,
|
||||||
CrystalWisp.class, CrystalGuardian.class, CrystalSpire.class, GnollGuard.class, GnollSapper.class, GnollGeomancer.class);
|
CrystalWisp.class, CrystalGuardian.class, CrystalSpire.class, GnollGuard.class, GnollSapper.class, GnollGeomancer.class);
|
||||||
|
|
||||||
NEUTRAL.addMobs(Ghost.class, Shopkeeper.class, Wandmaker.class, Blacksmith.class, Imp.class, Sheep.class, RatKing.class, Bee.class);
|
NEUTRAL.addEntities(Ghost.class, RatKing.class, Shopkeeper.class, Wandmaker.class, Blacksmith.class, Imp.class, Sheep.class, Bee.class);
|
||||||
|
|
||||||
ALLY.addMobs(MirrorImage.class, PrismaticImage.class,
|
ALLY.addEntities(MirrorImage.class, PrismaticImage.class,
|
||||||
DriedRose.GhostHero.class,
|
DriedRose.GhostHero.class,
|
||||||
WandOfWarding.Ward.class, WandOfLivingEarth.EarthGuardian.class, WandOfRegrowth.Lotus.class,
|
WandOfWarding.Ward.class, WandOfLivingEarth.EarthGuardian.class,
|
||||||
ShadowClone.ShadowAlly.class, SmokeBomb.NinjaLog.class, SpiritHawk.HawkAlly.class);
|
ShadowClone.ShadowAlly.class, SmokeBomb.NinjaLog.class, SpiritHawk.HawkAlly.class);
|
||||||
|
|
||||||
|
TRAP.addEntities(WornDartTrap.class, PoisonDartTrap.class, DisintegrationTrap.class, GatewayTrap.class,
|
||||||
|
ChillingTrap.class, BurningTrap.class, ShockingTrap.class, AlarmTrap.class, GrippingTrap.class, TeleportationTrap.class, OozeTrap.class,
|
||||||
|
FrostTrap.class, BlazingTrap.class, StormTrap.class, GuardianTrap.class, FlashingTrap.class, WarpingTrap.class,
|
||||||
|
ConfusionTrap.class, ToxicTrap.class, CorrosionTrap.class,
|
||||||
|
FlockTrap.class, SummoningTrap.class, WeakeningTrap.class, CursingTrap.class,
|
||||||
|
GeyserTrap.class, ExplosiveTrap.class, RockfallTrap.class, PitfallTrap.class,
|
||||||
|
DistortionTrap.class, DisarmingTrap.class, GrimTrap.class);
|
||||||
|
|
||||||
|
PLANT.addEntities(Rotberry.class, Sungrass.class, Fadeleaf.class, Icecap.class,
|
||||||
|
Firebloom.class, Sorrowmoss.class, Swiftthistle.class, Blindweed.class,
|
||||||
|
Stormvine.class, Earthroot.class, Mageroyal.class, Starflower.class,
|
||||||
|
BlandfruitBush.class,
|
||||||
|
WandOfRegrowth.Dewcatcher.class, WandOfRegrowth.Seedpod.class, WandOfRegrowth.Lotus.class);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int killCount(Class<?> mobClass) {
|
public static int encounterCount(Class<?> cls) {
|
||||||
for (Bestiary cat : values()) {
|
for (Bestiary cat : values()) {
|
||||||
if (cat.killCount.containsKey(mobClass)) {
|
if (cat.encounterCount.containsKey(cls)) {
|
||||||
return cat.killCount.get(mobClass);
|
return cat.encounterCount.get(cls);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isSeen(Class<?> mobClass){
|
public static boolean isSeen(Class<?> cls){
|
||||||
return killCount(mobClass) > 0;
|
return encounterCount(cls) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//some mobs have different internal classes when they are minions, so need to convert here
|
//some mobs and traps have different internal classes in some cases, so need to convert here
|
||||||
private static final HashMap<Class<?>, Class<?>> minionConversions = new HashMap<>();
|
private static final HashMap<Class<?>, Class<?>> classConversions = new HashMap<>();
|
||||||
static {
|
static {
|
||||||
minionConversions.put(CorpseDust.DustWraith.class, Wraith.class);
|
classConversions.put(CorpseDust.DustWraith.class, Wraith.class);
|
||||||
|
|
||||||
minionConversions.put(Necromancer.NecroSkeleton.class, Skeleton.class);
|
classConversions.put(Necromancer.NecroSkeleton.class, Skeleton.class);
|
||||||
|
|
||||||
minionConversions.put(DwarfKing.DKGhoul.class, Ghoul.class);
|
classConversions.put(TenguDartTrap.class, PoisonDartTrap.class);
|
||||||
minionConversions.put(DwarfKing.DKWarlock.class, Warlock.class);
|
classConversions.put(GnollRockfallTrap.class, RockfallTrap.class);
|
||||||
minionConversions.put(DwarfKing.DKMonk.class, Monk.class);
|
|
||||||
minionConversions.put(DwarfKing.DKGolem.class, Golem.class);
|
|
||||||
|
|
||||||
minionConversions.put(YogDzewa.YogRipper.class, RipperDemon.class);
|
classConversions.put(DwarfKing.DKGhoul.class, Ghoul.class);
|
||||||
minionConversions.put(YogDzewa.YogEye.class, Eye.class);
|
classConversions.put(DwarfKing.DKWarlock.class, Warlock.class);
|
||||||
minionConversions.put(YogDzewa.YogScorpio.class, Scorpio.class);
|
classConversions.put(DwarfKing.DKMonk.class, Monk.class);
|
||||||
|
classConversions.put(DwarfKing.DKGolem.class, Golem.class);
|
||||||
|
|
||||||
|
classConversions.put(YogDzewa.YogRipper.class, RipperDemon.class);
|
||||||
|
classConversions.put(YogDzewa.YogEye.class, Eye.class);
|
||||||
|
classConversions.put(YogDzewa.YogScorpio.class, Scorpio.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean setSeen(Class<?> mobClass){
|
public static boolean setSeen(Class<?> mobClass){
|
||||||
if (minionConversions.containsKey(mobClass)){
|
if (classConversions.containsKey(mobClass)){
|
||||||
mobClass = minionConversions.get(mobClass);
|
mobClass = classConversions.get(mobClass);
|
||||||
}
|
}
|
||||||
for (Bestiary cat : values()) {
|
for (Bestiary cat : values()) {
|
||||||
if (cat.killCount.containsKey(mobClass)) {
|
if (cat.encounterCount.containsKey(mobClass)) {
|
||||||
if (cat.killCount.get(mobClass) == 0){
|
if (cat.encounterCount.get(mobClass) == 0){
|
||||||
cat.killCount.put(mobClass, 1);
|
cat.encounterCount.put(mobClass, 1);
|
||||||
Journal.saveNeeded = true;
|
Journal.saveNeeded = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -233,14 +297,14 @@ public enum Bestiary {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void trackKill(Class<?> mobClass){
|
public static void trackEncounter(Class<?> mobClass){
|
||||||
if (minionConversions.containsKey(mobClass)){
|
if (classConversions.containsKey(mobClass)){
|
||||||
mobClass = minionConversions.get(mobClass);
|
mobClass = classConversions.get(mobClass);
|
||||||
}
|
}
|
||||||
for (Bestiary cat : values()) {
|
for (Bestiary cat : values()) {
|
||||||
if (cat.killCount.containsKey(mobClass)) {
|
if (cat.encounterCount.containsKey(mobClass)) {
|
||||||
if (cat.killCount.get(mobClass) != Integer.MAX_VALUE){
|
if (cat.encounterCount.get(mobClass) != Integer.MAX_VALUE){
|
||||||
cat.killCount.put(mobClass, cat.killCount.get(mobClass)+1);
|
cat.encounterCount.put(mobClass, cat.encounterCount.get(mobClass)+1);
|
||||||
Journal.saveNeeded = true;
|
Journal.saveNeeded = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -248,19 +312,18 @@ public enum Bestiary {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static final String BESTIARY_CLASSES = "bestiary_classes";
|
private static final String BESTIARY_CLASSES = "bestiary_classes";
|
||||||
private static final String BESTIARY_KILLS = "bestiary_kills";
|
private static final String BESTIARY_ENCOUNTERS = "bestiary_encounters";
|
||||||
|
|
||||||
public static void store( Bundle bundle ){
|
public static void store( Bundle bundle ){
|
||||||
Bundle bestiaryBundle = new Bundle();
|
|
||||||
|
|
||||||
ArrayList<Class<?>> classes = new ArrayList<>();
|
ArrayList<Class<?>> classes = new ArrayList<>();
|
||||||
ArrayList<Integer> kills = new ArrayList<>();
|
ArrayList<Integer> kills = new ArrayList<>();
|
||||||
|
|
||||||
for (Bestiary cat : values()) {
|
for (Bestiary cat : values()) {
|
||||||
for (Class<?> mob : cat.mobs()) {
|
for (Class<?> mob : cat.entities()) {
|
||||||
if (cat.killCount.get(mob) > 0){
|
if (cat.encounterCount.get(mob) > 0){
|
||||||
classes.add(mob);
|
classes.add(mob);
|
||||||
kills.add(cat.killCount.get(mob));
|
kills.add(cat.encounterCount.get(mob));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -271,7 +334,7 @@ public enum Bestiary {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bundle.put( BESTIARY_CLASSES, classes.toArray(new Class[0]) );
|
bundle.put( BESTIARY_CLASSES, classes.toArray(new Class[0]) );
|
||||||
bundle.put( BESTIARY_KILLS, killsToStore );
|
bundle.put( BESTIARY_ENCOUNTERS, killsToStore );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -279,12 +342,12 @@ public enum Bestiary {
|
|||||||
|
|
||||||
if (bundle.contains(BESTIARY_CLASSES)){
|
if (bundle.contains(BESTIARY_CLASSES)){
|
||||||
Class<?>[] classes = bundle.getClassArray(BESTIARY_CLASSES);
|
Class<?>[] classes = bundle.getClassArray(BESTIARY_CLASSES);
|
||||||
int[] kills = bundle.getIntArray(BESTIARY_KILLS);
|
int[] kills = bundle.getIntArray(BESTIARY_ENCOUNTERS);
|
||||||
|
|
||||||
for (int i = 0; i < classes.length; i++){
|
for (int i = 0; i < classes.length; i++){
|
||||||
for (Bestiary cat : values()){
|
for (Bestiary cat : values()){
|
||||||
if (cat.killCount.containsKey(classes[i])){
|
if (cat.encounterCount.containsKey(classes[i])){
|
||||||
cat.killCount.put(classes[i], kills[i]);
|
cat.encounterCount.put(classes[i], kills[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
+2
@@ -41,6 +41,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Statue;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Wraith;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Wraith;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.RatKing;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.RatKing;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfTeleportation;
|
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfTeleportation;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.watabou.utils.PathFinder;
|
import com.watabou.utils.PathFinder;
|
||||||
import com.watabou.utils.Random;
|
import com.watabou.utils.Random;
|
||||||
@@ -155,6 +156,7 @@ public class DistortionTrap extends Trap{
|
|||||||
if ((t = Dungeon.level.traps.get(mob.pos)) != null && t.active){
|
if ((t = Dungeon.level.traps.get(mob.pos)) != null && t.active){
|
||||||
if (t.disarmedByActivation) t.disarm();
|
if (t.disarmedByActivation) t.disarm();
|
||||||
t.reveal();
|
t.reveal();
|
||||||
|
Bestiary.trackEncounter(t.getClass());
|
||||||
t.activate();
|
t.activate();
|
||||||
}
|
}
|
||||||
ScrollOfTeleportation.appear(mob, mob.pos);
|
ScrollOfTeleportation.appear(mob, mob.pos);
|
||||||
|
|||||||
+2
@@ -27,6 +27,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.Actor;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.watabou.utils.BArray;
|
import com.watabou.utils.BArray;
|
||||||
import com.watabou.noosa.audio.Sample;
|
import com.watabou.noosa.audio.Sample;
|
||||||
@@ -66,6 +67,7 @@ public class FlockTrap extends Trap {
|
|||||||
if ((t = Dungeon.level.traps.get(i)) != null && t.active){
|
if ((t = Dungeon.level.traps.get(i)) != null && t.active){
|
||||||
if (t.disarmedByActivation) t.disarm();
|
if (t.disarmedByActivation) t.disarm();
|
||||||
t.reveal();
|
t.reveal();
|
||||||
|
Bestiary.trackEncounter(t.getClass());
|
||||||
t.activate();
|
t.activate();
|
||||||
}
|
}
|
||||||
Dungeon.level.occupyCell(sheep);
|
Dungeon.level.occupyCell(sheep);
|
||||||
|
|||||||
+2
@@ -26,6 +26,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.Actor;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.Char;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.Char;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Mob;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Mob;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfTeleportation;
|
import com.shatteredpixel.shatteredpixeldungeon.items.scrolls.ScrollOfTeleportation;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.watabou.utils.PathFinder;
|
import com.watabou.utils.PathFinder;
|
||||||
import com.watabou.utils.Random;
|
import com.watabou.utils.Random;
|
||||||
@@ -92,6 +93,7 @@ public class SummoningTrap extends Trap {
|
|||||||
if ((t = Dungeon.level.traps.get(mob.pos)) != null && t.active){
|
if ((t = Dungeon.level.traps.get(mob.pos)) != null && t.active){
|
||||||
if (t.disarmedByActivation) t.disarm();
|
if (t.disarmedByActivation) t.disarm();
|
||||||
t.reveal();
|
t.reveal();
|
||||||
|
Bestiary.trackEncounter(t.getClass());
|
||||||
t.activate();
|
t.activate();
|
||||||
}
|
}
|
||||||
ScrollOfTeleportation.appear(mob, mob.pos);
|
ScrollOfTeleportation.appear(mob, mob.pos);
|
||||||
|
|||||||
@@ -23,6 +23,7 @@ package com.shatteredpixel.shatteredpixeldungeon.levels.traps;
|
|||||||
|
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.Assets;
|
import com.shatteredpixel.shatteredpixeldungeon.Assets;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
|
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.watabou.noosa.audio.Sample;
|
import com.watabou.noosa.audio.Sample;
|
||||||
@@ -93,6 +94,7 @@ public abstract class Trap implements Bundlable {
|
|||||||
}
|
}
|
||||||
if (disarmedByActivation) disarm();
|
if (disarmedByActivation) disarm();
|
||||||
Dungeon.level.discover(pos);
|
Dungeon.level.discover(pos);
|
||||||
|
Bestiary.trackEncounter(getClass());
|
||||||
activate();
|
activate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,6 +34,7 @@ import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.particles.LeafParticle;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.particles.LeafParticle;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.Item;
|
import com.shatteredpixel.shatteredpixeldungeon.items.Item;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfRegrowth;
|
import com.shatteredpixel.shatteredpixeldungeon.items.wands.WandOfRegrowth;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.journal.Bestiary;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.levels.Level;
|
import com.shatteredpixel.shatteredpixeldungeon.levels.Level;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.levels.Terrain;
|
import com.shatteredpixel.shatteredpixeldungeon.levels.Terrain;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
import com.shatteredpixel.shatteredpixeldungeon.messages.Messages;
|
||||||
@@ -70,6 +71,7 @@ public abstract class Plant implements Bundlable {
|
|||||||
|
|
||||||
wither();
|
wither();
|
||||||
activate( ch );
|
activate( ch );
|
||||||
|
Bestiary.trackEncounter(getClass());
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract void activate( Char ch );
|
public abstract void activate( Char ch );
|
||||||
|
|||||||
Reference in New Issue
Block a user