All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.malisis.core.block.IBlockComponent Maven / Gradle / Ivy

Go to download

MalisisCore is a framework dedicated to simplify many processes required during a mod development.

There is a newer version: 1.12.2-6.4.0
Show newest version
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2014 Ordinastie
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

package net.malisis.core.block;

import java.util.List;
import java.util.Random;

import net.malisis.core.item.MalisisItemBlock;
import net.minecraft.block.Block;
import net.minecraft.block.material.MapColor;
import net.minecraft.block.properties.IProperty;
import net.minecraft.block.state.IBlockState;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.entity.EntityLivingBase;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.EnumHand;
import net.minecraft.util.math.AxisAlignedBB;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World;
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;

/**
 * @author Ordinastie
 *
 */
public interface IBlockComponent extends IComponent
{
	/**
	 * Gets the {@link IProperty} used by this {@link IBlockComponent}.
* Only use this if the component only has one property. * * @return the property */ public IProperty getProperty(); /** * Gets the all the {@link IProperty properties} used by this {@link IBlockComponent}. * * @return the properties */ public default IProperty[] getProperties() { if (getProperty() == null) return new IProperty[0]; return new IProperty[] { getProperty() }; } /** * Sets the default values for the {@link IBlockState}. * * @param block the block * @param state the state */ public IBlockState setDefaultState(Block block, IBlockState state); public default Item getItem(Block block) { return new MalisisItemBlock(block); } /** * Gets the unlocalized name for the specific {@link IBlockState}. * * @param block the block * @param state the state * @return the unlocalized name */ public default String getUnlocalizedName(Block block, IBlockState state) { return null; } //#region Events /** * Called when the {@link Block} is placed in the {@link World}. * * @param block the block * @param world the world * @param pos the pos * @param state the state * @param facing the facing * @param hitX the hit x * @param hitY the hit y * @param hitZ the hit z * @param meta the meta * @param placer the placer * @return the i block state */ public default IBlockState onBlockPlaced(Block block, World world, BlockPos pos, IBlockState state, EnumFacing facing, float hitX, float hitY, float hitZ, int meta, EntityLivingBase placer) { return state; } /** * Called when the {@link Block} is placed by an {@link EntityLivingBase} in the {@link World} * * @param block the block * @param world the world * @param pos the pos * @param state the state * @param placer the placer * @param stack the stack */ public default void onBlockPlacedBy(Block block, World world, BlockPos pos, IBlockState state, EntityLivingBase placer, ItemStack stack) {} /** * Called when the {@link Block} is right-clicked by the player. * * @param block the block * @param world the world * @param pos the pos * @param state the state * @param player the player * @param hand * @param side the side * @param hitX the hit x * @param hitY the hit y * @param hitZ the hit z * @return true, if successful */ public default boolean onBlockActivated(Block block, World world, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand, EnumFacing side, float hitX, float hitY, float hitZ) { return false; } /** * Called when a neighboring {@link Block} changes. * * @param block the block * @param world the world * @param pos the pos * @param state the state * @param neighborBlock the neighbor block */ public default void onNeighborBlockChange(Block block, World world, BlockPos pos, IBlockState state, Block neighborBlock) { } /** * Called when the {@link Block} is broken. * * @param block the block * @param world the world * @param pos the pos * @param state the state */ public default void breakBlock(Block block, World world, BlockPos pos, IBlockState state) {} //#end Events /** * Gets the bounding box for the {@link Block}. * * @param world the world * @param pos the pos * @param type the type * @return the bounding box */ public default AxisAlignedBB getBoundingBox(Block block, IBlockAccess world, BlockPos pos, IBlockState state, BoundingBoxType type) { return null; } /** * Gets the bounding boxes for the {@link Block}. * * @param block the block * @param world the world * @param pos the pos * @param type the type * @return the bounding boxes */ public default AxisAlignedBB[] getBoundingBoxes(Block block, IBlockAccess world, BlockPos pos, IBlockState state, BoundingBoxType type) { return null; } /** * Whether the {@link Block} can be placed on the side of another block. * * @param block the block * @param world the world * @param pos the pos * @param side the side * @return true, if successful */ public default boolean canPlaceBlockOnSide(Block block, World world, BlockPos pos, EnumFacing side) { return true; } /** * Whether the {@link Block} can be placed at the position. * * @param world the world * @param pos the pos * @return true, if successful */ public default boolean canPlaceBlockAt(Block block, World world, BlockPos pos) { return true; } //#region Sub-Blocks /** * Gets the damage value for the item when the {@link Block} is dropped. * * @param block the block * @param state the state * @return the int */ public default int damageDropped(Block block, IBlockState state) { return 0; } /** * Fills the list with the sub-blocks associated with this {@link Block}. * * @param block the block * @param item the item * @param tab the tab * @param list the list */ @SideOnly(Side.CLIENT) public default void getSubBlocks(Block block, Item item, CreativeTabs tab, List list) {} //#end Sub-blocks //#region Colors /** * Get the {@link MapColor} for this {@link Block} and the given {@link IBlockState}. * * @param block the block * @param state the state * @return the map color */ public default MapColor getMapColor(Block block, IBlockState state) { return null; } //#end Colors //#region State<->Meta /** * Gets the {@link IBlockState} from meta. * * @param block the block * @param meta the meta * @return the state from meta */ public default IBlockState getStateFromMeta(Block block, IBlockState state, int meta) { return state; } /** * Gets the metadata from the {@link IBlockState}. * * @param block the block * @param state the state * @return the meta from state */ public default int getMetaFromState(Block block, IBlockState state) { return 0; } //#end State<->Meta //#region Fullness /** * Checks whether a side should be rendered. * * @param block the block * @param world the world * @param pos the pos * @param state the state * @param side the side * @return the boolean */ public default Boolean shouldSideBeRendered(Block block, IBlockAccess world, BlockPos pos, IBlockState state, EnumFacing side) { return null; } /** * Checks whether this {@link IBlockComponent} represents a full {@link Block}. * * @param block the block * @param state the state * @return the boolean */ public default Boolean isFullBlock(Block block, IBlockState state) { return null; } /** * Checks whether this {@link IBlockComponent} represents a full cube. * * @param block the block * @param state the state * @return the boolean */ public default Boolean isFullCube(Block block, IBlockState state) { return null; } /** * Checks whether this {@link IBlockComponent} represents an opaque cube. * * @param block the block * @param state the state * @return the boolean */ public default Boolean isOpaqueCube(Block block, IBlockState state) { return null; } //#end Fullness //#region Other /** * Gets the mixed brightness for the {@link Block}. * * @param block the block * @param world the world * @param pos the pos * @param state * @return the mixed brightness for block */ public default Integer getPackedLightmapCoords(Block block, IBlockAccess world, BlockPos pos, IBlockState state) { return null; } /** * Gets the item dropped by the {@link Block} when broken. * * @param state the state * @param rand the rand * @param fortune the fortune * @return the item dropped */ public default Item getItemDropped(Block block, IBlockState state, Random rand, int fortune) { return null; } /** * Quantity the quantity dropped by the {@link Block} when broken. * * @param block the block * @param state the state * @param fortune the fortune * @param random the random * @return the integer */ public default Integer quantityDropped(Block block, IBlockState state, int fortune, Random random) { return null; } /** * Gets the light opacity for the {@link Block}. * * @param block the block * @param world the world * @param pos the pos * @param state * @return the light opacity */ public default Integer getLightOpacity(Block block, IBlockAccess world, BlockPos pos, IBlockState state) { return null; } //#end Other }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy