net.malisis.core.block.IBlockComponent Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of malisiscore Show documentation
Show all versions of malisiscore Show documentation
MalisisCore is a framework dedicated to simplify many processes required during a mod development.
/*
* 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