Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shanecelis/bevy_plane_cut
A plane cut material for bevy
https://github.com/shanecelis/bevy_plane_cut
Last synced: 2 months ago
JSON representation
A plane cut material for bevy
- Host: GitHub
- URL: https://github.com/shanecelis/bevy_plane_cut
- Owner: shanecelis
- License: apache-2.0
- Created: 2024-06-07T10:11:07.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-05T09:59:02.000Z (6 months ago)
- Last Synced: 2024-10-07T18:09:36.150Z (3 months ago)
- Language: Rust
- Homepage:
- Size: 158 KB
- Stars: 7
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# bevy_plane_cut
![Maintenance](https://img.shields.io/badge/maintenance-actively--developed-brightgreen.svg)
[![CI](https://github.com/shanecelis/bevy_plane_cut/actions/workflows/rust.yml/badge.svg)](https://github.com/shanecelis/bevy_plane_cut/actions)
[![crates-io](https://img.shields.io/crates/v/bevy_plane_cut.svg)](https://crates.io/crates/bevy_plane_cut)
[![api-docs](https://docs.rs/bevy_plane_cut/badge.svg)](https://docs.rs/bevy_plane_cut)A plane cut material for the [bevy game engine](https://bevyengine.org).
![simple example](https://github.com/shanecelis/bevy_plane_cut/assets/54390/d220108d-a0c0-4da7-bb84-b5a3dc223463)
# Install
Install the crate.
```sh
cargo add bevy_plane_cut
```# Usage
## Add Plugin to App
```rust,no_run
use bevy::prelude::*;
fn main() {
App::new()
.add_plugins(bevy_plane_cut::PlaneCutPlugin)
.run();
}
```## Add Material to Object
```rust,compile
use bevy::{
prelude::*,
color::palettes::basic,
pbr::ExtendedMaterial,
};
use bevy_plane_cut::*;fn setup(
mut commands: Commands,
mut meshes: ResMut>,
mut materials: ResMut>) {commands.spawn(MaterialMeshBundle {
mesh: meshes.add(Sphere::new(1.0)),
material: materials.add(ExtendedMaterial {
base: StandardMaterial {
base_color: basic::RED.into(),
..default()
},
extension: PlaneCutExt {
plane: Vec4::new(-1.0, 1.0, -2.0, 0.0),
color: Color::linear_rgb(0.0, 0.0, 0.7),
shaded: true,
space: Space::World,
},
}),
..default()
});
}
```# Examples
Run the "simple" example like so:
```sh
cargo run --example simple
```This will show a red sphere with a light rotating around it and blue plane cut.
* `simple` - A red sphere with a plane cut.
* `simple_screenspace` - A red sphere with a plane cut in screen space.
* `moving_cut` - A red sphere with a plane cut moving in and out.## Not Working Examples
![simple_deferred](https://github.com/shanecelis/bevy_plane_cut/assets/54390/0b2fa6f5-6202-4301-b502-8fa37ae74c3f)
* `simple_deferred` - same as simple but using deferred renderer.
NOTE: This one does not look right on my macOS machine.
* `deferred` - A red sphere rendered with deferred renderer. This has no plane
cut at all and it still does not look right. I'm using macOS, so I'd be
curious if it looks correct on other platforms.
* `two_cuts` - This is a material that has been extended by `PlaneCutExt` twice.
However, it has a bug. See `two_cuts.rs` example for more details. PRs welcome!# Compatibility
| bevy_plane_cut | bevy |
|----------------|------|
| 0.2 | 0.14 |
| 0.1 | 0.13 |# License
This crate is licensed under the MIT License or the Apache License 2.0. The
examples are licensed under the CC0 license.# Acknowlegments
* [Clipping a Model with a Plane](https://www.ronja-tutorials.com/post/021-plane-clipping/) by [Ronja](https://eldritch.cafe/@ronja) taught me the technique many years ago.
* [Extending Materials in Bevy 0.12 with Material Extension](https://www.rustadventure.dev/extending-materials-in-bevy-0-12-with-materialextension) by [Chris Biscardi](https://hachyderm.io/@chrisbiscardi) showed off how cool `ExtendedMaterial` is.
* Thanks to [robtfm](https://github.com/robtfm) who wrote the original [extended_material.rs](https://github.com/bevyengine/bevy/blob/release-0.13.2/examples/shader/extended_material.rs) example in bevy.