1.7.10 commit of I-still-can't-do-any-branches

This commit is contained in:
WayofTime 2014-06-27 19:43:09 -04:00
parent 6aec0a87ea
commit cabc296b21
763 changed files with 64290 additions and 0 deletions

View file

@ -0,0 +1,86 @@
package WayofTime.alchemicalWizardry.common.summoning.meteor;
import java.util.ArrayList;
import java.util.List;
import net.minecraft.block.Block;
import net.minecraft.init.Blocks;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.world.World;
import WayofTime.alchemicalWizardry.AlchemicalWizardry;
public class MeteorParadigm
{
public List<MeteorParadigmComponent> componentList = new ArrayList();
public ItemStack focusStack;
public int radius;
public static int maxChance = 1000;
public MeteorParadigm(ItemStack focusStack, int radius)
{
this.focusStack = focusStack;
this.radius = radius;
}
public void parseStringArray(String[] oreArray)
{
for (int i = 0; i + 1 < oreArray.length; i += 2)
{
String oreName = oreArray[i];
int oreChance = Integer.parseInt(oreArray[i + 1]);
MeteorParadigmComponent mpc = new MeteorParadigmComponent(oreName, oreChance);
componentList.add(mpc);
}
}
public void createMeteorImpact(World world, int x, int y, int z)
{
world.createExplosion(null, x, y, z, radius * 4, AlchemicalWizardry.doMeteorsDestroyBlocks);
for (int i = -radius; i <= radius; i++)
{
for (int j = -radius; j <= radius; j++)
{
for (int k = -radius; k <= radius; k++)
{
if (i * i + j * j + k * k >= (radius + 0.50f) * (radius + 0.50f))
{
continue;
}
if (!world.isAirBlock(x + i, y + j, z + k))
{
continue;
}
int randNum = world.rand.nextInt(maxChance);
boolean hasPlacedBlock = false;
for (MeteorParadigmComponent mpc : componentList)
{
if (mpc == null || !mpc.isValidBlockParadigm())
{
continue;
}
randNum -= mpc.getChance();
if (randNum < 0)
{
ItemStack blockStack = mpc.getValidBlockParadigm();
world.setBlock(x + i, y + j, z + k, Block.getBlockById(Item.getIdFromItem(blockStack.getItem())), blockStack.getItemDamage(), 3);
hasPlacedBlock = true;
break;
}
}
if (!hasPlacedBlock)
{
world.setBlock(x + i, y + j, z + k, Blocks.stone, 0, 3);
}
}
}
}
}
}

View file

@ -0,0 +1,54 @@
package WayofTime.alchemicalWizardry.common.summoning.meteor;
import net.minecraft.item.ItemBlock;
import net.minecraft.item.ItemStack;
import net.minecraftforge.oredict.OreDictionary;
import java.util.List;
public class MeteorParadigmComponent
{
public String oreDictName;
public int chance;
public MeteorParadigmComponent(String dictName, int chance)
{
this.oreDictName = dictName;
this.chance = chance;
}
public boolean isValidBlockParadigm()
{
if (this.getValidBlockParadigm() != null)
{
return true;
}
return false;
}
public String getOreDictName()
{
return this.oreDictName;
}
public int getChance()
{
return this.chance;
}
public ItemStack getValidBlockParadigm()
{
List<ItemStack> list = OreDictionary.getOres(getOreDictName());
for (ItemStack stack : list)
{
if (stack != null && stack.getItem() instanceof ItemBlock)
{
return stack;
}
}
return null;
}
}

View file

@ -0,0 +1,61 @@
package WayofTime.alchemicalWizardry.common.summoning.meteor;
import net.minecraft.item.ItemStack;
import net.minecraft.world.World;
import net.minecraftforge.oredict.OreDictionary;
import java.util.ArrayList;
import java.util.List;
public class MeteorRegistry
{
public static List<MeteorParadigm> paradigmList = new ArrayList();
public static void registerMeteorParadigm(MeteorParadigm paradigm)
{
paradigmList.add(paradigm);
}
public static void registerMeteorParadigm(ItemStack stack, String[] oreList, int radius)
{
if (stack != null && oreList != null)
{
MeteorParadigm meteor = new MeteorParadigm(stack, radius);
meteor.parseStringArray(oreList);
paradigmList.add(meteor);
}
}
public static void createMeteorImpact(World world, int x, int y, int z, int paradigmID)
{
if (paradigmID < paradigmList.size())
{
paradigmList.get(paradigmID).createMeteorImpact(world, x, y, z);
}
}
public static int getParadigmIDForItem(ItemStack stack)
{
if (stack == null)
{
return -1;
}
for (int i = 0; i < paradigmList.size(); i++)
{
ItemStack focusStack = paradigmList.get(i).focusStack;
if (focusStack != null && focusStack.getItem()== stack.getItem() && (focusStack.getItemDamage() == OreDictionary.WILDCARD_VALUE || focusStack.getItemDamage() == stack.getItemDamage()))
{
return i;
}
}
return -1;
}
public static boolean isValidParadigmItem(ItemStack stack)
{
return getParadigmIDForItem(stack) != -1;
}
}