mirror of
https://github.com/italicsjenga/valence.git
synced 2025-01-10 06:41:30 +11:00
Use a struct to store block collision shapes (#334)
## Description Created a new CollisionShape struct for blocks (was previously an [f64; 6]). ## Test Plan Explain the steps necessary to test your changes. If you used a playground, include the code in the details below. Steps: 1. Run the following code <details> <summary>Playground</summary> ```rust use valence_block; fn main() { let shapes = valence_block::BlockState::STONE.collision_shapes(); println!("{:?}", shapes.collect::<Vec<_>>()); // [CollisionShape { min_x: 0.0, min_y: 0.0, min_z: 0.0, max_x: 1.0, max_y: 1.0, max_z: 1.0 }] let shapes = valence_block::BlockState::OAK_STAIRS.collision_shapes(); println!("{:?}", shapes.collect::<Vec<_>>()); // [CollisionShape { min_x: 0.0, min_y: 0.0, min_z: 0.0, max_x: 1.0, max_y: 0.5, max_z: 1.0 }, CollisionShape { min_x: 0.0, min_y: 0.5, min_z: 0.0, max_x: 1.0, max_y: 1.0, max_z: 0.5 }] } ``` </details>
This commit is contained in:
parent
8897eeacb9
commit
81044440dd
|
@ -6,6 +6,7 @@ edition.workspace = true
|
||||||
[dependencies]
|
[dependencies]
|
||||||
valence_core.workspace = true
|
valence_core.workspace = true
|
||||||
anyhow.workspace = true
|
anyhow.workspace = true
|
||||||
|
glam.workspace = true
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
anyhow.workspace = true
|
anyhow.workspace = true
|
||||||
|
|
|
@ -161,14 +161,10 @@ fn build() -> anyhow::Result<TokenStream> {
|
||||||
let max_y = s.max_y;
|
let max_y = s.max_y;
|
||||||
let max_z = s.max_z;
|
let max_z = s.max_z;
|
||||||
quote! {
|
quote! {
|
||||||
[
|
Aabb {
|
||||||
#min_x,
|
min: dvec3(#min_x, #min_y, #min_z),
|
||||||
#min_y,
|
max: dvec3(#max_x, #max_y, #max_z),
|
||||||
#min_z,
|
}
|
||||||
#max_x,
|
|
||||||
#max_y,
|
|
||||||
#max_z,
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -577,6 +573,9 @@ fn build() -> anyhow::Result<TokenStream> {
|
||||||
let prop_value_count = prop_values.len();
|
let prop_value_count = prop_values.len();
|
||||||
|
|
||||||
Ok(quote! {
|
Ok(quote! {
|
||||||
|
use valence_core::aabb::Aabb;
|
||||||
|
use glam::dvec3;
|
||||||
|
|
||||||
/// Represents the state of a block. This does not include block entity data such as
|
/// Represents the state of a block. This does not include block entity data such as
|
||||||
/// the text on a sign, the design on a banner, or the content of a spawner.
|
/// the text on a sign, the design on a banner, or the content of a spawner.
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Default, Hash)]
|
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Default, Hash)]
|
||||||
|
@ -682,11 +681,11 @@ fn build() -> anyhow::Result<TokenStream> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const SHAPES: [[f64; 6]; #shape_count] = [
|
const SHAPES: [Aabb; #shape_count] = [
|
||||||
#(#shapes,)*
|
#(#shapes,)*
|
||||||
];
|
];
|
||||||
|
|
||||||
pub fn collision_shapes(self) -> impl ExactSizeIterator<Item = [f64; 6]> + FusedIterator + Clone {
|
pub fn collision_shapes(self) -> impl ExactSizeIterator<Item = Aabb> + FusedIterator + Clone {
|
||||||
let shape_idxs: &'static [u16] = match self.0 {
|
let shape_idxs: &'static [u16] = match self.0 {
|
||||||
#state_to_collision_shapes_arms
|
#state_to_collision_shapes_arms
|
||||||
_ => &[],
|
_ => &[],
|
||||||
|
|
Loading…
Reference in a new issue