aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/GoodGenerator/util/StructureHelper.java
diff options
context:
space:
mode:
authorGlodBlock <1356392126@qq.com>2021-08-16 22:46:40 +0800
committerGlodBlock <1356392126@qq.com>2021-08-16 22:46:40 +0800
commitc6daf6b4d70ccde55c2a944036cb13656966e991 (patch)
treefe57ed6b65ed9e4c601445eff0627e19fdb0a586 /src/main/java/GoodGenerator/util/StructureHelper.java
parent845cce81a82e1cfd9d404fa1b13490acff96bf35 (diff)
downloadGT5-Unofficial-c6daf6b4d70ccde55c2a944036cb13656966e991.tar.gz
GT5-Unofficial-c6daf6b4d70ccde55c2a944036cb13656966e991.tar.bz2
GT5-Unofficial-c6daf6b4d70ccde55c2a944036cb13656966e991.zip
add Neutron Activator related blocks
Diffstat (limited to 'src/main/java/GoodGenerator/util/StructureHelper.java')
-rw-r--r--src/main/java/GoodGenerator/util/StructureHelper.java61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/main/java/GoodGenerator/util/StructureHelper.java b/src/main/java/GoodGenerator/util/StructureHelper.java
new file mode 100644
index 0000000000..2c5feadab8
--- /dev/null
+++ b/src/main/java/GoodGenerator/util/StructureHelper.java
@@ -0,0 +1,61 @@
+package GoodGenerator.util;
+
+import com.github.technus.tectech.TecTech;
+import com.github.technus.tectech.mechanics.structure.IStructureElement;
+import gregtech.api.enums.Materials;
+import gregtech.api.enums.OrePrefixes;
+import gregtech.api.metatileentity.BaseMetaPipeEntity;
+import gregtech.api.metatileentity.implementations.GT_MetaPipeEntity_Frame;
+import gregtech.api.util.GT_OreDictUnificator;
+import net.minecraft.init.Items;
+import net.minecraft.item.ItemBlock;
+import net.minecraft.item.ItemStack;
+import net.minecraft.tileentity.TileEntity;
+import net.minecraft.util.IIcon;
+import net.minecraft.world.World;
+
+import java.util.Arrays;
+
+public class StructureHelper {
+
+ public static <T>IStructureElement<T> addFrame(Materials aMaterials) {
+ return new IStructureElement<T>() {
+
+ private IIcon[] mIcons;
+
+ @Override
+ public boolean check(T t, World world, int x, int y, int z) {
+ TileEntity tBlock = world.getTileEntity(x, y, z);
+ if (tBlock instanceof BaseMetaPipeEntity) {
+ BaseMetaPipeEntity tFrame = (BaseMetaPipeEntity) tBlock;
+ if (tFrame.isInvalidTileEntity()) return false;
+ if (tFrame.getMetaTileEntity() instanceof GT_MetaPipeEntity_Frame) {
+ return ((GT_MetaPipeEntity_Frame) tFrame.getMetaTileEntity()).mMaterial == aMaterials;
+ }
+ }
+ return false;
+ }
+
+ @Override
+ public boolean spawnHint(T t, World world, int x, int y, int z, ItemStack trigger) {
+ if (mIcons == null) {
+ mIcons = new IIcon[6];
+ Arrays.fill(mIcons, aMaterials.mIconSet.mTextures[OrePrefixes.frameGt.mTextureIndex].getIcon());
+ }
+ TecTech.proxy.hint_particle_tinted(world, x, y, z, mIcons, aMaterials.mRGBa);
+ return true;
+ }
+
+ @Override
+ public boolean placeBlock(T t, World world, int x, int y, int z, ItemStack trigger) {
+ ItemStack tFrame = GT_OreDictUnificator.get(OrePrefixes.frameGt, aMaterials, 1);
+ if (tFrame.getItem() instanceof ItemBlock) {
+ ItemBlock tFrameStackItem = (ItemBlock) tFrame.getItem();
+ return tFrameStackItem.placeBlockAt(tFrame, null, world, x, y, z, 6, 0, 0, 0, Items.feather.getDamage(tFrame));
+ }
+ return false;
+ }
+ };
+ }
+
+}