Committing the Ritual stuff
Incomplete. Ritual detection/rotation needs to be implemented. Currently hardcoded to a test ritual
This commit is contained in:
parent
9faae07131
commit
03847ad6d9
|
@ -207,6 +207,7 @@ public class ConfigHandler {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void checkRituals() {
|
public static void checkRituals() {
|
||||||
|
RitualHelper.checkRituals(config, "WayofTime.bloodmagic.ritual", "Rituals");
|
||||||
RitualHelper.checkImperfectRituals(config, "WayofTime.bloodmagic.ritual.imperfect", "Rituals.imperfect");
|
RitualHelper.checkImperfectRituals(config, "WayofTime.bloodmagic.ritual.imperfect", "Rituals.imperfect");
|
||||||
config.save();
|
config.save();
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,11 +10,11 @@ public interface IMasterRitualStone {
|
||||||
|
|
||||||
String getOwner();
|
String getOwner();
|
||||||
|
|
||||||
boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator);
|
boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator, Ritual ritual);
|
||||||
|
|
||||||
void performRitual(World world, BlockPos pos, Ritual ritual);
|
void performRitual(World world, BlockPos pos);
|
||||||
|
|
||||||
void stopRitual();
|
void stopRitual(Ritual.BreakType breakType);
|
||||||
|
|
||||||
int getCooldown();
|
int getCooldown();
|
||||||
|
|
||||||
|
|
|
@ -23,11 +23,11 @@ public abstract class Ritual {
|
||||||
this(name, crystalLevel, activationCost, null);
|
this(name, crystalLevel, activationCost, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract boolean startRitual(IMasterRitualStone masterRitualStone, EntityPlayer player);
|
public abstract boolean activateRitual(IMasterRitualStone masterRitualStone, EntityPlayer player);
|
||||||
|
|
||||||
public abstract void performEffect(IMasterRitualStone masterRitualStone);
|
public abstract void performRitual(IMasterRitualStone masterRitualStone);
|
||||||
|
|
||||||
public abstract void onRitualBroken(IMasterRitualStone masterRitualStone, Ritual.BreakType breakType);
|
public abstract void stopRitual(IMasterRitualStone masterRitualStone, Ritual.BreakType breakType);
|
||||||
|
|
||||||
public abstract int getRefreshCost();
|
public abstract int getRefreshCost();
|
||||||
|
|
||||||
|
|
|
@ -3,12 +3,21 @@ package WayofTime.bloodmagic.api.util.helper;
|
||||||
import WayofTime.bloodmagic.BloodMagic;
|
import WayofTime.bloodmagic.BloodMagic;
|
||||||
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
||||||
import WayofTime.bloodmagic.api.registry.RitualRegistry;
|
import WayofTime.bloodmagic.api.registry.RitualRegistry;
|
||||||
|
import WayofTime.bloodmagic.api.ritual.EnumRuneType;
|
||||||
import WayofTime.bloodmagic.api.ritual.Ritual;
|
import WayofTime.bloodmagic.api.ritual.Ritual;
|
||||||
|
import WayofTime.bloodmagic.api.ritual.RitualComponent;
|
||||||
import WayofTime.bloodmagic.api.ritual.imperfect.ImperfectRitual;
|
import WayofTime.bloodmagic.api.ritual.imperfect.ImperfectRitual;
|
||||||
|
import WayofTime.bloodmagic.block.BlockRitualStone;
|
||||||
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
import net.minecraft.util.BlockPos;
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.config.Configuration;
|
import net.minecraftforge.common.config.Configuration;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public class RitualHelper {
|
public class RitualHelper {
|
||||||
|
@ -31,6 +40,25 @@ public class RitualHelper {
|
||||||
return RitualRegistry.getIds().get(previousIndex);
|
return RitualRegistry.getIds().get(previousIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean checkValidRitual(World world, BlockPos pos, String ritualId, EnumFacing direction) {
|
||||||
|
ArrayList<RitualComponent> components = RitualRegistry.getRitualForId(ritualId).getComponents();
|
||||||
|
|
||||||
|
if (components == null)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for (RitualComponent component : components) {
|
||||||
|
IBlockState worldState = world.getBlockState(pos.add(component.getOffset()));
|
||||||
|
if (worldState.getBlock() instanceof BlockRitualStone) {
|
||||||
|
EnumRuneType worldType = EnumRuneType.values()[worldState.getBlock().getMetaFromState(worldState)];
|
||||||
|
|
||||||
|
if (component.getRuneType() != worldType)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public static void checkImperfectRituals(Configuration config, String packageName, String category) {
|
public static void checkImperfectRituals(Configuration config, String packageName, String category) {
|
||||||
checkRituals(config, packageName, category, ImperfectRitual.class, ImperfectRitualRegistry.enabledRituals);
|
checkRituals(config, packageName, category, ImperfectRitual.class, ImperfectRitualRegistry.enabledRituals);
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,15 +4,24 @@ import WayofTime.bloodmagic.BloodMagic;
|
||||||
import WayofTime.bloodmagic.api.BlockStack;
|
import WayofTime.bloodmagic.api.BlockStack;
|
||||||
import WayofTime.bloodmagic.api.Constants;
|
import WayofTime.bloodmagic.api.Constants;
|
||||||
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
||||||
|
import WayofTime.bloodmagic.api.registry.RitualRegistry;
|
||||||
|
import WayofTime.bloodmagic.api.ritual.Ritual;
|
||||||
|
import WayofTime.bloodmagic.api.ritual.RitualComponent;
|
||||||
|
import WayofTime.bloodmagic.api.util.helper.RitualHelper;
|
||||||
import WayofTime.bloodmagic.block.base.BlockStringContainer;
|
import WayofTime.bloodmagic.block.base.BlockStringContainer;
|
||||||
|
import WayofTime.bloodmagic.registry.ModBlocks;
|
||||||
|
import WayofTime.bloodmagic.registry.ModItems;
|
||||||
import WayofTime.bloodmagic.tile.TileImperfectRitualStone;
|
import WayofTime.bloodmagic.tile.TileImperfectRitualStone;
|
||||||
import WayofTime.bloodmagic.tile.TileMasterRitualStone;
|
import WayofTime.bloodmagic.tile.TileMasterRitualStone;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
|
import net.minecraft.block.state.BlockState;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.BlockPos;
|
import net.minecraft.util.BlockPos;
|
||||||
|
import net.minecraft.util.ChatComponentText;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.world.Explosion;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class BlockRitualController extends BlockStringContainer {
|
public class BlockRitualController extends BlockStringContainer {
|
||||||
|
@ -34,7 +43,25 @@ public class BlockRitualController extends BlockStringContainer {
|
||||||
public boolean onBlockActivated(World world, BlockPos pos, IBlockState state, EntityPlayer player, EnumFacing side, float hitX, float hitY, float hitZ) {
|
public boolean onBlockActivated(World world, BlockPos pos, IBlockState state, EntityPlayer player, EnumFacing side, float hitX, float hitY, float hitZ) {
|
||||||
TileEntity tile = world.getTileEntity(pos);
|
TileEntity tile = world.getTileEntity(pos);
|
||||||
|
|
||||||
if (getMetaFromState(state) == 1 && tile instanceof TileImperfectRitualStone) {
|
if (player.getHeldItem() == null && tile instanceof TileMasterRitualStone) {
|
||||||
|
Ritual send = ((TileMasterRitualStone) tile).getCurrentRitual();
|
||||||
|
if (send != null)
|
||||||
|
player.addChatComponentMessage(new ChatComponentText(send.getName()));
|
||||||
|
else {
|
||||||
|
Ritual place = RitualRegistry.getRitualForId("ritualTest");
|
||||||
|
for (RitualComponent ritualComponent : place.getComponents()) {
|
||||||
|
IBlockState toPlace = ModBlocks.ritualStone.getStateFromMeta(ritualComponent.getRuneType().ordinal());
|
||||||
|
world.setBlockState(pos.add(ritualComponent.getOffset()), toPlace);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (getMetaFromState(state) == 0 && tile instanceof TileMasterRitualStone) {
|
||||||
|
if (player.getHeldItem() != null && player.getHeldItem().getItem() == ModItems.activationCrystal) {
|
||||||
|
if (RitualHelper.checkValidRitual(world, pos, "ritualTest", null))
|
||||||
|
((TileMasterRitualStone) tile).activateRitual(player.getHeldItem(), player, RitualRegistry.getRitualForId("ritualTest"));
|
||||||
|
}
|
||||||
|
} else if (getMetaFromState(state) == 1 && tile instanceof TileImperfectRitualStone) {
|
||||||
|
|
||||||
IBlockState determinerState = world.getBlockState(pos.up());
|
IBlockState determinerState = world.getBlockState(pos.up());
|
||||||
BlockStack determiner = new BlockStack(determinerState.getBlock(), determinerState.getBlock().getMetaFromState(determinerState));
|
BlockStack determiner = new BlockStack(determinerState.getBlock(), determinerState.getBlock().getMetaFromState(determinerState));
|
||||||
|
@ -45,6 +72,23 @@ public class BlockRitualController extends BlockStringContainer {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBlockHarvested(World world, BlockPos pos, IBlockState state, EntityPlayer player) {
|
||||||
|
TileEntity tile = world.getTileEntity(pos);
|
||||||
|
|
||||||
|
if (getMetaFromState(state) == 0 && tile instanceof TileMasterRitualStone)
|
||||||
|
((TileMasterRitualStone) tile).stopRitual(Ritual.BreakType.BREAK_MRS);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBlockDestroyedByExplosion(World world, BlockPos pos, Explosion explosion) {
|
||||||
|
TileEntity tile = world.getTileEntity(pos);
|
||||||
|
IBlockState state = world.getBlockState(pos);
|
||||||
|
|
||||||
|
if (getMetaFromState(state) == 0 && tile instanceof TileMasterRitualStone)
|
||||||
|
((TileMasterRitualStone) tile).stopRitual(Ritual.BreakType.EXPLOSION);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TileEntity createNewTileEntity(World world, int meta) {
|
public TileEntity createNewTileEntity(World world, int meta) {
|
||||||
return meta == 0 ? new TileMasterRitualStone() : new TileImperfectRitualStone();
|
return meta == 0 ? new TileMasterRitualStone() : new TileImperfectRitualStone();
|
||||||
|
|
|
@ -43,22 +43,6 @@ public class ItemActivationCrystal extends ItemBindable {
|
||||||
tooltip.add(TextHelper.localize("tooltip.BloodMagic.activationCrystal." + names[stack.getItemDamage()]));
|
tooltip.add(TextHelper.localize("tooltip.BloodMagic.activationCrystal." + names[stack.getItemDamage()]));
|
||||||
|
|
||||||
super.addInformation(stack, player, tooltip, advanced);
|
super.addInformation(stack, player, tooltip, advanced);
|
||||||
|
|
||||||
// if (stack.getItemDamage() == 1) {
|
|
||||||
// if (Keyboard.isKeyDown(Keyboard.KEY_RSHIFT) || Keyboard.isKeyDown(Keyboard.KEY_LSHIFT)) {
|
|
||||||
// ItemStack[] recipe = AlchemyRecipeRegistry.getRecipeForItemStack(stack);
|
|
||||||
//
|
|
||||||
// if (recipe != null) {
|
|
||||||
// tooltip.add(TextHelper.getFormattedText(StatCollector.translateToLocal("tooltip.alchemy.recipe")));
|
|
||||||
//
|
|
||||||
// for (ItemStack item : recipe)
|
|
||||||
// if (item != null)
|
|
||||||
// tooltip.add(item.getDisplayName());
|
|
||||||
// }
|
|
||||||
// } else {
|
|
||||||
// tooltip.add(TextHelper.getFormattedText(StatCollector.translateToLocal("tooltip.alchemy.pressShift")));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getCrystalLevel(ItemStack stack) {
|
public int getCrystalLevel(ItemStack stack) {
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
package WayofTime.bloodmagic.registry;
|
package WayofTime.bloodmagic.registry;
|
||||||
|
|
||||||
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
import WayofTime.bloodmagic.api.registry.ImperfectRitualRegistry;
|
||||||
|
import WayofTime.bloodmagic.api.registry.RitualRegistry;
|
||||||
|
import WayofTime.bloodmagic.api.ritual.Ritual;
|
||||||
import WayofTime.bloodmagic.api.ritual.imperfect.ImperfectRitual;
|
import WayofTime.bloodmagic.api.ritual.imperfect.ImperfectRitual;
|
||||||
|
import WayofTime.bloodmagic.ritual.RitualTest;
|
||||||
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualNight;
|
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualNight;
|
||||||
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualRain;
|
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualRain;
|
||||||
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualResistance;
|
import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualResistance;
|
||||||
|
@ -9,13 +12,16 @@ import WayofTime.bloodmagic.ritual.imperfect.ImperfectRitualZombie;
|
||||||
|
|
||||||
public class ModRituals {
|
public class ModRituals {
|
||||||
|
|
||||||
|
public static Ritual testRitual;
|
||||||
|
|
||||||
public static ImperfectRitual imperfectNight;
|
public static ImperfectRitual imperfectNight;
|
||||||
public static ImperfectRitual imperfectRain;
|
public static ImperfectRitual imperfectRain;
|
||||||
public static ImperfectRitual imperfectResistance;
|
public static ImperfectRitual imperfectResistance;
|
||||||
public static ImperfectRitual imperfectZombie;
|
public static ImperfectRitual imperfectZombie;
|
||||||
|
|
||||||
public static void initRituals() {
|
public static void initRituals() {
|
||||||
|
testRitual = new RitualTest();
|
||||||
|
RitualRegistry.registerRitual(testRitual, testRitual.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void initImperfectRituals() {
|
public static void initImperfectRituals() {
|
||||||
|
|
55
src/main/java/WayofTime/bloodmagic/ritual/RitualTest.java
Normal file
55
src/main/java/WayofTime/bloodmagic/ritual/RitualTest.java
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
package WayofTime.bloodmagic.ritual;
|
||||||
|
|
||||||
|
import WayofTime.bloodmagic.api.ritual.*;
|
||||||
|
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.util.BlockPos;
|
||||||
|
import net.minecraft.util.ChatComponentText;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
public class RitualTest extends Ritual {
|
||||||
|
|
||||||
|
public RitualTest() {
|
||||||
|
super("ritualTest", 0, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean activateRitual(IMasterRitualStone masterRitualStone, EntityPlayer player) {
|
||||||
|
player.addChatComponentMessage(new ChatComponentText("ritual started"));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void performRitual(IMasterRitualStone masterRitualStone) {
|
||||||
|
EntityPlayer player = PlayerHelper.getPlayerFromUsername(masterRitualStone.getOwner());
|
||||||
|
|
||||||
|
if (player != null)
|
||||||
|
player.addChatComponentMessage(new ChatComponentText("effect performed"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stopRitual(IMasterRitualStone masterRitualStone, BreakType breakType) {
|
||||||
|
EntityPlayer player = PlayerHelper.getPlayerFromUsername(masterRitualStone.getOwner());
|
||||||
|
|
||||||
|
if (player != null)
|
||||||
|
player.addChatComponentMessage(new ChatComponentText("ritual stopped - " + breakType.name()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getRefreshCost() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ArrayList<RitualComponent> getComponents() {
|
||||||
|
ArrayList<RitualComponent> components = new ArrayList<RitualComponent>();
|
||||||
|
|
||||||
|
components.add(new RitualComponent(new BlockPos(1, 0, 1), EnumRuneType.AIR));
|
||||||
|
components.add(new RitualComponent(new BlockPos(-1, 0, 1), EnumRuneType.EARTH));
|
||||||
|
components.add(new RitualComponent(new BlockPos(1, 0, -1), EnumRuneType.WATER));
|
||||||
|
components.add(new RitualComponent(new BlockPos(-1, 0, -1), EnumRuneType.FIRE));
|
||||||
|
|
||||||
|
return components;
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,12 +8,14 @@ import WayofTime.bloodmagic.api.ritual.IMasterRitualStone;
|
||||||
import WayofTime.bloodmagic.api.ritual.Ritual;
|
import WayofTime.bloodmagic.api.ritual.Ritual;
|
||||||
import WayofTime.bloodmagic.api.util.helper.NBTHelper;
|
import WayofTime.bloodmagic.api.util.helper.NBTHelper;
|
||||||
import WayofTime.bloodmagic.api.util.helper.NetworkHelper;
|
import WayofTime.bloodmagic.api.util.helper.NetworkHelper;
|
||||||
|
import WayofTime.bloodmagic.api.util.helper.PlayerHelper;
|
||||||
import WayofTime.bloodmagic.api.util.helper.RitualHelper;
|
import WayofTime.bloodmagic.api.util.helper.RitualHelper;
|
||||||
import WayofTime.bloodmagic.item.ItemActivationCrystal;
|
import WayofTime.bloodmagic.item.ItemActivationCrystal;
|
||||||
import WayofTime.bloodmagic.util.ChatUtil;
|
import WayofTime.bloodmagic.util.ChatUtil;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.Setter;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
@ -29,49 +31,83 @@ import net.minecraftforge.fml.common.eventhandler.Event;
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
public class TileMasterRitualStone extends TileEntity implements IMasterRitualStone, ITickable {
|
public class TileMasterRitualStone extends TileEntity implements IMasterRitualStone, ITickable {
|
||||||
|
|
||||||
public static final int REFRESH_TIME = 0;
|
public static final int REFRESH_TIME = 20;
|
||||||
|
|
||||||
private String owner;
|
private String owner;
|
||||||
private boolean active;
|
private boolean active;
|
||||||
private int activeTime;
|
private int activeTime;
|
||||||
private int cooldown;
|
private int cooldown;
|
||||||
private Ritual currentRitual;
|
private Ritual currentRitual;
|
||||||
|
@Setter
|
||||||
private EnumFacing direction;
|
private EnumFacing direction;
|
||||||
|
|
||||||
public void readClientNBT(NBTTagCompound tag) {
|
@Override
|
||||||
|
public void update() {
|
||||||
|
if (getCurrentRitual() != null && isActive()) {
|
||||||
|
if (activeTime % REFRESH_TIME == 0)
|
||||||
|
performRitual(getWorld(), getPos());
|
||||||
|
|
||||||
|
activeTime++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void readFromNBT(NBTTagCompound tag) {
|
||||||
|
owner = tag.getString(Constants.NBT.OWNER_NAME);
|
||||||
currentRitual = RitualRegistry.getRitualForId(tag.getString(Constants.NBT.CURRENT_RITUAL));
|
currentRitual = RitualRegistry.getRitualForId(tag.getString(Constants.NBT.CURRENT_RITUAL));
|
||||||
active = tag.getBoolean(Constants.NBT.IS_RUNNING);
|
active = tag.getBoolean(Constants.NBT.IS_RUNNING);
|
||||||
activeTime = tag.getInteger(Constants.NBT.RUNTIME);
|
activeTime = tag.getInteger(Constants.NBT.RUNTIME);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeClientNBT(NBTTagCompound tag) {
|
@Override
|
||||||
tag.setString(Constants.NBT.CURRENT_RITUAL, RitualRegistry.getIdForRitual(currentRitual));
|
public void writeToNBT(NBTTagCompound tag) {
|
||||||
tag.setBoolean(Constants.NBT.IS_RUNNING, active);
|
String ritualId = RitualRegistry.getIdForRitual(getCurrentRitual());
|
||||||
tag.setInteger(Constants.NBT.RUNTIME, activeTime);
|
tag.setString(Constants.NBT.OWNER_NAME, Strings.isNullOrEmpty(getOwner()) ? "" : getOwner());
|
||||||
|
tag.setString(Constants.NBT.CURRENT_RITUAL, Strings.isNullOrEmpty(ritualId) ? "" : ritualId);
|
||||||
|
tag.setBoolean(Constants.NBT.IS_RUNNING, isActive());
|
||||||
|
tag.setInteger(Constants.NBT.RUNTIME, getActiveTime());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void update() {
|
public boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator, Ritual ritual) {
|
||||||
|
|
||||||
}
|
if (PlayerHelper.isFakePlayer(activator))
|
||||||
|
return false;
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean activateRitual(ItemStack activationCrystal, EntityPlayer activator) {
|
|
||||||
activationCrystal = NBTHelper.checkNBT(activationCrystal);
|
activationCrystal = NBTHelper.checkNBT(activationCrystal);
|
||||||
String crystalOwner = activationCrystal.getTagCompound().getString(Constants.NBT.OWNER_NAME);
|
String crystalOwner = activationCrystal.getTagCompound().getString(Constants.NBT.OWNER_NAME);
|
||||||
Ritual ritual = RitualRegistry.getRitualForId("");
|
|
||||||
|
|
||||||
if (!Strings.isNullOrEmpty(crystalOwner) && ritual != null) {
|
if (!Strings.isNullOrEmpty(crystalOwner) && ritual != null) {
|
||||||
if (activationCrystal.getItem() instanceof ItemActivationCrystal) {
|
if (activationCrystal.getItem() instanceof ItemActivationCrystal) {
|
||||||
int crystalLevel = ((ItemActivationCrystal) activationCrystal.getItem()).getCrystalLevel(activationCrystal);
|
int crystalLevel = ((ItemActivationCrystal) activationCrystal.getItem()).getCrystalLevel(activationCrystal);
|
||||||
if (RitualHelper.canCrystalActivate(ritual, crystalLevel)) {
|
if (RitualHelper.canCrystalActivate(ritual, crystalLevel)) {
|
||||||
|
|
||||||
|
SoulNetwork network = NetworkHelper.getSoulNetwork(activator.getDisplayNameString(), getWorld());
|
||||||
|
|
||||||
|
if (network.getCurrentEssence() < ritual.getActivationCost()) {
|
||||||
|
ChatUtil.sendNoSpamUnloc(activator, "chat.BloodMagic.ritual.weak");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentRitual != null)
|
||||||
|
currentRitual.stopRitual(this, Ritual.BreakType.ACTIVATE);
|
||||||
|
|
||||||
RitualEvent.RitualActivatedEvent event = new RitualEvent.RitualActivatedEvent(this, crystalOwner, ritual, activator, activationCrystal, crystalLevel);
|
RitualEvent.RitualActivatedEvent event = new RitualEvent.RitualActivatedEvent(this, crystalOwner, ritual, activator, activationCrystal, crystalLevel);
|
||||||
|
|
||||||
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY) {
|
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY) {
|
||||||
ChatUtil.sendNoSpamUnloc(activator, "chat.BloodMagic.ritual.prevent");
|
ChatUtil.sendNoSpamUnloc(activator, "chat.BloodMagic.ritual.prevent");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ritual.activateRitual(this, activator)) {
|
||||||
|
network.syphon(ritual.getActivationCost());
|
||||||
|
|
||||||
|
this.active = true;
|
||||||
|
this.owner = activator.getDisplayNameString();
|
||||||
|
this.currentRitual = ritual;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,17 +116,32 @@ public class TileMasterRitualStone extends TileEntity implements IMasterRitualSt
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void performRitual(World world, BlockPos pos, Ritual ritual) {
|
public void performRitual(World world, BlockPos pos) {
|
||||||
if (ritual != null && RitualRegistry.ritualEnabled(ritual)) {
|
if (getCurrentRitual() != null && RitualRegistry.ritualEnabled(getCurrentRitual()) && RitualHelper.checkValidRitual(getWorld(), getPos(), RitualRegistry.getIdForRitual(currentRitual), null)) {
|
||||||
|
RitualEvent.RitualRunEvent event = new RitualEvent.RitualRunEvent(this, getOwner(), getCurrentRitual());
|
||||||
|
|
||||||
|
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY)
|
||||||
|
return;
|
||||||
|
|
||||||
SoulNetwork network = NetworkHelper.getSoulNetwork(getOwner(), getWorld());
|
SoulNetwork network = NetworkHelper.getSoulNetwork(getOwner(), getWorld());
|
||||||
network.syphonAndDamage(ritual.getRefreshCost());
|
network.syphonAndDamage(getCurrentRitual().getRefreshCost());
|
||||||
ritual.performEffect(this);
|
getCurrentRitual().performRitual(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void stopRitual() {
|
public void stopRitual(Ritual.BreakType breakType) {
|
||||||
|
if (getCurrentRitual() != null) {
|
||||||
|
RitualEvent.RitualStopEvent event = new RitualEvent.RitualStopEvent(this, getOwner(), getCurrentRitual(), breakType);
|
||||||
|
|
||||||
|
if (MinecraftForge.EVENT_BUS.post(event) || event.getResult() == Event.Result.DENY)
|
||||||
|
return;
|
||||||
|
|
||||||
|
getCurrentRitual().stopRitual(this, breakType);
|
||||||
|
this.currentRitual = null;
|
||||||
|
this.active = false;
|
||||||
|
this.activeTime = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in a new issue