Jump to content

[1.8][Solved] Clay-like Generation


NathanHam89

Recommended Posts

So I am relatively new to Minecraft Modding but I'm trying to generate a block I have called Fireclay into the world the same way clay does, so far I have achieved this:

http://pastebin.com/ZYTU5Fti-FireClayGen Class

(Copied from the clay generation and modified)

http://pastebin.com/aS0QAnPN-Ore Gen/World Gen Class

http://pastebin.com/2Nz3rPNJ-The World Gen Registry

I am aware that I need to enter the FireClayGen method under generateOverworld, however I am abit stuck.

I also have an error under FireClayGen on:

public class FireClayGen extends WorldGenerator{

which asks me to add the unimplemented methods.

 

 

Link to comment
Share on other sites

Okay it's good now

package com.penumbral.steelworks.world;

import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.init.Blocks;
import net.minecraft.util.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenerator;

import com.penumbral.steelworks.init.SteelworksBlocks;

public class FireClayGen extends WorldGenerator{

private final Block blockToGen;
    private final int numberOfBlocks;
    
    public FireClayGen(Block block, int p_i2011_1_)
    {
        this.blockToGen = SteelworksBlocks.fire_clayblock;
        this.numberOfBlocks = p_i2011_1_;
    }

	public boolean generate(World world1, Random rand, BlockPos pos)
    {
        if (world1.getBlockState(pos).getBlock().getMaterial() != Material.water)
        {
            return false;
        }
        else
        {
            int i = rand.nextInt(this.numberOfBlocks - 2) + 2;
            byte b0 = 1;

            for (int j = pos.getX() - i; j <= pos.getX() + i; ++j)
            {
                for (int k = pos.getZ() - i; k <= pos.getZ() + i; ++k)
                {
                    int l = j - pos.getX();
                    int i1 = k - pos.getZ();

                    if (l * l + i1 * i1 <= i * i)
                    {
                        for (int j1 = pos.getY() - b0; j1 <= pos.getY() + b0; ++j1)
                        {
                            BlockPos blockpos1 = new BlockPos(j, j1, k);
                            Block block = world1.getBlockState(blockpos1).getBlock();

                            if (block == Blocks.dirt || block == blockToGen)
                            {
                                world1.setBlockState(blockpos1, this.blockToGen.getDefaultState(), 2);
                            }
                        }
                    }
                }
            }

            return false;
        }
  }
}


Now I just need to get it to generate

Link to comment
Share on other sites

Sorry, I'm still trying to do it:

package com.penumbral.steelworks.world;

import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.BlockStone;
import net.minecraft.block.state.IBlockState;
import net.minecraft.block.state.pattern.BlockHelper;
import net.minecraft.init.Blocks;
import net.minecraft.util.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.chunk.IChunkProvider;
import net.minecraft.world.gen.feature.WorldGenMinable;
import net.minecraftforge.fml.common.IWorldGenerator;

import com.penumbral.steelworks.init.SteelworksBlocks;

public class OreGeneration implements IWorldGenerator{

@Override
public void generate(Random random, int chunkX, int chunkZ, World world,
		IChunkProvider chunkGenerator, IChunkProvider chunkProvider) {
	switch(world.provider.getDimensionId())
	{
	case 1:
		generateEnd(world, random, chunkX * 16, chunkZ * 16); break;
	case 0:
		generateOverworld(world, random, chunkX * 16, chunkZ * 16); break;
	case -1:
		generateNether(world, random, chunkX * 16, chunkZ * 16); break;
	}
}

private void generateEnd(World world, Random random, int x, int z) {

}

public void generateOverworld(World world, Random random, int x, int z) {

	generateOre(SteelworksBlocks.fire_clayblock, world, random, x, z, 4, 8, 100, 10, 64);
	new FireClayGen().generate(world, random, pos);
}

private void generateNether(World world, Random random, int x, int z) {

}

public void generateOre(Block block, World world, Random random, int posX, int posZ, int minVein, int maxVein, int spawnChance, int minY, int maxY)
{
	WorldGenMinable gen = new WorldGenMinable(block.getDefaultState(), (minVein + random.nextInt(maxVein - minVein)), BlockHelper.forBlock(Blocks.stone));
	for (int i = 0; i < spawnChance; i++) {
		int xPos = posX + random.nextInt(16);
		int yPos = minY + random.nextInt(maxY - minY);
		int zPos = posZ + random.nextInt(16);
		gen.generate(world, random, new BlockPos(xPos, yPos, zPos));
	}
}
}

 

package com.penumbral.steelworks.world;

import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.init.Blocks;
import net.minecraft.util.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenerator;

import com.penumbral.steelworks.init.SteelworksBlocks;

public class FireClayGen extends WorldGenerator{

private final Block blockToGen;
    private final int numberOfBlocks;
    
    public FireClayGen(Block block, int p_i2011_1_)
    {
        this.blockToGen = SteelworksBlocks.fire_clayblock;
        this.numberOfBlocks = p_i2011_1_;
    }

	public boolean generate(World world, Random random, BlockPos pos)
    {
        if (world.getBlockState(pos).getBlock().getMaterial() != Material.water)
        {
            return false;
        }
        else
        {
            int i = random.nextInt(this.numberOfBlocks - 2) + 2;
            byte b0 = 1;

            for (int j = pos.getX() - i; j <= pos.getX() + i; ++j)
            {
                for (int k = pos.getZ() - i; k <= pos.getZ() + i; ++k)
                {
                    int l = j - pos.getX();
                    int i1 = k - pos.getZ();

                    if (l * l + i1 * i1 <= i * i)
                    {
                        for (int j1 = pos.getY() - b0; j1 <= pos.getY() + b0; ++j1)
                        {
                            BlockPos blockpos1 = new BlockPos(j, j1, k);
                            Block block = world.getBlockState(blockpos1).getBlock();

                            if (block == Blocks.dirt || block == blockToGen)
                            {
                                world.setBlockState(blockpos1, this.blockToGen.getDefaultState(), 2);
                            }
                        }
                    }
                }
            }

            return false;
        }
  }
}

 

Just unsure about what to put for

new FireClayGen().generate(world, random, pos);

I understand I most probably need to do something with the BlockPos

Link to comment
Share on other sites

I think you have to create a new BlockPos based on the x and z values passed into the generateOverworld function.  Granted, using these values as-is will only generate your blocks in the corner of the chunk closest to the origin, so you have to add some randomness to the position you use for the generate() function if you don't want this result.  Also, you have to find the height you want to generate at and include that in the BlockPos.

 

I haven't worked with 1.8 yet, but it seems that not a lot has changed between 1.7 and 1.8 when it comes to determining a location in Minecraft.  Try looking at some tutorials for 1.7 and see if you can adapt them to 1.8

Link to comment
Share on other sites

Maybe something like this then?

	public void generateOverworld(World world, Random random, int x, int z) {

	int x1 = x + random.nextInt(16);
	int y = 0 + random.nextInt(64-0);	
	int z1 = z + random.nextInt(16);

	generateOre(SteelworksBlocks.fire_clayblock, world, random, x, z, 4, 8, 100, 10, 64);
	new FireClayGen().generate(world, random, new BlockPos(x1, y, z1));
}

However, I have an error under

new FireClayGen()

Link to comment
Share on other sites

Actually I tried moving this to here and this looks better:

package com.penumbral.steelworks.world;

import java.util.Random;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.init.Blocks;
import net.minecraft.util.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenerator;

import com.penumbral.steelworks.init.SteelworksBlocks;

public class FireClayGen extends WorldGenerator{

public final Block blockToGen;
    public final int numberOfBlocks;
    
    FireClayGen clayGen = new FireClayGen(blockToGen, numberOfBlocks);
    
    public FireClayGen(Block block, int p_i2011_1_)
    {
        this.blockToGen = SteelworksBlocks.fire_clayblock;
        this.numberOfBlocks = p_i2011_1_;
    }

	public boolean generate(World world, Random random, BlockPos pos)
    {
        if (world.getBlockState(pos).getBlock().getMaterial() != Material.water)
        {
            return false;
        }
        else
        {
            int i = random.nextInt(this.numberOfBlocks - 2) + 2;
            byte b0 = 1;

            for (int j = pos.getX() - i; j <= pos.getX() + i; ++j)
            {
                for (int k = pos.getZ() - i; k <= pos.getZ() + i; ++k)
                {
                    int l = j - pos.getX();
                    int i1 = k - pos.getZ();

                    if (l * l + i1 * i1 <= i * i)
                    {
                        for (int j1 = pos.getY() - b0; j1 <= pos.getY() + b0; ++j1)
                        {
                            BlockPos blockpos1 = new BlockPos(j, j1, k);
                            Block block = world.getBlockState(blockpos1).getBlock();

                            if (block == Blocks.dirt || block == blockToGen)
                            {
                                world.setBlockState(blockpos1, this.blockToGen.getDefaultState(), 2);
                            }
                        }
                    }
                }
            }

            return false;
        }
  }
}


Link to comment
Share on other sites

Okay I think this is it, sorry about that

(new FireClayGen(SteelworksBlocks.fire_clayblock, 15)).generate(world, random, BlockPos(x1, y, z1));

It just doesn't recognise the BlockPos, this is what I have for the generate:

public boolean generate(World world, Random random, BlockPos pos)

Link to comment
Share on other sites

However it does seem to appear that it generates less frequently than normal clay but generates in a larger cluster

You have to play with the number 15, as this is the number of blocks, the larger it is, the more generates, I guess  :D

(new FireClayGen(SteelworksBlocks.fire_clayblock, 15)).generate(world, random, new BlockPos(x1, y, z1));

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • so basically another rundown of my probelm. Im the admin of a 1.20.1 modded server. Were using forge 47.2.0 but tested this issue in other forge versions too on sevrer and client side. so the forge version isnt the issue. The bug happens in following instances. Were using the attacks of the jujutsucraft mod by orca normally. And for everyone that stands there nothing changes. But everyone who wasnt in the chunks before or who relogins again those chunks will appear invisible for the most part. I tried fixing this be removing and adding following mods in many combinations. Embeddium, canary, memoryleakfix, ai improvements, Krypton reforges, better chunkloading, radium reforged, embeddium plus, farsight, betterchunkloading, oculus I tested most of these mods alone and in differents combinations with each other and without the mods. What i noticed is zhat when i removed  . most invisible chunks will return or semi return. and only ine or two chunks stay invisible. I rechanged those mids mostly on the cöient side but also some in the serveside. Ir most likely isnt an issue with another non performance mod since i noticed this thing with embeddium. Ans also the problem wasnt there im the beginning of the server. Granted since then we updated some of the mods that add content and their lib mod. But i went to every big mods discord and community that we have and i didnt find someone else havinf that chunk problem. Heres the link to a video of the Problem. https://streamable.com/9v1if2     heres the link to the modlist: https://ibb.co/myF8dtX     Pleaee im foghting for months with this problem. All the performance mods kn the modlist are for sure not the issue i tested without all of them.
    • It looks like you're only setting the health if the thing you are hitting is a player.  
    • It sounds like you accidentally have two items that are both named "orange". Ensure that you give items unique names in the string when you register them. That's one of the more annoying errors to track down if you don't know what's causing it, though.
    • when i tried downloading blockfront from curseforge for version 1.20.1 i get the winrar file  and that i extract and i just get the "manifest.json" file no mod when exctracted
    • I have managed to implement your code after finally managing to sort out my error with exporting to .zip, though when the game launches, it will not allow me to proceed further and gives this error:   Caused by: java.lang.IllegalArgumentException: Duplicate registration orange   I have checked over my code and no errors or warnings are present that would affect my orange item. I am not sure what to do here. (It is only registered in the ModItems, as it should be).
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.