From 753cc02b152c83dc1067847684ddc17011ddd283 Mon Sep 17 00:00:00 2001 From: Namikon Date: Thu, 2 Jul 2015 16:09:32 +0200 Subject: Moved from Bitbucket to Github. We're open source, yaay --- .../galacticgreg/api/ISpaceObjectGenerator.java | 51 ++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 src/main/java/bloodasp/galacticgreg/api/ISpaceObjectGenerator.java (limited to 'src/main/java/bloodasp/galacticgreg/api/ISpaceObjectGenerator.java') diff --git a/src/main/java/bloodasp/galacticgreg/api/ISpaceObjectGenerator.java b/src/main/java/bloodasp/galacticgreg/api/ISpaceObjectGenerator.java new file mode 100644 index 0000000000..b51e5facb3 --- /dev/null +++ b/src/main/java/bloodasp/galacticgreg/api/ISpaceObjectGenerator.java @@ -0,0 +1,51 @@ +package bloodasp.galacticgreg.api; + +import java.util.List; + +import bloodasp.galacticgreg.api.Enums.SpaceObjectType; +import net.minecraft.util.Vec3; + +public interface ISpaceObjectGenerator { + Vec3 getCenterPoint(); + /** + * Set the center-point of the object to generate, by providing X, Y and Z directly + * @param pX + * @param pY + * @param pZ + */ + void setCenterPoint(int pX, int pY, int pZ); + + /** + * Set the center-point of the object to generate, by providing a Vec3 instance + * @param pCenter + */ + void setCenterPoint(Vec3 pCenter); + List getStructure(); + + /** + * Calculate the structure + * Called after randomize() + */ + void calculate(); + + /** + * Randomize the structure. + * Called before calculate() + * @param pSizeMin The minimum size for the structure. It is up to you how you handle this value. it's what the user sets in his config file + * @param pSizeMax The maximum size for the structure. It is up to you how you handle this value. it's what the user sets in his config file + */ + void randomize(int pSizeMin, int pSizeMax); + + /** + * Define the type of the generator. OreAsteroid will be used to spawn ores at given coordinates, + * where NonOreSchematic will use the Blocks provided in the structural information to generate your structure + * @return + */ + SpaceObjectType getType(); + + + /** + * This function is called every time the generator shall be reset in order to generate a blank, new structure + */ + void reset(); +} -- cgit