14 releases (breaking)
0.11.0+mc1.21.4 | Dec 21, 2024 |
---|---|
0.10.3+mc1.21.1 | Oct 23, 2024 |
0.10.2 | Jun 14, 2024 |
0.9.0 | Dec 5, 2023 |
0.4.0 | Nov 19, 2022 |
#642 in Network programming
245 downloads per month
Used in 6 crates
780KB
20K
SLoC
Representation of Minecraft block states.
There's three block types, used for different things. You can (mostly) convert between them with .into()
.
BlockState struct
BlockState
is a struct containing the numerical protocol ID of a block state. This is how blocks are stored in the world.
# use azalea_block::BlockState;
let block_state: BlockState = azalea_block::blocks::CobblestoneWall {
east: azalea_block::properties::WallEast::Low,
north: azalea_block::properties::WallNorth::Low,
south: azalea_block::properties::WallSouth::Low,
west: azalea_block::properties::WallWest::Low,
up: false,
waterlogged: false,
}
.into();
# use azalea_block::BlockState;
let block_state: BlockState = azalea_registry::Block::Jukebox.into();
Block trait
The Block
trait represents a type of a block. With the the Block
trait, you can get some extra things like the string block ID and some information about the block's behavior. Also, the structs that implement the trait contain the block attributes as fields so it's more convenient to get them. Note that this is often used as Box<dyn Block>
.
If for some reason you don't want the Block
trait, set default-features to false.
# use azalea_block::{Block, BlockState};
# let block_state = BlockState::from(azalea_registry::Block::Jukebox);
let block = Box::<dyn Block>::from(block_state);
# use azalea_block::{Block, BlockState};
# let block_state: BlockState = azalea_registry::Block::Jukebox.into();
if let Some(jukebox) = Box::<dyn Block>::from(block_state).downcast_ref::<azalea_block::blocks::Jukebox>() {
// ...
}
azalea_registry::Block enum
This one technically isn't from the azalea-block
crate, but it's still very relevant. It's an enum that contains every block type as a variant without containing any state data (unlike BlockState
and the Block
trait). Converting this into any other block type will use the default state for that block.
Dependencies
~2–2.8MB
~50K SLoC