Advertisement
ViiRuS

Tree Generation Tutorial #1

Jan 2nd, 2012
856
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 11.02 KB | None | 0 0
  1. mod_ file
  2. ------------------------
  3. public static Block candylog = new cl_BlockCandyLog(211).setHardness(1.0F).setResistance(2F).setBlockName("Log");
  4.     public static Block leaves = new cl_leaves(214,0).setHardness(0.2F).setLightOpacity(1).setBlockName("leaves").setRequiresSelfNotify();
  5.  
  6. cl_leaves
  7. ------------------------
  8. package net.minecraft.src;
  9.  
  10. import java.util.Random;
  11. import net.minecraft.src.Block;
  12. import net.minecraft.src.BlockLeavesBase;
  13. import net.minecraft.src.ColorizerFoliage;
  14. import net.minecraft.src.Entity;
  15. import net.minecraft.src.EntityPlayer;
  16. import net.minecraft.src.IBlockAccess;
  17. import net.minecraft.src.Item;
  18. import net.minecraft.src.ItemStack;
  19. import net.minecraft.src.Material;
  20. import net.minecraft.src.StatList;
  21. import net.minecraft.src.World;
  22.  
  23. public class cl_leaves extends BlockLeavesBase{
  24.    
  25.     int fancy = ModLoader.addOverride("/terrain.png", "/candyland/candyleave1fancygraphics.png");
  26.     int fast = ModLoader.addOverride("/terrain.png", "/candyland/candyleave1fastgraphics.png");
  27.    
  28.        private int baseIndexInPNG;
  29.        int[] adjacentTreeBlocks;
  30.  
  31.  
  32.        protected cl_leaves(int var1, int var2) {
  33.           super(var1, var2, Material.leaves, false);
  34.           this.baseIndexInPNG = var2;
  35.           this.setTickOnLoad(true);
  36.        }
  37.  
  38.      /*  public int getBlockColor() {
  39.           double var1 = 0.5D;
  40.           double var3 = 1.0D;
  41.           return ColorizerFoliage.getFoliageColor(var1, var3);
  42.        }
  43.  
  44.        public int getRenderColor(int var1) {
  45.           return (var1 & 1) == 1?ColorizerFoliage.getFoliageColorPine():((var1 & 2) == 2?ColorizerFoliage.getFoliageColorBirch():ColorizerFoliage.getFoliageColorBasic());
  46.        }
  47.  
  48.        public int colorMultiplier(IBlockAccess var1, int var2, int var3, int var4) {
  49.           int var5 = var1.getBlockMetadata(var2, var3, var4);
  50.           return (var5 & 1) == 1?ColorizerFoliage.getFoliageColorPine():((var5 & 2) == 2?ColorizerFoliage.getFoliageColorBirch():var1.getWorldChunkManager().getBiomeGenAt(var2, var4).getFoliageColorAtCoords(var1, var2, var3, var4));
  51.        }*/
  52.  
  53.        public void onBlockRemoval(World var1, int var2, int var3, int var4) {
  54.           byte var5 = 1;
  55.           int var6 = var5 + 1;
  56.           if(var1.checkChunksExist(var2 - var6, var3 - var6, var4 - var6, var2 + var6, var3 + var6, var4 + var6)) {
  57.              for(int var7 = -var5; var7 <= var5; ++var7) {
  58.                 for(int var8 = -var5; var8 <= var5; ++var8) {
  59.                    for(int var9 = -var5; var9 <= var5; ++var9) {
  60.                       int var10 = var1.getBlockId(var2 + var7, var3 + var8, var4 + var9);
  61.                       if(var10 == mod_raintest.leaves.blockID) {
  62.                          int var11 = var1.getBlockMetadata(var2 + var7, var3 + var8, var4 + var9);
  63.                          var1.setBlockMetadata(var2 + var7, var3 + var8, var4 + var9, var11 | 8);
  64.                       }
  65.                    }
  66.                 }
  67.              }
  68.           }
  69.  
  70.        }
  71.  
  72.        public void updateTick(World var1, int var2, int var3, int var4, Random var5) {
  73.           if(!var1.multiplayerWorld) {
  74.              int var6 = var1.getBlockMetadata(var2, var3, var4);
  75.              if((var6 & 8) != 0 && (var6 & 4) == 0) {
  76.                 byte var7 = 4;
  77.                 int var8 = var7 + 1;
  78.                 byte var9 = 32;
  79.                 int var10 = var9 * var9;
  80.                 int var11 = var9 / 2;
  81.                 if(this.adjacentTreeBlocks == null) {
  82.                    this.adjacentTreeBlocks = new int[var9 * var9 * var9];
  83.                 }
  84.  
  85.                 int var12;
  86.                 if(var1.checkChunksExist(var2 - var8, var3 - var8, var4 - var8, var2 + var8, var3 + var8, var4 + var8)) {
  87.                    int var13;
  88.                    int var14;
  89.                    int var15;
  90.                    for(var12 = -var7; var12 <= var7; ++var12) {
  91.                       for(var13 = -var7; var13 <= var7; ++var13) {
  92.                          for(var14 = -var7; var14 <= var7; ++var14) {
  93.                             var15 = var1.getBlockId(var2 + var12, var3 + var13, var4 + var14);
  94.                             if(var15 == mod_raintest.candylog.blockID) {
  95.                                this.adjacentTreeBlocks[(var12 + var11) * var10 + (var13 + var11) * var9 + var14 + var11] = 0;
  96.                             } else if(var15 == mod_raintest.leaves.blockID) {
  97.                                this.adjacentTreeBlocks[(var12 + var11) * var10 + (var13 + var11) * var9 + var14 + var11] = -2;
  98.                             } else {
  99.                                this.adjacentTreeBlocks[(var12 + var11) * var10 + (var13 + var11) * var9 + var14 + var11] = -1;
  100.                             }
  101.                          }
  102.                       }
  103.                    }
  104.  
  105.                    for(var12 = 1; var12 <= 4; ++var12) {
  106.                       for(var13 = -var7; var13 <= var7; ++var13) {
  107.                          for(var14 = -var7; var14 <= var7; ++var14) {
  108.                             for(var15 = -var7; var15 <= var7; ++var15) {
  109.                                if(this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11) * var9 + var15 + var11] == var12 - 1) {
  110.                                   if(this.adjacentTreeBlocks[(var13 + var11 - 1) * var10 + (var14 + var11) * var9 + var15 + var11] == -2) {
  111.                                      this.adjacentTreeBlocks[(var13 + var11 - 1) * var10 + (var14 + var11) * var9 + var15 + var11] = var12;
  112.                                   }
  113.  
  114.                                   if(this.adjacentTreeBlocks[(var13 + var11 + 1) * var10 + (var14 + var11) * var9 + var15 + var11] == -2) {
  115.                                      this.adjacentTreeBlocks[(var13 + var11 + 1) * var10 + (var14 + var11) * var9 + var15 + var11] = var12;
  116.                                   }
  117.  
  118.                                   if(this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11 - 1) * var9 + var15 + var11] == -2) {
  119.                                      this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11 - 1) * var9 + var15 + var11] = var12;
  120.                                   }
  121.  
  122.                                   if(this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11 + 1) * var9 + var15 + var11] == -2) {
  123.                                      this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11 + 1) * var9 + var15 + var11] = var12;
  124.                                   }
  125.  
  126.                                   if(this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11) * var9 + (var15 + var11 - 1)] == -2) {
  127.                                      this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11) * var9 + (var15 + var11 - 1)] = var12;
  128.                                   }
  129.  
  130.                                   if(this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11) * var9 + var15 + var11 + 1] == -2) {
  131.                                      this.adjacentTreeBlocks[(var13 + var11) * var10 + (var14 + var11) * var9 + var15 + var11 + 1] = var12;
  132.                                   }
  133.                                }
  134.                             }
  135.                          }
  136.                       }
  137.                    }
  138.                 }
  139.  
  140.                 var12 = this.adjacentTreeBlocks[var11 * var10 + var11 * var9 + var11];
  141.                 if(var12 >= 0) {
  142.                    var1.setBlockMetadata(var2, var3, var4, var6 & -9);
  143.                 } else {
  144.                    this.removeLeaves(var1, var2, var3, var4);
  145.                 }
  146.              }
  147.  
  148.           }
  149.        }
  150.  
  151.        private void removeLeaves(World var1, int var2, int var3, int var4) {
  152.           this.dropBlockAsItem(var1, var2, var3, var4, var1.getBlockMetadata(var2, var3, var4), 0);
  153.           var1.setBlockWithNotify(var2, var3, var4, 0);
  154.        }
  155.  
  156.        public int quantityDropped(Random var1) {
  157.           return var1.nextInt(20) == 0?1:0;
  158.        }
  159.  
  160.        public int idDropped(int var1, Random var2, int var3) {
  161.           return Item.cookie.shiftedIndex;
  162.        }
  163.  
  164.        public void harvestBlock(World var1, EntityPlayer var2, int var3, int var4, int var5, int var6) {
  165.           if(!var1.multiplayerWorld && var2.getCurrentEquippedItem() != null && var2.getCurrentEquippedItem().itemID == Item.shears.shiftedIndex) {
  166.              var2.addStat(StatList.mineBlockStatArray[this.blockID], 1);
  167.              this.dropBlockAsItem_do(var1, var3, var4, var5, new ItemStack(mod_raintest.leaves.blockID, 1, var6 & 3));
  168.           } else {
  169.              super.harvestBlock(var1, var2, var3, var4, var5, var6);
  170.           }
  171.  
  172.        }
  173.  
  174.        protected int damageDropped(int var1) {
  175.           return var1 & 3;
  176.        }
  177.  
  178.        /*public boolean isOpaqueCube() {
  179.           return !this.graphicsLevel;
  180.        }*/
  181.  
  182.        public int getBlockTextureFromSideAndMetadata(int var1, int var2) {
  183.           if (ModLoader.getMinecraftInstance().gameSettings.fancyGraphics == true)
  184.           {
  185.               return fancy;
  186.           }else{
  187.               return fast;
  188.           }
  189.        }
  190.  
  191.        /*public void setGraphicsLevel(boolean var1) {
  192.           this.graphicsLevel = var1;
  193.           this.blockIndexInTexture = this.baseIndexInPNG + (var1?0:1);
  194.        }*/
  195.  
  196.        public void onEntityWalking(World var1, int var2, int var3, int var4, Entity var5) {
  197.           super.onEntityWalking(var1, var2, var3, var4, var5);
  198.        }
  199.     }
  200.  
  201.  
  202. cl_candylog
  203. ------------------------
  204.  
  205. package net.minecraft.src;
  206.  
  207. import java.util.Random;
  208.  
  209. import net.minecraft.client.Minecraft;
  210.  
  211. // Referenced classes of package net.minecraft.src:
  212. //            Block, Material, World, BlockLeaves,
  213. //            EntityPlayer
  214.  
  215. public class cl_BlockCandyLog extends Block
  216. {
  217.  
  218.     int top = ModLoader.addOverride("/terrain.png", "/candyland/candylogtop.png");
  219.     int side = ModLoader.addOverride("/terrain.png", "/candyland/candylogside.png");
  220.     public static Minecraft mc = ModLoader.getMinecraftInstance();
  221.    
  222.     protected cl_BlockCandyLog(int i)
  223.     {
  224.         super(i, Material.wood);
  225.        
  226.     }
  227.  
  228.     public int quantityDropped(Random random)
  229.     {
  230.         return 1;
  231.     }
  232.  
  233.     public int idDropped(int i, Random random, int j)
  234.     {
  235.         return mod_raintest.candylog.blockID;
  236.     }
  237.  
  238.     public void harvestBlock(World world, EntityPlayer entityplayer, int i, int j, int k, int l)
  239.     {
  240.         super.harvestBlock(world, entityplayer, i, j, k, l);
  241.     }
  242.    
  243.        
  244.     public int getBlockTextureFromSide(int i)
  245.     {
  246.         if(i == 1 || i == 0)
  247.         {
  248.             return top;
  249.         }
  250.         else
  251.         {
  252.             return side;
  253.         }
  254.     }
  255.    
  256.     public void onBlockRemoval(World var1, int var2, int var3, int var4) {
  257.         byte var5 = 4;
  258.         int var6 = var5 + 1;
  259.         if(var1.checkChunksExist(var2 - var6, var3 - var6, var4 - var6, var2 + var6, var3 + var6, var4 + var6)) {
  260.            for(int var7 = -var5; var7 <= var5; ++var7) {
  261.               for(int var8 = -var5; var8 <= var5; ++var8) {
  262.                  for(int var9 = -var5; var9 <= var5; ++var9) {
  263.                     int var10 = var1.getBlockId(var2 + var7, var3 + var8, var4 + var9);
  264.                     if(var10 == mod_raintest.leaves.blockID) {
  265.                        int var11 = var1.getBlockMetadata(var2 + var7, var3 + var8, var4 + var9);
  266.                        if((var11 & 8) == 0) {
  267.                           var1.setBlockMetadata(var2 + var7, var3 + var8, var4 + var9, var11 | 8);
  268.                        }
  269.                     }
  270.                  }
  271.               }
  272.            }
  273.         }
  274.  
  275.      }
  276. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement