62 lines
2.0 KiB
Markdown
62 lines
2.0 KiB
Markdown
# bevy_spatial
|
|
|
|
<p align="center">
|
|
<img src="https://i.laundmo.com/tENe0/rozUsOnA55.png/raw">
|
|
</p>
|
|
|
|
A bevy plugin to track your entities in spatial indices and query them.
|
|
|
|

|
|
|
|
Currently implemented features:
|
|
| Feature | Description |
|
|
| ------------------ | -------------------------------------------------------------------------------------------------------------------- |
|
|
| `kdtree` (default) | KD-Tree for spatial lookups which is fully recreated on update, but fast to recreate. Works well in most situations. |
|
|
|
|
```rust
|
|
use bevy_spatial::{AutomaticUpdate, KDTree3, TransformMode, SpatialAccess};
|
|
|
|
#[derive(Component, Default)]
|
|
struct TrackedByKDTree;
|
|
|
|
fn main() {
|
|
App::new()
|
|
.add_plugins(AutomaticUpdate::<TrackedByKDTree>::new()
|
|
.with_frequency(Duration::from_secs_f32(0.3))
|
|
.with_transform(TransformMode::GlobalTransform))
|
|
.add_systems(Update, use_neighbour);
|
|
// ...
|
|
}
|
|
|
|
type NNTree = KDTree3<TrackedByKDTree>; // type alias for later
|
|
|
|
// spawn some entities with the TrackedByKDTree component
|
|
|
|
fn use_neighbour(tree: Res<NNTree>){
|
|
if let Some((pos, entity)) = tree.nearest_neighbour(Vec3::ZERO) {
|
|
// pos: Vec3
|
|
// do something with the nearest entity here
|
|
}
|
|
}
|
|
```
|
|
|
|
For more details on usage see [Examples](https://github.com/laundmo/bevy-spatial/tree/main/examples)
|
|
|
|
## compatible bevy versions
|
|
|
|
| bevy | bevy_spatial |
|
|
|------|--------------|
|
|
| 0.16 | 0.11.0 |
|
|
| 0.15 | 0.10.0 |
|
|
| 0.14 | 0.9.1 |
|
|
| 0.13 | 0.8.0 |
|
|
| 0.12 | 0.7.0 |
|
|
| 0.11 | 0.6.0 |
|
|
| 0.10 | 0.5.0 |
|
|
| 0.9 | 0.4.0 |
|
|
| 0.8 | 0.3.0 |
|
|
| 0.8 | 0.2.1 |
|
|
| 0.7 | 0.1 |
|
|
|
|
wasm caveats: Since the rayon acceleration for kdtree is enabled by default, but rayon doesn't work on wasm, for projects targeting wasm you'll need to disable default features for bevy-spatial and re-enable `kdtree`
|