From 70c1354a4a96698758a88c032866288f79de6f5a Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Sat, 24 Aug 2024 08:16:37 -0400 Subject: Initial commit --- .../java/jp/plusplus/fbs/magic/MagicHarvest.java | 92 ++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 src/main/java/jp/plusplus/fbs/magic/MagicHarvest.java (limited to 'src/main/java/jp/plusplus/fbs/magic/MagicHarvest.java') diff --git a/src/main/java/jp/plusplus/fbs/magic/MagicHarvest.java b/src/main/java/jp/plusplus/fbs/magic/MagicHarvest.java new file mode 100644 index 0000000..1998aa8 --- /dev/null +++ b/src/main/java/jp/plusplus/fbs/magic/MagicHarvest.java @@ -0,0 +1,92 @@ +package jp.plusplus.fbs.magic; + +import jp.plusplus.fbs.Registry; +import jp.plusplus.fbs.api.MagicBase; +import net.minecraft.enchantment.EnchantmentHelper; +import net.minecraft.entity.item.EntityItem; +import net.minecraft.item.ItemStack; +import net.minecraft.util.ChatComponentText; +import net.minecraft.util.MathHelper; + +import java.util.ArrayList; + +/** + * Created by plusplus_F on 2015/09/27. + */ +public class MagicHarvest extends MagicBase { + @Override + public boolean checkSuccess() { + if(!isSpelled || usingStaff) return false; + float r=0.15f+0.03f*Math.max(getLvDiff(), 0); + return rand.nextFloat() list=Registry.GetChestContents(1); + int valueSum=0; + for(Registry.ChestContent cc : list) valueSum+=cc.weight; + + //アイテムスタックのスタックサイズと数 + int min=1+ld/2; + int max=3+ld; + int amount=6+ld/2+rand.nextInt(ld+5); + + for(int i=0;iitem.getMaxStackSize()) item.stackSize=item.getMaxStackSize(); + + if(item.isItemEnchantable() && rand.nextInt(3)==0){ + EnchantmentHelper.addRandomEnchantment(rand, item, 3*ld+rand.nextInt(10)); + } + + EntityItem e=new EntityItem(world, x,h-1.5*rand.nextDouble(),z, item); + world.spawnEntityInWorld(e); + + break; + } + sum+=cc.weight; + } + } + } + + @Override + public void failure() { + + } + + @Override + public String getMagicCircleName(){ + return "fbs.harvest"; + } + + public int getHeight(){ + int x= MathHelper.floor_double(player.posX); + int y= MathHelper.floor_double(player.posY+player.getEyeHeight()); + int z= MathHelper.floor_double(player.posZ); + + if(world.getHeightValue(x,z)