From 941173dbf4bb27549cf570bcbdb9f8c95a8185f3 Mon Sep 17 00:00:00 2001 From: WayofTime Date: Tue, 27 Feb 2018 17:25:41 -0500 Subject: [PATCH] Added book entry for the Burning Furnace array. --- .../AlchemyArrayEffectFurnaceFuel.java | 2 +- .../compat/guideapi/book/CategoryAlchemy.java | 43 ++++++++++++++----- .../assets/bloodmagicguide/lang/en_US.lang | 2 + 3 files changed, 35 insertions(+), 12 deletions(-) diff --git a/src/main/java/WayofTime/bloodmagic/alchemyArray/AlchemyArrayEffectFurnaceFuel.java b/src/main/java/WayofTime/bloodmagic/alchemyArray/AlchemyArrayEffectFurnaceFuel.java index 29706cef..145b6143 100644 --- a/src/main/java/WayofTime/bloodmagic/alchemyArray/AlchemyArrayEffectFurnaceFuel.java +++ b/src/main/java/WayofTime/bloodmagic/alchemyArray/AlchemyArrayEffectFurnaceFuel.java @@ -20,7 +20,7 @@ import WayofTime.bloodmagic.util.PleaseStopUsingMe; public class AlchemyArrayEffectFurnaceFuel extends AlchemyArrayEffect { static double radius = 10; - static int burnTicksAdded = 201; //Set to +1 more than it needs to be due to a hacky method - basically done so that the array doesn't double dip your health if you only add one item. + static int burnTicksAdded = 401; //Set to +1 more than it needs to be due to a hacky method - basically done so that the array doesn't double dip your health if you only add one item. public AlchemyArrayEffectFurnaceFuel(String key) { diff --git a/src/main/java/WayofTime/bloodmagic/compat/guideapi/book/CategoryAlchemy.java b/src/main/java/WayofTime/bloodmagic/compat/guideapi/book/CategoryAlchemy.java index fcde6142..9eb03a5b 100644 --- a/src/main/java/WayofTime/bloodmagic/compat/guideapi/book/CategoryAlchemy.java +++ b/src/main/java/WayofTime/bloodmagic/compat/guideapi/book/CategoryAlchemy.java @@ -22,8 +22,10 @@ import java.util.List; import java.util.Map; import java.util.Map.Entry; -public class CategoryAlchemy { - public static Map buildCategory() { +public class CategoryAlchemy +{ + public static Map buildCategory() + { Map entries = new LinkedHashMap(); String keyBase = "guide." + BloodMagic.MODID + ".entry.alchemy."; @@ -34,16 +36,28 @@ public class CategoryAlchemy { List ashPages = new ArrayList(); TartaricForgeRecipe ashRecipe = RecipeHelper.getForgeRecipeForOutput(new ItemStack(RegistrarBloodMagicItems.ARCANE_ASHES)); - if (ashRecipe != null) { + if (ashRecipe != null) + { ashPages.add(new PageTartaricForgeRecipe(ashRecipe)); } ashPages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "ash" + ".info"), 370)); entries.put(new ResourceLocation(keyBase + "ash"), new EntryText(ashPages, TextHelper.localize(keyBase + "ash"), true)); + List furnacePages = new ArrayList(); + + PageAlchemyArray furnaceRecipePage = BookUtils.getAlchemyPage("furnace"); + if (furnaceRecipePage != null) + { + furnacePages.add(furnaceRecipePage); + } + furnacePages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "furnace" + ".info"), 370)); + entries.put(new ResourceLocation(keyBase + "furnace"), new EntryText(furnacePages, TextHelper.localize(keyBase + "furnace"), true)); + List speedPages = new ArrayList(); PageAlchemyArray speedRecipePage = BookUtils.getAlchemyPage("movement"); - if (speedRecipePage != null) { + if (speedRecipePage != null) + { speedPages.add(speedRecipePage); } speedPages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "speed" + ".info"), 370)); @@ -52,7 +66,8 @@ public class CategoryAlchemy { List updraftPages = new ArrayList(); PageAlchemyArray updraftRecipePage = BookUtils.getAlchemyPage("updraft"); - if (updraftRecipePage != null) { + if (updraftRecipePage != null) + { updraftPages.add(updraftRecipePage); } updraftPages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "updraft" + ".info"), 370)); @@ -61,7 +76,8 @@ public class CategoryAlchemy { List turretPages = new ArrayList(); PageAlchemyArray turretRecipePage = BookUtils.getAlchemyPage("skeletonTurret"); - if (turretRecipePage != null) { + if (turretRecipePage != null) + { turretPages.add(turretRecipePage); } turretPages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "turret" + ".info"), 370)); @@ -70,7 +86,8 @@ public class CategoryAlchemy { List bouncePages = new ArrayList(); PageAlchemyArray bounceRecipePage = BookUtils.getAlchemyPage("bounce"); - if (bounceRecipePage != null) { + if (bounceRecipePage != null) + { bouncePages.add(bounceRecipePage); } bouncePages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "bounce" + ".info"), 370)); @@ -84,15 +101,19 @@ public class CategoryAlchemy { List fastMinerPages = new ArrayList(); PageAlchemyArray fastMinerRecipePage = BookUtils.getAlchemyPage("fastMiner"); - if (fastMinerRecipePage != null) { + if (fastMinerRecipePage != null) + { fastMinerPages.add(fastMinerRecipePage); } fastMinerPages.addAll(PageHelper.pagesForLongText(TextHelper.localize(keyBase + "fastMiner" + ".info"), 370)); entries.put(new ResourceLocation(keyBase + "fastMiner"), new EntryText(fastMinerPages, TextHelper.localize(keyBase + "fastMiner"), true)); - for (Entry entry : entries.entrySet()) { - for (IPage page : entry.getValue().pageList) { - if (page instanceof PageText) { + for (Entry entry : entries.entrySet()) + { + for (IPage page : entry.getValue().pageList) + { + if (page instanceof PageText) + { ((PageText) page).setUnicodeFlag(true); } } diff --git a/src/main/resources/assets/bloodmagicguide/lang/en_US.lang b/src/main/resources/assets/bloodmagicguide/lang/en_US.lang index 75787652..1ba63f89 100644 --- a/src/main/resources/assets/bloodmagicguide/lang/en_US.lang +++ b/src/main/resources/assets/bloodmagicguide/lang/en_US.lang @@ -243,6 +243,7 @@ guide.bloodmagic.entry.alchemy.bounce=Bouncing Array guide.bloodmagic.entry.alchemy.turret=Skeleton Turret Array guide.bloodmagic.entry.alchemy.buff=Buff Arrays guide.bloodmagic.entry.alchemy.fastMiner=Fast Miner Array +guide.bloodmagic.entry.alchemy.furnace=Burning Furnace Array @@ -256,3 +257,4 @@ guide.bloodmagic.entry.alchemy.bounce.info=By using a source of heat near its ce guide.bloodmagic.entry.alchemy.turret.info=By utilizing the Demon Will that is still controlling a mob, you can take over the mind of a skeleton in order to make it do your bidding. If a skeleton finds itself inside of the area of this array, it will act as a sentry and attack hostile monsters nearby. Unfortunately this array is still highly experimental, so it may not work very well or consistently. guide.bloodmagic.entry.alchemy.buff.info=Through rigorous study, you realize that alchemical arrays have a wide range of applications. So far, you have managed to create powerful items through crafting arrays, as well as a couple of arrays that provide functional benefits such as rapid movement and weak forms of teleportation. However, one of the uses that you have yet to tap into is providing powerful buffs through an active array.\n\t"Buff Arrays" are the general term for alchemy arrays that provide some buff to players within its area of effect. These areas of effect tends to have a very large radius which cannot be manipulated (unlike Rituals). However, because alchemy arrays have no concept of a Soul Network, they have to power their effects through other means: mainly through direct blood offerings. In simplified terms, this means that whenever the array will apply a buff, it will damage (take HP) from the player that it is cast on. \n\tBecause of the direct nature of these sacrifices, the HP -> buff conversion is a lot more favourable for players in the early game compared to similar buffs in the mod. For instance, if a buff from a sigil cost 100 LP for 10 seconds of activation, a more powerful buff can be applied by the array for 30 seconds for 1 HP (which is 100 LP in a T1 altar with no runes). This can be seen as a lot more efficient in the early tiers, while during the later tiers it is not as efficient of an effect. However, because of the stationary nature of the arrays, they will tend to provide a stronger effect than their sigil counter parts, so people may wish to still use it in the late-game. guide.bloodmagic.entry.alchemy.fastMiner.info=When tasked with carving out a large area of land, sometimes it is best to just do it by hand. For those occasions, this array is for you. The array applies a Haste III buff to players within a 10 block radius, costing the user 1 HP per 30 seconds. Because it is a general Haste buff, it will also increase your attack speed while in its area of effect, though you will have to be careful since other players will benefit from this too! +guide.bloodmagic.entry.alchemy.furnace.info=One of the many problems that you may encounter in the beginning of your adventure is the inability to keep your furnace lit. A lit furnace can mean the difference between having a full stomach and strong weapons or starving in a cave. \n\tThe Burning Furnace array, as the name implies, will provide a much needed heat source for any nearby furnace. By placing the array directly adjacent to a vanilla furnace (it can be next to multiple), it will provide fuel to the furnace if an operation is able to be completed - nothing will happen if it is next to an empty or a full furnace, mainly for your protection. \n\tThis does not come for free, however: when a person is nearby (within a 10 block radius), it will take away half a heart of health in order to cook up to two things in the furnace. This will be helpful to either get a quick bite or to smelt a full stack of ore, but unfortunately you haven't found a way to add any safety measures to the array...